# HCS12 V1.5 Core User Guide Version 1.2 

Original Release Date: 12 May 2000
Revised: 17 August 2000

## Revision History

| Release Number | Date | Author | Summary of Changes |
| :---: | :---: | :--- | :--- |
| 1.2 | 17 August 2000 |  | Update allocated RAM space table. |
| 1.2 | 13 October 2000 |  | Security enhancements, add core_exp_t2, core_per_t2 <br> outputs and peri_clk2, peri_clk4, and ram_fmts inputs. |
| 1.1 | 21 July 2000 |  | Correct access detail for LSL instruction in appendix B |
| 1.0 | 12 May 2000 |  | Original draft. Distributed only within Motorola |

## Table of Contents

## Section 1 Introduction

1.1 Core Overview ..... 23
1.2 Features ..... 23
1.3 Block Diagram ..... 25
1.4 Architectural Summary ..... 26
1.5 Programming Model ..... 26
1.6 Data Format Summary ..... 27
1.6.1 Data Types ..... 27
1.6.2 Memory Organization ..... 28
1.7 Addressing modes ..... 28
1.8 Instruction Set Overview. ..... 29
1.8.1 Register and Memory Notation ..... 43
1.8.2 Source Form Notation ..... 43
1.8.3 Operation Notation ..... 45
1.8.4 Address Mode Notation ..... 45
1.8.5 Machine Code Notation ..... 46
1.8.6 Access Detail Notation ..... 47
1.8.7 Condition Code State Notation. ..... 49
Section 2 Nomenclature
2.1 References ..... 51
2.2 Units and Measures ..... 51
2.3 Symbology ..... 51
2.4 Terminology ..... 51
Section 3 Core Registers
3.1 Programming Model ..... 53
3.1.1 Accumulators ..... 53
3.1.2 Index Registers ( X and Y ) ..... 54
3.1.3 Stack Pointer (SP) ..... 55
3.1.4 Program Counter (PC) ..... 56
3.1.5 Condition Code Register (CCR) ..... 56
3.2 Core Register Map ..... 58
User Guide - S12CPU15UGefrscale Semiconductor, Inc.
Section 4 Instructions
4.1 Instruction Types ..... 63
4.2 Addressing Modes ..... 63
4.2.1 Effective Address ..... 64
4.2.2 Inherent Addressing Mode ..... 64
4.2.3 Immediate Addressing Mode ..... 64
4.2.4 Direct Addressing Mode ..... 65
4.2.5 Extended Addressing Mode ..... 65
4.2.6 Relative Addressing Mode ..... 66
4.2.7 Indexed Addressing Modes ..... 66
4.2.8 Instructions Using Multiple Modes ..... 71
4.3 Instruction Descriptions ..... 73
4.3.1 Load and Store Instructions ..... 73
4.3.2 Transfer and Exchange Instructions ..... 74
4.3.3 Move Instructions ..... 74
4.3.4 Add and Subtract Instructions ..... 75
4.3.5 Binary Coded Decimal Instructions ..... 76
4.3.6 Decrement and Increment Instructions ..... 76
4.3.7 Compare and Test Instructions ..... 77
4.3.8 Boolean Logic Instructions ..... 78
4.3.9 Clear, Complement, and Negate Instructions ..... 78
4.3.10 Multiply and Divide Instructions ..... 79
4.3.11 Bit Test and Bit Manipulation Instructions ..... 79
4.3.12 Shift and Rotate Instructions ..... 80
4.3.13 Fuzzy Logic Instructions. ..... 81
4.3.14 Maximum and Minimum Instructions ..... 81
4.3.15 Multiply and Accumulate Instruction. ..... 83
4.3.16 Table Interpolation Instructions ..... 83
4.3.17 Branch Instructions ..... 84
4.3.18 Jump and Subroutine Instructions ..... 86
4.3.19 Interrupt Instructions ..... 87
4.3.20 Index Manipulation Instructions ..... 88
4.3.21 Stacking Instructions ..... 89
4.3.22 Load Effective Address Instructions ..... 90
4.3.23 Condition Code Instructions ..... 90
4.3.24 STOP and WAI Instructions ..... 91
4.3.25 Background Mode and Null Operation Instructions ..... 91
4.4 High-Level Language Support ..... 92
4.4.1 Data Types ..... 92
4.4.2 Parameters and Variables ..... 92
4.4.3 Increment and Decrement Operators ..... 94
4.4.4 Higher Math Functions ..... 94
4.4.5 Conditional If Constructs ..... 94
4.4.6 Case and Switch Statements ..... 95
4.4.7 Pointers ..... 95
4.4.8 Function Calls ..... 95
4.4.9 Instruction Set Orthogonality ..... 95
4.5 Opcode Map ..... 97
4.6 Transfer and Exchange Postbyte Encoding ..... 99
4.7 Loop Primitive Postbyte (lb) Encoding ..... 100
4.8 Indexed Addressing Postbyte (xb) Encoding ..... 101
Section 5 Instruction Execution
5.1 Normal Instruction Execution ..... 103
5.2 Execution Sequence ..... 103
5.2.1 No Movement ..... 103
5.2.2 Advance and Load from Data Bus ..... 103
5.3 Changes of Flow. ..... 104
5.3.1 Exceptions ..... 104
5.3.2 Subroutines ..... 104
5.3.3 Branches ..... 104
5.3.4 Jumps. ..... 106
5.4 Instruction Timing ..... 106
5.4.1 Register and Memory Notation ..... 120
5.4.2 Source Form Notation ..... 121
5.4.3 Operation Notation ..... 122
5.4.4 Address Mode Notation ..... 122
5.4.5 Machine Code Notation ..... 123
5.4.6 Access Detail Notation ..... 123
5.4.7 Condition Code State Notation. ..... 126
5.5 External Visibility Of Instruction Queue ..... 126
5.5.1 Instruction Queue Status Signals ..... 126
5.5.2 No Movement (0:0) ..... 128
5.5.3 ALD - Advance and Load from Data Bus (1:0) ..... 128
5.5.4 INT — Start Interrupt (0:1) ..... 128
5.5.5 SEV — Start Even Instruction (1:0) ..... 128
5.5.6 SOD — Start Odd Instruction (1:1) ..... 129
Section 6 Exception Processing
6.1 Exception Processing Overview ..... 131
6.1.1 Reset Processing ..... 133
6.1.2 Interrupt Processing ..... 133
6.2 Exception Vectors. ..... 135
6.3 Exception Types ..... 136
6.3.1 Resets ..... 136
6.3.2 Interrupts ..... 137
Section 7 Core Interface
7.1 Core Interface Overview ..... 141
7.1.1 Signal Summary ..... 142
7.2 Signal Descriptions. ..... 145
7.2.1 Internal Bus Interface Signals ..... 145
7.2.2 External Bus Interface Signals ..... 148
7.2.3 Clock and Reset Signals ..... 150
7.2.4 Vector Request/Acknowledge Signals ..... 151
7.2.5 Stop and Wait Mode Control/Status Signals ..... 151
7.2.6 Background Debug Mode (BDM) Interface Signals ..... 151
7.2.7 Memory Configuration Signals ..... 152
7.2.8 Scan Control Interface Signals ..... 152
7.3 Interface Operation. ..... 152
7.3.1 Read Operations ..... 152
7.3.2 Write Operations ..... 155
7.3.3 Multiplexed External Bus Interface. ..... 158
7.3.4 General Internal Read Visibility Timing ..... 161
7.3.5 Detecting Access Type from External Signals ..... 162
Section 8 Core Clock and Reset Connections
8.1 Clocking Overview ..... 163
8.1.1 Basic Clock Relationship ..... 164
8.1.2 Reset Relationship ..... 165
8.1.3 Phase-Locked Loop Interface ..... 165
8.1.4 HCS12 CPU Wait and Stop Modes ..... 166
8.2 Signal Summary ..... 166
8.3 Detailed Clock and Reset Signal Descriptions ..... 167
8.3.1 Clock and Reset Signals ..... 167
8.3.2 Stop and Wait Mode Control/Status Signals ..... 168
Section 9 Core Power Connections
9.1 Power Overview ..... 169
9.1.1 Power and Ground Summary ..... 169
Section 10 Interrupt (INT)
10.1 Overview. ..... 171
10.1.1 Features ..... 171
10.1.2 Block Diagram ..... 172
10.2 Interface Signals ..... 172
10.3 Registers ..... 173
10.3.1 Interrupt Test Control Register. ..... 173
10.3.2 Interrupt Test Registers ..... 174
10.3.3 Highest Priority I Interrupt (Optional) ..... 175
10.4 Operation ..... 175
10.4.1 Interrupt Exception Requests ..... 175
10.4.2 Reset Exception Requests ..... 176
10.4.3 Exception Priority ..... 176
10.5 Modes of Operation ..... 177
10.5.1 Normal Operation ..... 177
10.5.2 Special Operation ..... 177
10.5.3 Emulation Modes ..... 177
10.6 Low-Power Options ..... 177
10.6.1 Run Mode ..... 177
10.6.2 Wait Mode ..... 177
10.6.3 Stop Mode ..... 177
10.7 Motorola Internal Information ..... 177
Section 11 Module Mapping Control (MMC)

User Guide - S12CPuI5Uteferscale Semiconductor, Inc.
11.1 Overview. ..... 179
11.1.1 Features ..... 179
11.1.2 Block Diagram ..... 180
11.2 Interface Signals ..... 180
11.3 Registers ..... 181
11.3.1 Initialization of Internal RAM Position Register (INITRM) ..... 182
11.3.2 Initialization of Internal Registers Position Register (INITRG) ..... 182
11.3.3 Initialization of Internal EEPROM Position Register (INITEE) ..... 183
11.3.4 Miscellaneous System Control Register (MISC) ..... 184
11.3.5 Reserved Test Register Zero (MTSTO) ..... 185
11.3.6 Reserved Test Register One (MTST1) ..... 185
11.3.7 Memory Size Register Zero (MEMSIZO) ..... 186
11.3.8 Memory Size Register One (MEMSIZ1). ..... 187
11.3.9 Program Page Index Register (PPAGE) ..... 188
11.4 Operation ..... 189
11.4.1 Bus Control ..... 189
11.4.2 Address Decoding ..... 189
11.4.3 Memory Expansion ..... 191
11.5 Motorola Internal Information ..... 196
11.5.1 Test Registers ..... 196
11.5.2 MMC Bus Control. ..... 198
Section 12 Multiplexed External Bus Interface (MEBI)
12.1 Overview. ..... 201
12.1.1 Features ..... 201
12.1.2 Block Diagram ..... 202
12.2 Interface Signals ..... 202
12.2.1 MEBI Signal Descriptions. ..... 203
12.3 Registers ..... 207
12.3.1 Port A Data Register (PORTA) ..... 208
12.3.2 Data Direction Register A (DDRA) ..... 209
12.3.3 Port B Data Register (PORTB) ..... 210
12.3.4 Data Direction Register B (DDRB) ..... 210
12.3.5 Port E Data Register (PORTE) ..... 211
12.3.6 Data Direction Register E (DDRE) ..... 212
12.3.7 Port E Assignment Register (PEAR) ..... 213
12.3.8 MODE Register (MODE) ..... 215
12.3.9 Pullup Control Register (PUCR) ..... 218
12.3.10 Reduced Drive Register (RDRIV) ..... 219
12.3.11 External Bus Interface Control Register (EBICTL) ..... 220
12.3.12 IRQ Control Register (IRQCR) ..... 220
12.3.13 Reserved Registers. ..... 222
12.3.14 Port K Data Register (PORTK) ..... 222
12.3.15 Port K Data Direction Register (DDRK) ..... 223
12.4 Operation ..... 224
12.4.1 External Bus Control ..... 224
12.4.2 External Data Bus Interface ..... 224
12.4.3 Control ..... 224
12.4.4 Registers ..... 224
12.4.5 External System Pin Functional Descriptions ..... 225
12.4.6 Detecting Access Type from External Signals ..... 226
12.4.7 Stretched Bus Cycles ..... 227
12.4.8 Modes of Operation ..... 227
12.4.9 Internal Visibility ..... 231
12.4.10 Secure Mode ..... 232
12.5 Low-Power Options ..... 232
12.5.1 Run Mode. ..... 232
12.5.2 Wait Mode ..... 232
12.5.3 Stop Mode ..... 232
12.6 Motorola Internal Information ..... 232
12.6.1 Peripheral Mode Operation ..... 232
12.6.2 Special Test Clock ..... 233
Section 13 Breakpoint (BKP)
13.1 Overview ..... 235
13.1.1 Features ..... 235
13.1.2 Block Diagram ..... 236
13.2 Interface Signals ..... 238
13.3 Registers ..... 238
13.3.1 Breakpoint Control Register 0 (BKPCTO) ..... 238
13.3.2 Breakpoint Control Register 1 (BKPCT1). ..... 239
13.3.3 Breakpoint First Address Expansion Register (BKPOX) ..... 242

User Guide - S12CPU15Ftitesscale Semiconductor, Inc.
13.3.4 Breakpoint First Address High Byte Register (BKPOH) ..... 243
13.3.5 Breakpoint First Address Low Byte Register (BKPOL) ..... 243
13.3.6 Breakpoint Second Address Expansion Register (BKP1X) ..... 243
13.3.7 Breakpoint Data (Second Address) High Byte Register (BKP1H) ..... 244
13.3.8 Breakpoint Data (Second Address) Low Byte Register (BKP1L) ..... 244
13.4 Operation ..... 245
13.4.1 Modes of Operation ..... 245
13.4.2 Breakpoint Priority ..... 246
13.5 Motorola Internal Information ..... 246
Section 14 Background Debug Mode (BDM)
14.1 Overview. ..... 247
14.1.1 Features ..... 247
14.1.2 Block Diagram ..... 248
14.2 Interface Signals ..... 248
14.2.1 Background Interface Pin (BKGD) ..... 248
14.2.2 High Byte Instruction Tagging Pin (TAGHI) ..... 248
14.2.3 Low Byte Instruction Tagging Pin (TAGLO) ..... 249
14.3 Registers ..... 249
14.3.1 BDM Status Register ..... 250
14.3.2 BDM CCR Holding Register ..... 252
14.3.3 BDM Internal Register Position Register ..... 253
14.4 Operation ..... 253
14.4.1 Security ..... 253
14.4.2 Enabling and Activating BDM ..... 254
14.4.3 BDM Hardware Commands ..... 254
14.4.4 Standard BDM Firmware Commands ..... 255
14.4.5 BDM Command Structure ..... 256
14.4.6 BDM Serial Interface ..... 258
14.4.7 Instruction Tracing ..... 260
14.4.8 Instruction Tagging ..... 260
14.5 Modes of Operation ..... 261
14.5.1 Normal Operation ..... 261
14.5.2 Special Operation ..... 262
14.5.3 Emulation Modes ..... 262
14.6 Low-Power Options ..... 262
14.6.1 Run Mode ..... 262
14.6.2 Wait Mode ..... 262
14.6.3 Stop Mode ..... 262
14.7 Interrupt Operation ..... 262
14.8 Motorola Internal Information ..... 262
14.8.1 Registers ..... 263
14.8.2 BDM Instruction Register (Hardware) ..... 264
14.8.3 BDM Instruction Register (Firmware) ..... 265
14.8.4 BDM Status Register ..... 266
14.8.5 BDM Shift Register ..... 267
14.8.6 BDM Address Register ..... 268
14.8.7 Special Peripheral Mode ..... 268
14.8.8 Standard BDM Firmware Listing ..... 268
14.8.9 Secured Mode BDM Firmware Listing ..... 275
Section 15 Secured Mode of Operation
15.1 Overview. ..... 279
15.1.1 Features ..... 279
15.1.2 Block Diagram ..... 280
15.2 Interface Signals ..... 280
15.3 Registers ..... 281
15.4 Operation ..... 281
15.4.1 Normal Single-Chip Mode ..... 281
15.4.2 Expanded Mode ..... 281
15.4.3 Unsecuring The System ..... 281
15.5 Motorola Internal Information ..... 283
15.5.1 BDM Secured Mode Firmware ..... 283
Appendix A Instruction Set and Commands
A. 1 General. ..... 285
A. 2 Glossary Notation ..... 285
A.2.1 Condition Code State Notation. ..... 285
A.2.2 Register and Memory Notation ..... 286
A.2.3 Address Mode Notation ..... 287
A.2.4 Operator Notation ..... 287
A.2.5 Machine Code Notation ..... 287

User Guide - S12CPU15Ufteperscale Semiconductor, Inc.
A.2.6 Source Form Notation ..... 288
A.2.7 CPU Cycles Notation ..... 289
A. 3 Glossary ..... 292
Appendix B Fuzzy Logic Support
B. 1 General ..... 503
B. 2 Introduction. ..... 503
B. 3 Fuzzy Logic Basics ..... 503
B.3.1 Fuzzification (MEM) ..... 505
B.3.2 Rule Evaluation (REV and REVW) ..... 506
B.3.3 Defuzzification (WAV) ..... 508
B. 4 Example Inference Kernel ..... 508
B. 5 MEM Instruction Details ..... 510
B.5.1 Membership Function Definitions ..... 510
B.5.2 Abnormal Membership Function Definitions ..... 511
B. 6 REV, REVW Instruction Details ..... 514
B.6.1 Unweighted Rule Evaluation (REV) ..... 514
B.6.2 Weighted Rule Evaluation (REVW) ..... 518
B. 7 WAV Instruction Details ..... 523
B.7.1 Initialization Prior to Executing WAV ..... 523
B.7.2 WAV Interrupt Details. ..... 523
B.7.3 Cycle-by-Cycle Details for WAV and wavr ..... 524
B. 8 Custom Fuzzy Logic Programming ..... 527
B.8.1 Fuzzification Variations ..... 527
B.8.2 Rule Evaluation Variations ..... 529
B.8.3 Defuzzification Variations. ..... 530
Appendix C M68HC11 to HCS12 Upgrade
C. 1 General. ..... 531
C. 2 Source Code Compatibility ..... 531
C. 3 Programmer's Model and Stacking ..... 533
C. 4 True 16-Bit Architecture ..... 533
C.4.1 Bus Structures ..... 533
C.4.2 Instruction Queue ..... 533
C.4.3 Stack Function ..... 534
C. 5 Improved Indexing ..... 535
C.5.1 Constant Offset Indexing ..... 536
C.5.2 Autoincrement/Autodecrement Indexing ..... 537
C.5.3 Accumulator Offset Indexing ..... 537
C.5.4 Indirect Indexing ..... 538
C. 6 Improved Performance ..... 538
C.6.1 Reduced Cycle Counts ..... 538
C.6.2 Fast Math ..... 538
C.6.3 Code Size Reduction ..... 539
C. 7 Additional Functions ..... 540
C.7.1 New Instructions. ..... 540
C.7.2 Memory-to-Memory Moves ..... 542
C.7.3 Universal Transfer and Exchange ..... 542
C.7.4 Loop Construct. ..... 542
C.7.5 Long Branches ..... 542
C.7.6 Minimum and Maximum Instructions ..... 543
C.7.7 Fuzzy Logic Support ..... 543
C.7.8 Table Lookup and Interpolation ..... 544
C.7.9 Extended Bit Manipulation ..... 544
C.7.10 Push and Pull D and CCR ..... 544
C.7.11 Compare SP. ..... 544
C.7.12 Support for Memory Expansion ..... 544
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## List of Figures

Figure 1-1 Core Block Diagram ..... 25
Figure 1-2 Programming Model ..... 27
Figure 3-1 Programming Model ..... 53
Figure 3-2 Accumulator A ..... 54
Figure 3-3 Accumulator B ..... 54
Figure 3-4 Index Register X ..... 54
Figure 3-5 Index Register Y ..... 54
Figure 3-6 Stack Pointer (SP) ..... 55
Figure 3-7 Program Counter (PC) ..... 56
Figure 3-8 Condition Code Register (CCR) ..... 56
Figure 3-9 Core Register Map Summary ..... 61
Figure 5-1 Queue Status Signal Timing ..... 127
Figure 7-1 Core Interface Signals ..... 142
Figure 7-2 Basic 8-bit Peripheral Read Timing ..... 153
Figure 7-3 Basic 16-bit Peripheral Read Timing ..... 153
Figure 7-4 Basic 8-bit Memory Read Timing ..... 154
Figure 7-5 Basic 16-bit Memory Read Timing ..... 154
Figure 7-6 Basic 8-bit Core Register Read Timing ..... 155
Figure 7-7 Basic 16-bit Core Register Read Timing ..... 155
Figure 7-8 Basic 8-bit Peripheral Write Timing ..... 156
Figure 7-9 Basic 16-bit Peripheral Write Timing ..... 156
Figure 7-10 Basic 8-bit Memory Write Timing ..... 157
Figure 7-11 Basic 16-bit Memory Write Timing ..... 157
Figure 7-12 Basic 8-bit Core Register Write Timing ..... 158
Figure 7-13 Basic 16-bit Core Register Write Timing ..... 158
Figure 7-14 General External Bus Timing ..... 159
Figure 7-15 General Internal Read Visibility Timing ..... 161
Figure 8-1 Core Interface Signals ..... 164
Figure 8-2 System Clock Timing Diagram ..... 165
Figure 10-1 Interrupt Block Diagram ..... 172
Figure 10-2 Interrupt Register Summary ..... 173
Figure 10-3 Interrupt Test Control Register (ITCR) ..... 173
Figure 10-4 Interrupt TEST Registers (ITEST) ..... 174
User Guide - S12CPU15UtGer.zcale Semiconductor, Inc.
Figure 10-5 Highest Priority I Interrupt Register (HPRIO) ..... 175
Figure 11-1 Module Mapping Control Block Diagram ..... 180
Figure 11-2 Module Mapping Control Register Summary ..... 181
Figure 11-3 INITRM Register ..... 182
Figure 11-4 INITRG Register ..... 182
Figure 11-5 INITEE Register ..... 183
Figure 11-6 Miscellaneous System Control Register (MISC) ..... 184
Figure 11-7 Reserved Test Register Zero (MTSTO) ..... 185
Figure 11-8 Reserved Test Register One (MTST1) ..... 185
Figure 11-9 Memory Size Register Zero ..... 186
Figure 11-10 Memory Size Register One ..... 187
Figure 11-11 Program Page Index Register (PPAGE) ..... 188
Figure 11-13 Mapping Test Register Zero (MTSTO) ..... 196
Figure 11-14 Mapping Test Register One (MTST1) ..... 197
Figure 12-1 MEBI Block Diagram ..... 202
Figure 12-2 MEBI Register Map Summary ..... 207
Figure 12-3 Port A Data Register (PORTA) ..... 208
Figure 12-4 Data Direction Register A (DDRA) ..... 209
Figure 12-5 Port B Data Register (PORTB) ..... 210
Figure 12-6 Data Direction Register B (DDRB) ..... 210
Figure 12-7 Port E Data Register (PORTE) ..... 211
Figure 12-8 Data Direction Register E (DDRE) ..... 212
Figure 12-9 Port E Assignment Register (PEAR) ..... 213
Figure 12-10 MODE Register (MODE) ..... 215
Figure 12-11 Pullup Control Register (PUCR) ..... 218
Figure 12-12 Reduced Drive Register (RDRIV) ..... 219
Figure 12-13 External Bus Interface Control Register (EBICTL) ..... 220
Figure 12-14 IRQ Control Register (IRQCR) ..... 220
Figure 12-15 Reserved Registers ..... 222
Figure 12-16 Port K Data Register (PORTK) ..... 222
Figure 12-17 Port K Data Direction Register (DDRK) ..... 223
Figure 13-1 Breakpoint Block Diagram ..... 237
Figure 13-2 Breakpoint Register Summary ..... 238
Figure 13-3 Breakpoint Control Register 0 (BKPCTO) ..... 239
Figure 13-4 Breakpoint Control Register 1 (BKPCT1) ..... 240
Figure 13-5 Breakpoint First Address Expansion Register (BKPOX) ..... 242
Figure 13-6 Breakpoint First Address High Byte Register (BKPOH) ..... 243
Figure 13-7 Breakpoint First Address Low Byte Register (BKPOL) ..... 243
Figure 13-8 Breakpoint Second Address Expansion Register (BKP1X) ..... 244
Figure 13-9 Breakpoint Data High Byte Register (BKP1H) ..... 244
Figure 13-10 Breakpoint Data Low Byte Register (BKP1L) ..... 245
Figure 14-1 BDM Block Diagram ..... 248
Figure 14-2 BDM Register Map Summary ..... 249
Figure 14-3 BDM Status Register (BDMSTS) ..... 250
Figure 14-4 BDM CCR Holding Register (BDMCCR) ..... 252
Figure 14-5 BDM Internal Register Position (BDMINR) ..... 253
Figure 14-11 BDM Instruction Register (BDMIST) ..... 264
Figure 14-12 BDM Instruction Register (BDMIST) ..... 265
Figure 14-13 BDM Shift Register (BDMSHTH) ..... 267
Figure 14-14 BDM Shift Register (BDMSHTL) ..... 267
Figure 14-15 BDM Address Register (BDMADDH), ..... 268
Figure 14-16 BDM Address Register (BDMADDL) ..... 268
Figure 15-1 Security Implementation Block Diagram ..... 280
Figure B-1 Block Diagram of a Fuzzy Logic System ..... 504
Figure B-2 Fuzzification Using Membership Functions ..... 506
Figure B-3 Fuzzy Inference Engine ..... 509
Figure B-4 Defining a Normal Membership Function ..... 511
Figure B-5 MEM Instruction Flow Diagram ..... 512
Figure B-6 Abnormal Membership Function Case 1 ..... 513
Figure B-7 Abnormal Membership Function Case 2 ..... 514
Figure B-8 Abnormal Membership Function Case 3 ..... 514
Figure B-9 REV Instruction Flow Diagram ..... 517
Figure B-10 REVW Instruction Flow Diagram ..... 522
Figure B-11 WAV and wavr Instruction Flow Diagram ..... 526
Figure B-12 Endpoint Table Handling ..... 528
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## List of Tables

Table 1-1 Addressing Mode Summary ..... 28
Table 1-2 Instruction Set Summary ..... 29
Table 1-3 Register and Memory Notation ..... 43
Table 1-4 Source Form Notation ..... 44
Table 1-5 Operation Notation ..... 45
Table 1-6 Address Mode Notation ..... 45
Table 1-7 Machine Code Notation ..... 46
Table 1-8 Access Detail Notation. ..... 47
Table 1-9 Condition Code State Notation ..... 49
Table 2-1 Symbols and Operators ..... 51
Table 3-1 Core Register Map Reference ..... 61
Table 4-1 Addressing Mode Summary ..... 63
Table 4-2 Summary of Indexed Operations ..... 68
Table 4-3 Load and Store Instructions ..... 73
Table 4-4 Transfer and Exchange Instructions ..... 74
Table 4-5 Move Instructions ..... 74
Table 4-6 Add and Subtract Instructions ..... 75
Table 4-7 BCD Instructions ..... 76
Table 4-8 Decrement and Increment Instructions ..... 76
Table 4-9 Compare and Test Instructions ..... 77
Table 4-10 Boolean Logic Instructions ..... 78
Table 4-11 Clear, Complement, and Negate Instructions ..... 78
Table 4-12 Multiplication and Division Instructions ..... 79
Table 4-13 Bit Test and Bit Manipulation Instructions ..... 79
Table 4-14 Shift and Rotate Instructions ..... 80
Table 4-15 Fuzzy Logic Instructions ..... 81
Table 4-16 Minimum and Maximum Instructions ..... 82
Table 4-17 Multiply and Accumulate Instruction ..... 83
Table 4-18 Table Interpolation Instructions ..... 83
Table 4-19 Short Branch Instructions ..... 84
Table 4-20 Long Branch Instructions ..... 85
Table 4-21 Bit Condition Branch Instructions ..... 85
Table 4-22 Loop Primitive Instructions ..... 86
User Guide - S12CPU15ƯGĘ.scale Semiconductor, Inc.
Table 4-23 Jump and Subroutine Instructions ..... 87
Table 4-24 Interrupt Instructions ..... 87
Table 4-25 Index Manipulation Instructions ..... 88
Table 4-26 Stacking Instructions ..... 89
Table 4-27 Load Effective Address Instructions. ..... 90
Table 4-28 Condition Code Instructions ..... 90
Table 4-29 STOP and WAI Instructions ..... 91
Table 4-30 Background Mode and Null Operation Instructions ..... 91
Table 5-1 Instruction Set Summary ..... 106
Table 5-2 Register and Memory Notation ..... 120
Table 5-3 Source Form Notation ..... 121
Table 5-4 Operation Notation ..... 122
Table 5-5 Address Mode Notation ..... 122
Table 5-6 Machine Code Notation ..... 123
Table 5-7 Access Detail Notation ..... 123
Table 5-8 Condition Code State Notation ..... 126
Table 5-9 IPIPE[1:0] Decoding when E Clock is High ..... 127
Table 5-10 IPIPE[1:0] Decoding when E Clock is Low ..... 128
Table 6-1 Exception Vector Map and Priority ..... 135
Table 6-2 Reset Sources ..... 136
Table 6-3 Interrupt Sources ..... 137
Table 7-1 Core Interface Signal Definitions ..... 142
Table 7-2 Multiplexed Expansion Bus Timing - Preliminary Targets ..... 160
Table 7-3 Expansion Bus Timing - Preliminary Targets. ..... 161
Table 7-4 Access Type vs. Bus Control Pins ..... 162
Table 8-1 Core Clock and Reset Interface Signals ..... 166
Table 10-1 Exception Vector Map and Priority ..... 176
Table 11-1 External Stretch Bit Definition ..... 184
Table 11-2 Allocated EEPROM Memory Space ..... 186
Table 11-3 Allocated RAM Memory Space ..... 186
Table 11-4 Allocated Flash EEPROM/ROM Physical Memory Space ..... 187
Table 11-5 Allocated Off-Chip Memory Options ..... 188
Table 11-6 Program Page Index Register Bits. ..... 189
Table 11-7 Select Signal Priority ..... 190
Table 11-8 Allocated Off-Chip Memory Options ..... 191
Table 11-9 External/Internal Page Window Access ..... 191
Table 11-100K Byte Physical Flash/ROM Allocated ..... 193
Table 11-1116K Byte Physical Flash/ROM Allocated ..... 193
Table 11-1248K Byte Physical Flash/ROM Allocated ..... 193
Table 11-1364K Byte Physical Flash/ROM Allocated ..... 194
Table 11-14Wide Bus Enable Signal Generation ..... 198
Table 11-15Read Data Bus Swapping ..... 199
Table 12-1 MEBI Interface Signal Definitions ..... 203
Table 12-2 MODC, MODB, MODA Write Capability ..... 216
Table 12-3 Mode Select and State of Mode Bits ..... 216
Table 12-4 External System Pins Associated With MEBI ..... 225
Table 12-5 Access Type vs. Bus Control Pins ..... 227
Table 12-6 Mode Pin Setup and Hold Timing ..... 227
Table 12-7 Peripheral Mode Pin Configuration ..... 232
Table 13-1 Breakpoint Mask Bits for First Address ..... 240
Table 13-2 Breakpoint Mask Bits for Second Address (Dual Mode) ..... 241
Table 13-3 Breakpoint Mask Bits for Data Breakpoints (Full Mode) ..... 241
Table 14-1 Hardware Commands ..... 255
Table 14-2 Firmware Commands. ..... 256
Table 14-3 Tag Pin Function ..... 261
Table 14-4 TTAGO Decoding ..... 265
Table 14-5 RNEXT Decoding ..... 266
Table 15-1 Security Interface Signal Definitions ..... 280
Table A-1 Condition Code State Notation ..... 285
Table A-2 Register and Memory Notation ..... 286
Table A-3 Address Mode Notation ..... 287
Table A-4 Operator Notation ..... 287
Table A-5 Machine Code Notation ..... 288
Table A-6 Source Form Notation ..... 289
Table A-7 CPU Cycle Notation ..... 290
Table C-1 Translated M68HC11 Mnemonics ..... 531
Table C-2 Instructions with Smaller Object Code ..... 532
Table C-3 Comparison of Math Instruction Speeds ..... 539
Table C-4 New HCS12 Instructions ..... 540
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 1 Introduction

### 1.1 Core Overview

The HCS12 V1.5 Core is a 16-bit processing core using the 68 HC 12 instruction set architecture (ISA). This makes the Core instruction set compatible with currently available Motorola 68HC12 based designs and allows for Motorola 68HC11 source code to be directly accepted by assemblers used for the HCS12 Central Processing Unit (CPU). In addition, the Core contains the Interrupt (INT), Module Mapping Control (MMC), Multiplexed External Bus Interface (MEBI), Breakpoint (BKP) and Background Debug Mode (BDM) sub-blocks providing a tightly coupled structure to maximize execution efficiency for integrating into a System-on-a-Chip (SoC) design. These sub-blocks handle all system interfacing with the Core including interrupt and reset processing, register and memory mapping, memory and peripheral interfacing, external bus control and source code debug for code development. A complete functional description of each sub-block is included in later sections of this guide.

### 1.2 Features

The main features of the Core are:

- High-speed, 16-bit processing with the same programming model and instruction set as the Motorola 68HC12 CPU
- Full 16-bit data paths for efficient arithmetic operation and high-speed mathematical execution
- Allows instructions with odd byte counts, including many single-byte instructions for more efficient use of program memory space
- Three stage instruction queue to buffer program information for more efficient CPU execution
- Extensive set of indexed addressing capabilities including:
- Using the stack pointer as an indexing register in all indexed operations
- Using the program counter as an indexing register in all but auto increment/decrement mode
- Accumulator offsets using A, B or D accumulators
- Automatic index pre-decrement, pre-increment, post-decrement and post-increment (by -8 to +8)
- 5-bit, 9-bit or 16-bit signed constant offsets
- 16-bit offset indexed-indirect and accumulator D offset indexed-indirect addressing
- Provides 2 to 122 I bit maskable interrupt vectors, 1 X bit maskable interrupt vector, 2 nonmaskable CPU interrupt vectors and 3 reset vectors
- Optional register configurable highest priority I bit maskable interrupt
- On-chip memory and peripheral block interfacing with internal memory expansion capability and external data chip select
- Configurable system memory and mapping options
- External Bus Interface (8-bit or 16-bit, multiplexed or non-multiplexed)
- Multiple modes of operation
- Hardware breakpoint support for forced or tagged breakpoints with two modes of operation:
- Dual Address Mode to match on either of two addresses
- Full Breakpoint Mode to match on address and data combination
- Single-wire background debug system implemented in on-chip hardware
- Secured mode of operation
- Fully synthesizable design
- Single Core clock operation
- Full Mux-D scan test implementation

The HCS12 V1.5 Core is designed to interface with the system peripherals through the use of the I.P. Bus and its interface defined by the Motorola Semiconductor Reuse Standards (MSRS). The Core communicates with the on-chip memory blocks either directly through the Core interface signals or via the STAR bus. Interfacing with memories external to the system is provided for through the MEBI sub-block of the Core and the corresponding port/pad logic it is connected to within the system.

### 1.3 Block Diagram

A block diagram of the Core within a typical SoC system is given in Figure 1-1 below. This diagram is a general representation of the Core, its sub-blocks and the interfaces to the rest of the blocks within the SoC design. The signals related to BKGD, Port A, Port B, Port E and Port K are direct interfaces to port/pad logic at the top level of the overall system.


Figure 1-1 Core Block Diagram
The main sub-blocks of the Core are:

- Central Processing Unit (CPU) - 68HC12 ISA compatible
- Interrupt (INT)
- Module Mapping Control (MMC)
- Multiplexed External Bus Interface (MEBI)
- Breakpoint (BKP)
- Background Debug Mode (BDM)

User Guide - S12CPU15UGEP:Scale Semiconductor, Inc.

### 1.4 Architectural Summary

As briefly discussed previously, the Core consists of the HCS12 Central Processing Unit (CPU) along with the Interrupt (INT), Module Mapping Control (MMC), Multiplexed External Bus Interface (MEBI), Breakpoint (BKP) and Background Debug Mode (BDM) sub-blocks. The CPU executes the 68HC12 CPU ISA with a three-stage instruction queue to facilitate a high level of code execution efficiency. The INT sub-block interacts with the CPU to provide 2 to 122 I bit maskable (configured at system integration), 1 X bit maskable and 2 nonmaskable CPU interrupt vectors, 3 reset vectors and handles waking-up the system from wait or stop mode due to a serviceable interrupt. The MMC sub-block controls address space mapping and generates memory selects and a single peripheral select (to be decoded by the I.P. Bus) as well as multiplexing the address and data signals for proper interaction with the CPU. The MEBI sub-block functions as the external bus controller with four 8-bit ports (A, B, E and K ) as well as handling mode decoding and initialization for the Core. The BKP sub-block serves to assist in debugging of software by providing for hardware breakpoints. The BKP supports dual address and full breakpoint modes for matching on either of two address or on an address and data combination, respectively, to initiate a Software Interrupt (SWI) or put the system into Background Debug Mode. The BKP also supports tagged or forced breakpoints for breaking just before a specific instruction or on the first instruction boundary after a match, respectively. The BDM sub-block provides for a single-wire background debug communication system implemented within the Core with on-chip hardware. The BDM allows for single-wire serial interfacing with a development system host.

The Core is a fully synthesizable single-clock design with full Mux-D scan test implementation. It is designed to be synthesized and timed together as a single block for optimizing speed of execution and minimizing area.

### 1.5 Programming Model

The HCS12 V1.5 Core CPU12 programming model, shown in Figure 1-2, is the same as that of the 68 HC 12 and 68 HC 11 . For a detailed description of the programming model and associated registers please refer to Section 3 of this guide.


Figure 1-2 Programming Model

### 1.6 Data Format Summary

Following is a discussion of the data types used and their organization in memory for the Core.

### 1.6.1 Data Types

The CPU uses the following types of data:

- Bits
- 5-bit signed integers
- 8-bit signed and unsigned integers
- 8-bit, 2-digit binary coded decimal numbers
- 9-bit signed integers
- 16-bit signed and unsigned integers
- 16-bit effective addresses
- 32-bit signed and unsigned integers


## NOTE: Negative integers are represented in two's complement form.

Five-bit and 9-bit signed integers are used only as offsets for indexed addressing modes. Sixteen-bit effective addresses are formed during addressing mode computations. Thirty-two-bit integer dividends are used by extended division instructions. Extended multiply and extended multiply-and-accumulate instructions produce 32 -bit products.

### 1.6.2 Memory Organization

The standard HCS12 Core address space is 64 K bytes. However, the CPU has special instructions to support paged memory expansion which increases the standard area by means of predefined windows within the available address space. See Section 11 Module Mapping Control (MMC) for more information.

Eight-bit values can be stored at any odd or even byte address in available memory. Sixteen-bit values occupy two consecutive memory locations; the high byte is in the lowest address, but does not have to be aligned to an even boundary. Thirty-two-bit values occupy four consecutive memory locations; the high byte is in the lowest address, but does not have to be aligned to an even boundary.

All I/O and all on-chip peripherals are memory-mapped. No special instruction syntax is required to access these addresses. On-chip register and memory mapping are determined at the SoCl level and are configured during integration of the Core into the system.

### 1.7 Addressing modes

A summary of the addressing modes used by the Core is given in Table 1-1 below. The operation of each of these modes is discussed in detail in Section 4 of this guide.

Table 1-1 Addressing Mode Summary

| Addressing Mode | Source Form | Abbreviation | Description |
| :---: | :--- | :---: | :--- |
| Inherent | INST <br> (no externally supplied <br> operands) | INH | Operands (if any) are in CPU registers. |
| Immediate | INST \#opr8i <br> or <br> INST \#opr16i | IMM | Operand is included in instruction stream; 8-bit or <br> $16-$ bit size implied by context. |
| Direct | INST opr8a | DIR | Operand is the lower 8-bits of an address in the range <br> \$0000-\$00FF. |
| Extended | INST opr16a | EXT | Operand is a 16-bit address. |
| Relative | INST rel8 <br> or <br> INST rel16 | REL | Effective address is the value in PC plus an 8-bit or <br> 16 -bit relative offset value. |
| Indexed <br> (5-bit offset) | INST oprx5,xysp | IDX | Effective address is the value in X, Y, SP, or PC plus a <br> $5-$ bit signed constant offset. |
| Indexed <br> (predecrement) | INST oprx3,-xys | IDX | Effective address is the value in X, Y, or SP <br> autodecremented by 1 to 8. |

Table 1-1 Addressing Mode Summary

| Addressing Mode | Source Form | Abbreviation | Description |
| :---: | :--- | :---: | :--- |
| Indexed <br> (preincrement) | INST oprx3,+xys | IDX | Effective address is the value in X, Y, or SP <br> autoincremented by 1 to 8. |
| Indexed <br> (postdecrement) | INST oprx3,xys- | IDX | Effective address is the value in X, Y, or SP. The value <br> is postdecremented by 1 to 8. |
| Indexed <br> (postincrement) | INST oprx3,xys+ | IDX | Effective address is the value in X, Y, or SP. The value <br> is postincremented by 1 to 8. |
| Indexed <br> (accumulator offset) | INST abd,xysp | Effective address is the value in X, Y, SP, or PC plus <br> the value in A, B, or D. |  |
| Indexed <br> (9-bit offset) | INST oprx9,xysp | IDX1 | Effective address is the value in X, Y, SP, or PC plus a <br> 9-bit signed constant offset. |
| Indexed <br> (16-bit offset) | INST oprx16,xysp | IDX2 | Effective address is the value in X, Y, SP, or PC plus a <br> 16 -bit constant offset. |
| Indexed-indirect <br> (16-bit offset) | INST [oprx16,xysp] | [IDX2] | The value in X, Y, SP, or PC plus a 16-bit constant <br> offset points to the effective address. |
| Indexed-indirect <br> (D accumulator offset) | INST [D,xysp] | [D,IDX] | The value in X, Y, SP, or PC plus the value in D points <br> to the effective address. |

### 1.8 Instruction Set Overview

All memory and I/O are mapped in a common 64 K byte address space, allowing the same set of instructions to access memory, I/O, and control registers. Load, store, transfer, exchange, and move instructions facilitate movement of data to and from memory and peripherals.

There are instructions for signed and unsigned addition, division and multiplication with 8-bit, 16-bit, and some larger operands.

Special arithmetic and logic instructions aid stacking operations, indexing, BCD calculation, and condition code register manipulation. There are also dedicated instructions for multiply and accumulate operations, table interpolation, and specialized mathematical calculations for fuzzy logic operations.
A summary of the CPU instruction set is given in Table 1-2 below. A detailed overview of the entire instruction set is covered in Section 4 of this guide along with an instruction-by-instruction detailed description in Appendix A.

Table 1-2 Instruction Set Summary

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H I Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ABA | Add B to $\mathrm{A} ;(\mathrm{A})+(\mathrm{B}) \Rightarrow \mathrm{A}$ | INH | 1806 | 00 |  |
| ABXSame as LEAX B, X | Add B to $\mathrm{X} ;(\mathrm{X})+(\mathrm{B}) \Rightarrow \mathrm{X}$ | IDX | 1A E5 | Pf | \|-|-|-|-|-|-|-| |
| ABYSame as LEAY B, Y | Add B to $\mathrm{Y} ;(\mathrm{Y})+(\mathrm{B}) \Rightarrow \mathrm{Y}$ | IDX | 19 ED | Pf | - --- -------- |
| ADCA \#opr8i ADCA opr8a ADCA opr16a ADCA oprx0_xysppc ADCA oprx9,xysppc ADCA oprx16,xysppc ADCA [D,xysppc] ADCA [oprx16,xysppc] | Add with carry to $A ;(A)+(M)+C \Rightarrow A$ or $(A)+i m m+C \Rightarrow A$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 89 ii 99 dd B9 hh ll A9 xb A9 xb ff A9 xb ee ff A9 xb A9 xbeeff | P <br> rPf <br> rPo <br> rPf <br> rPO <br> frPP <br> fifrPf <br> fIPrPf |  |

: User Guide - S12CPU15जtarestcale Semiconductor, Inc.

| Source Form | Operation | $\begin{array}{\|c\|} \hline \text { Address } \\ \text { Mode } \end{array}$ | Machine Coding (Hex) | Access Detail | S X HIN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADCB \#opr8i ADCB opr8a ADCB opr16a ADCB oprx0_xysppc ADCB oprx9,xysppc ADCB oprx16,xysppc ADCB [D,xysppc] ADCB [oprx16,xysppc] | Add with carry to $B ;(B)+(M)+C \Rightarrow B$ or ( $B$ ) + imm $+C \Rightarrow B$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C9 ii <br> D9 dd <br> F9 hh ll <br> E9 xb <br> E9 xbff <br> E9 xbeeff <br> E9 xb <br> E9 xb ee ff | P rPf rPo rPf rPo frPP fIfrPf fIPrPf |  |
| ADDA \#opr8i ADDA opr8a ADDA opr16a ADDA oprx0_xysppc ADDA oprx9,xysppc ADDA oprx16,xysppc ADDA [D, xysppc] ADDA [oprx16,xysppc] | $\begin{aligned} & \text { Add to } A ;(A)+(M) \Rightarrow A \\ & \text { or }(A)+\text { imm } \Rightarrow A \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8B ii $9 B d d$ BB hh ll AB xb AB xb ff AB xb ee ff AB xb AB xb ee $f f$ | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ---\| $\Delta\|-\|\Delta\| \Delta\| \Delta \Delta$ |
| ADDB \#opr8i ADDB opr8a ADDB opr16a ADDB oprx0_xysppc ADDB oprx9,xysppc ADDB oprx16,xysppc ADDB [D, xysppc] ADDB [oprx16,xysppc] | $\begin{aligned} & \text { Add to } B ;(\mathrm{B})+(\mathrm{M}) \Rightarrow \mathrm{B} \\ & \text { or }(\mathrm{B})+i m m \Rightarrow \mathrm{~B} \end{aligned}$ | IMM <br> DR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | CB ii <br> DB dd <br> FBhh 11 <br> EB xb <br> EB xbff <br> EB xb eeff <br> EB xb <br> EB xb ee ff | P <br> rPf <br> rPO <br> rPf <br> rPo <br> frPP <br> fIfrPf <br> fIPrPf | ---\| $\Delta\|-\| \Delta \Delta \Delta \Delta \Delta$ |
| ADDD \#opr16i ADDD opr8a ADDD opr16a ADDD oprx0_xysppc ADDD oprx9,xysppc ADDD oprx16,xysppc ADDD [D,xysppc] ADDD [oprx16,xysppc] | Add to $D ;(A: B)+(M: M+1) \Rightarrow A: B$ or $(A: B)+i m m \Rightarrow A: B$ | IMM <br> DR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | C3 jjkk <br> D3 dd <br> F3 hh 11 <br> E3 xb <br> E3 xb ff <br> E3 xb eeff <br> E3 xb <br> E3 xb ee ff |  | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| ANDA \#opr8i ANDA opr8a ANDA opr16a ANDA oprx0_xysppc ANDA oprx9,xysppc ANDA oprx16,xysppc ANDA [D, xysppc] ANDA [oprx16,xysppc] | AND with $A ;(A) \bullet(M) \Rightarrow A$ or $(A) \cdot i m m \Rightarrow A$ | IMM DR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 84 ii 94 dd B4 hh ll A4 xb A4 xb ff A4 xb ee ff A4 xb A4 xb ee ff | P rPf rPO rPf rPo frPp fIfrPf fIPrPf |  |
| ANDB \#opr8i ANDB opr8a ANDB opr16a ANDB oprx0_xysppc ANDB oprx9,xysppc ANDB oprx16,xysppc ANDB [D,xysppc] ANDB [oprx16,xysppc] | AND with $B ;(B) \bullet(M) \Rightarrow B$ or $(B) \cdot i m m \Rightarrow B$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C4 ii D4 dd F4 hh ll E4 xb E4 xb ff E4 xbee ff E4 xb E4 xb ee ff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ------\| $\Delta \Delta 0 \mid-$ |
| ANDCC \#opr8i | AND with CCR; (CCR)•imm $\Rightarrow$ CCR | IMM | 10 ii | P |  |
| ASL opr16aSame as LSL ASL oprx0_xysp <br> ASL oprx9,xysppc <br> ASL oprx16,xysppc <br> ASL [D,xysppc] <br> ASL [oprx16,xysppc] <br> ASLASame as LSLA <br> ASLBSame as LSLB | Arithmetic shift left A Arithmetic shift left B | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 78 hh ll 68 xb 68 xb ff 68 xb ee ff 68 xb 68 xb ee ff 48 58 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 | ------- $\Delta \Delta \Delta \Delta \Delta$ |
| ASLDSame as LSLD |  | INH | 59 | $\bigcirc$ | ------- $\Delta \Delta \Delta \Delta \Delta$ |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X HIN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ASR opr16a <br> ASR oprx0_xysppc <br> ASR oprx9, xysppc <br> ASR oprx16,xysppc <br> ASR [D,xysppc] <br> ASR [oprx16,xysppc] <br> ASRA <br> ASRB | Arithmetic shift right M <br> Arithmetic shift right A Arithmetic shift right B | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \\ & \text { INH } \\ & \text { INH } \end{aligned}$ | 77 hh ll 67 xb 67 xb ff 67 xb ee ff 67 xb 67 xb ee ff 47 57 | $\begin{aligned} & \hline \text { rPwo } \\ & \text { rPw } \\ & \text { rPwo } \\ & \text { frPwP } \\ & \text { fIfrPw } \\ & \text { fIPrPw } \\ & 0 \\ & 0 \end{aligned}$ | $\square--\|-\|-\| \Delta \Delta \Delta \Delta \Delta$ |
| BCC rel8Same as BHS | Branch if C clear; if $\mathrm{C}=0$, then (PC) $+2+$ rel $\Rightarrow$ PC | REL | 24 rr | PPP (branch) P (no branch) | -------------- |
| BCLR opr8a, msk8 BCLR opr16a, msk8 BCLR oprx0_xysppc, msk8 BCLR oprx9,xysppc, msk8 BCLR oprx16,xysppc, msk8 | Clear bit(s) in M; (M)•mask byte $\Rightarrow \mathrm{M}$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 4D dd mm <br> 1D hh 11 mm <br> OD xb mm <br> OD xb ff mm <br> OD xb ee ff mm | $\begin{aligned} & \hline r \mathrm{PmO} \\ & r \mathrm{P} w \mathrm{P} \\ & r \mathrm{PwO} \\ & r \mathrm{PwP} \\ & \mathrm{frPwPO} \end{aligned}$ | ------- $\Delta \Delta \Delta 0 \mid-$ |
| BCS rel8Same as BLO | Branch if C set; if $\mathrm{C}=1$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 25 rr | PPP (branch) P (no branch) | ---\|-|-|-|--|- |
| BEQ rel8 | Branch if equal; if $Z=1$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 27 rr | PPP (branch) P (no branch) | ------------- |
| BGE rel8 | Branch if $\geq 0$, signed; if $\mathrm{N} \oplus \mathrm{V}=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 2Crr | PPP (branch) P (no branch) | ------------\|- |
| BGND | Enter background debug mode | INH | 00 | VfPPP | - ---\|-l-|-|-|- |
| BGT rel8 | $\begin{aligned} & \begin{array}{l} \text { Branch if }>0, \text { signed; if } \mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{~V})=0, \\ \text { then }(\mathrm{PC})+2+\text { rel } \Rightarrow \mathrm{PC} \end{array} \end{aligned}$ | REL | 2Err | PPP (branch) P (no branch) | - - - - - - - - - - - - - |
| BHI rel8 | Branch if higher, unsigned; if C \| $\mathrm{Z}=0$, then ( PC ) $+2+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 22 rr | PPP (branch) P (no branch) | ------------- |
| BHS rel8Same as BCC | Branchifhigherorsame,unsigned;if $\mathrm{C}=0$, then $(\mathrm{PC})+2+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 24 rr | PPP (branch) P (no branch) | - ----\|-|-|---|- |
| BITA \#opr8i <br> BITA opr8a <br> BITA opr16a <br> BITA oprx0_xysppc <br> BITA oprx9, xysppc <br> BITA oprx16,xysppc <br> BITA [D,xysppc] <br> BITA [oprx16,xysppc] | $\begin{aligned} & \text { Bit test A; (A)•(M) } \\ & \text { or (A) } \cdot \mathrm{mm} \end{aligned}$ | IMM IMR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 85 ii 95 dd B5 hh ll A5 xb A5 xb ff A5 xb ee ff A5 xb A5 xb ee ff | P rPf rPo rPf rPo frPP fIfrPf fIPrPf | ------- $\Delta \Delta \Delta 0 \mid-$ |
| BITB \#opr8i <br> BITB opr8a <br> BITB opr16a <br> BITB oprx0_xysppc <br> BITB oprx9, xysppc <br> BITB oprx16,xysppc <br> BITB [D,xysppc] <br> BITB [oprx16,xysppc] | $\begin{aligned} & \text { Bit test B; (B)•(M) } \\ & \text { or (B)•imm } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{array}$ | C5 ii <br> D5 dd <br> F5 hh 11 <br> E5 xb <br> E5 xb ff <br> E5 xbeeff <br> E5 xb <br> E5 xbeeff | P rPf rPO rPf rPO frPP fIfrPf fIPrPf | ------ $\Delta \Delta \Delta 0]$ |
| BLE re/8 | $\begin{aligned} & \text { Branch if } \leq 0, \text { signed; if } \mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{~V})=1, \\ & \text { then }(\mathrm{PC})+2+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 2 Frr | PPP (branch) P (no branch) | - ----\|-|-|---|- |
| BLO rel8Same as BCS | $\begin{aligned} & \text { Branch if lower, unsigned; if } \mathrm{C}=1 \text {, } \\ & \text { then }(\mathrm{PC})+2+\mathrm{rel} \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 25 rr | PPP (branch) P (no branch) | - ------------ |
| BLS rel8 | Branch if lower or same, unsigned; if $\mathrm{C} \mid \mathrm{Z}=1$, then $(\mathrm{PC})+2+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 23 rr | PPP (branch) P (no branch) | ------------- |
| BLT rel8 | Branch if $<0$, signed; if $\mathrm{N} \oplus \mathrm{V}=1$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 2Drr | PPP (branch) P (no branch) | ---\|-|--|-|-|- |
| BMI rel8 | $\begin{aligned} & \text { Branch if minus; if } \mathrm{N}=1 \text {, then } \\ & (\mathrm{PC})+2+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 2Brr | PPP (branch) P (no branch) | - - - - - - - - - - - - - |
| BNE rel8 | Branch if not equal to 0 ; if $Z=0$, then (PC)+2+rel $\Rightarrow$ PC | REL | 26 rr | PPP (branch) P (no branch) | - ------------ |
| BPL rel8 | Branch if plus; if $\mathrm{N}=0$, then (PC)+2+rel $\Rightarrow$ PC | REL | 2Arr | PPP (branch) P (no branch) | ------------- |
| BRA rel8 | Branch always | REL | 20 rr | PPP | ------------- |

: User Guide - S12CPU15जtert.2cale Semiconductor, Inc.

| Source Form | Operation | Address Mode | $\begin{gathered} \text { Machine } \\ \text { Coding (Hex) } \end{gathered}$ | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| BRCLR opr8a, msk8, rel8 BRCLR opr16a, msk8, rel8 BRCLR oprx__xysppc, msk8, rel8 BRCLR oprx9,xysppc, msk8, rel8 BRCLR oprx16,xysppc, msk8, rel8 | Branch if bit(s) clear; if (M)•(mask byte) $=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 4F ddmmrr 1 Fhh llmmrr OF xb mm rr 0 Fxb ff mm rr 0 Fxb ee ffmmrr | $\mathrm{r} P \mathrm{PPP}$ rfPPP rPPP rfPPP PrfPPP | ------------- |
| BRN rel8 | Branch never | REL | 21 rr | P | $-1-\|-\|-\|-\|$ |
| BRSET opr8, msk8, rel8 BRSET opr16a, msk8, rel8 BRSET oprx0_xysppc, msk8, rel8 BRSET oprx9,xysppc, msk8, rel8 BRSET oprx16,xysppc, msk8, rel8 | Branch if bit(s) set; if $(\overline{\mathrm{M}}) \bullet($ mask byte $)=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | $\begin{array}{\|l\|} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | 4E dd mm rr 1 E hh 11 mmrr 0 Exbmmrr 0 Exb ff mmrr 0 Exb ee ffmmrr | $\begin{aligned} & \mathrm{rPPP} \\ & \mathrm{rfPPP} \\ & \mathrm{rPPP} \\ & \mathrm{rfPPP} \\ & \mathrm{PrfPPP} \end{aligned}$ | ------------\| |
| BSET opr8, msk8 <br> BSET opr16a, msk8 <br> BSET oprx0_xysppc, msk8 <br> BSET oprx9,xysppc, msk8 <br> BSET oprx16,xysppc, msk8 | Set bit(s) in $M$ (M) $\mid$ mask byte $\Rightarrow M$ | DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 | 4 C dd mm <br> 1C hh 11 mm 0 Cxb mm OC xb ff mm 0 Cxb ee ff mm | rPwo rPwP rPwo rPwP frPwPo | - ------ ${ }^{\text {a }}$ \| $0 \mid-$ |
| BSR rel8 | Branch to subroutine; (SP)-2 $\Rightarrow$ SP $\operatorname{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 07 rr | SPPP | - ------------ |
| BVC rel8 | Branch if V clear; if $\mathrm{V}=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 28 rr | PPP (branch) P (no branch) | ------------- |
| BVS rel8 | $\begin{aligned} & \text { Branch if } V \text { set; if } V=1 \text {, then } \\ & (P C)+2+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 29 rr | PPP (branch) P (no branch) | ------------ |
| CALL opr16a, page CALL oprx0_xysppc, page CALL oprx9, xysppc, page CALL oprx16,xysppc, page CALL [D,xysppc] CALL [oprx16, xysppc] | $\begin{aligned} & \text { Call subroutine in expanded memory } \\ & (S P)-2 \Rightarrow S P \\ & \text { RTN }_{H}: R N_{L} \Rightarrow M_{S P}: M_{S P+1} \\ & (S P)-1 \Rightarrow S P ;(P P G) \Rightarrow M_{S P} \\ & \text { pg } \Rightarrow P P A G E \text { register } \\ & \text { subroutine address } \Rightarrow P C \end{aligned}$ |  <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 4A hh ll pg 4B xb pg 4B xb ff $p g$ 4B xb ee ff $p g$ 4B xb 4B xb ee ff | gnSsPPP gnSsPPP gnSsPPP fgnssPPP fIignSsPPP fIignSsPPP | ------------\| |
| CBA | Compare A to B; (A)-(B) | INH | 1817 | 00 | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| CLCSame as ANDCC \#\$FE | Clear C bit | IMM | 10 FE | P | -----------0 |
| CLISame as ANDCC \#\$EF | Clear I bit | IMM | 10 EF | P | - ----\|0|-|-|-| |
| CLR opr16a CLR oprx0_xysppc CLR oprx9,xysppc CLR oprx16,xysppc CLR [D,xysppc] CLR [oprx16,xysppc] CLRA CLRB | Clear M; $\$ 00 \Rightarrow \mathrm{M}$ <br> Clear A; $\$ 00 \Rightarrow \mathrm{~A}$ <br> Clear $B ; \$ 00 \Rightarrow B$ | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \\ & \text { INH } \\ & \text { INH } \end{aligned}$ | 79 hh ll 69 xb 69 xb ff 69 xb ee ff 69 xb 69 xb ee ff 87 C 7 | $\begin{aligned} & \mathrm{P} w \mathrm{O} \\ & \mathrm{Pw} \\ & \mathrm{PwO} \\ & \mathrm{PwP} \\ & \mathrm{PIfw} \\ & \mathrm{PIPw} \\ & 0 \\ & \mathrm{O} \end{aligned}$ |  |
| CLVSame as ANDCC \#\$FD | Clear V | IMM | 10 FD | P | - ----\|----|0| |
| CMPA \#opr8i CMPA opr8a CMPA opr16a CMPA oprx0_xysppc CMPA oprx9,xysppc CMPA oprx16,xysppc CMPA [D, xysppc] CMPA [oprx16,xysppc] | Compare A (A)-(M) or (A)-imm | $\begin{array}{\|l\|l} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{array}$ | 81 ii <br> 91 dd <br> B1 hh 11 <br> A1 xb <br> A1 xb ff <br> A1 xbeeff <br> A1 xb <br> A1 xbeeff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ------\| $\Delta \\| \Delta \Delta \Delta$ |
| CMPB \#opr8i <br> CMPB opr8a <br> CMPB opr16a <br> CMPB oprx0_xysppc <br> CMPB oprx9,xysppc <br> CMPB oprx16,xysppc <br> CMPB [D, xysppc] <br> CMPB [oprx16,xysppc] | Compare B (B)-(M) or (B)-imm | $\begin{aligned} & \hline \text { IMM } \\ & \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | C1 ii <br> D1 dd <br> F1 hh 11 <br> E1 xb <br> E1 xb ff <br> E1 xbeeff <br> E1 xb <br> E1 xbeeff | P rPf rPO rPf rPo frPp fIfrPf fIPrPf | ------\| $\Delta \mid \Delta \Delta \Delta$ |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| COM opr16a COM oprx0 xysppc COM oprx9,xysppp COM oprx16,xysppc COM [D, xysppc] COM [oprx16,xysppc] COMA COMB | Complement M ; $(\overline{\mathrm{M}})=\$ \mathrm{FF}-(\mathrm{M}) \Rightarrow \mathrm{M}$ <br> Complement $\mathrm{A} ;(\overline{\mathrm{A}})=$ \$FF- $(\mathrm{A}) \Rightarrow \mathrm{A}$ <br> Complement $B ;(\bar{B})=\$ F F-(B) \Rightarrow B$ | $\begin{array}{\|l} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \\ \hline \end{array}$ | 71 hh ll 61 xb 61 xb ff 61 xb ee ff 61 xb 61 xb ee ff 41 51 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 |  |
| CPD \#opr16i CPD opr8a CPD opr16a CPD oprx0_xysppc CPD oprx9, xysppc CPD opr16,xysppc CPD [D, xyspppc] CPD [oprx16,xysppc] | $\begin{aligned} & \text { Compare D } \\ & (A: B)-(M: M+1) \\ & \text { or }(A: B)-i m m \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | 8C jjkk 9 C dd BC hh 11 AC xb AC xbff AC xbeeff AC xb AC xbeeff | PO RPf RPO RPf RPO fRPP fIfRPf fIPRPf | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| CPS \#opr16i CPS opr8a CPS opr16a CPS oprx0_ xysppc CPS oprx9,xysppc CPS oprx16,xysppc CPS [D,xyspp] CPS [oprx16,xysppc] | $\begin{aligned} & \text { Compare SP } \\ & \text { (SP)-(M:M+1) } \\ & \text { or (SP)-imm } \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8F jjkk $9 F \mathrm{dd}$ BF hh ll AF xb AF xb ff AF xbee ff AF xb AF xbee ff |  | - ----- $\Delta \Delta \Delta \Delta \Delta$ |
| CPX\#opr16i <br> CPX opr8a <br> CPX opr16a <br> CPX oprx0_xysppc <br> CPX opry, xysppc <br> CPX opr16,xysppc <br> CPX[D,xysppc] <br> CPX [oprx16,xysppc] <br> CPY | $\begin{aligned} & \text { Compare X } \\ & \text { (X)-(M:M+1) } \\ & \text { or (X)-imm } \end{aligned}$ | IMM IDR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | 8E jjkk <br> 9E dd <br> BE hh 11 <br> AE xb <br> AE xb ff <br> AE xbeeff <br> AE xb <br> AE xbeeff | PO RPf RPO RPf RPO fRPP fIfRPf fIPRPf |  |
| CPY \#opr16i CPY opr8a CPY opr16a CPY oprx0_xysppc CPY oprx9,xysppc CPY oprx16,xysppc CPY [D,xysppc] CPY [oprx16,xysppc] | $\begin{aligned} & \text { Compare } \mathrm{Y} \\ & (\mathrm{Y}) \text {-(M:M+1) } \\ & \text { or }(\mathrm{Y}) \text {-imm } \end{aligned}$ | $\begin{aligned} & \hline \text { IMM } \\ & \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | 8D jjkk <br> 9D dd <br> BD hh 11 <br> AD xb <br> AD xb ff <br> $A D x b$ eeff <br> AD xb <br> AD xbeeff |  | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| DAA | Decimal adjust A for BCD | INH | 1807 | Ofo | ------\| $\Delta \Delta^{\text {a }}$ ? $\Delta^{\text {a }}$ |
| DBEQ abdxysp, rel9 | Decrement and branch if equal to 0 (counter) $-1 \Rightarrow$ counter if (counter) $=0$, then branch | $\begin{aligned} & \mathrm{REL} \\ & \text { (9-bit) } \end{aligned}$ | 04 lb rr |   <br> PPP (branch) <br> PPO (no branch) | - --------\|-|- |
| DBNE abdxysp, rel9 | Decrement and branch if not equal to 0; (counter) $-1 \Rightarrow$ counter; if (counter) $\neq 0$, then branch | $\begin{aligned} & \mathrm{REL} \\ & \text { (9-bit) } \end{aligned}$ | 04 lbrr | PPP (branch) PPO (no branch) | - ----------- |
| DEC opr16a DEC oprx0_xysppc DEC oprx9,xysppc DEC oprx6,xysppc DEC [D,xysppc] DEC[oprx16,xysppc] DECA DECB | Decrement M ; (M)-1 $\Rightarrow \mathrm{M}$ <br> Decrement A ; $(\mathrm{A})-1 \Rightarrow \mathrm{~A}$ Decrement B ; B ) $-1 \Rightarrow \mathrm{~B}$ | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \\ & \text { INH } \\ & \text { INH } \\ & \hline \end{aligned}$ | 73 hh ll 63 xb 63 xb ff 63 xb ee ff 63 xb 63 xb ee ff 43 53 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 | ------\| $\Delta\|\Delta\| \Delta \mid$ |
| DESSame as LEAS-1,SP | Decrement SP; (SP)-1 ${ }^{\text {S }}$ SP | IDX | 1B 9F | Pf | - ----\|-|-|-|-| |
| DEX | Decrement $X$; $(X)-1 \Rightarrow X$ | INH | 09 | 0 |  |
| DEY | Decrement $\mathrm{Y} ;(\mathrm{Y})-1 \Rightarrow \mathrm{Y}$ | INH | 03 | 0 |  |
| EDIV | Extended divide, unsigned; 32 by 16 to 16-bit; $(Y: D) \div(X) \Rightarrow Y ;$ remainder $\Rightarrow D$ | INH | 11 | ffffffffffo | ------\| $\Delta \Delta \Delta \Delta \Delta$ |

: User Guide - S12CPU15जtarestcale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H I N V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EDIVS | Extended divide,signed; 32 by 16 to 16-bit; $(\mathrm{Y}: \mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{Y}$ remainder $\Rightarrow \mathrm{D}$ | INH | 1814 | Offffffffffo |  |
| EMACS opr16a | Extended multiply and accumulate, signed; $\left(M_{X}: M_{X+1}\right) \times\left(M_{Y}: M_{Y+1}\right)+$ $(\mathrm{M} \sim \mathrm{M}+3) \Rightarrow \mathrm{M} \sim \mathrm{M}+3$; 16 by 16 to 32 -bit | Special | 1812 hh 11 | ORROfffRRfWWP |  |
| EMAXD oprx0_xysppc EMAXD oprx9, xysppc EMAXD oprx16,xysppc EMAXD [D, xysppc] EMAXD [oprx16,xysppc] | Extended maximum in D; put larger of 2 unsigned 16 -bit values in D $\operatorname{MAX}[(D),(M: M+1)] \Rightarrow D$ <br> N, Z, V, C bits reflect result of internal compare [(D)-(M:M+1)] | $\begin{array}{\|l} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \end{array}$ | $\begin{aligned} & 181 \mathrm{Axb} \\ & 181 \mathrm{Axb} \mathrm{ff} \\ & 181 \mathrm{Axb} \text { ee ff } \\ & 181 \mathrm{Axb} \\ & 181 \mathrm{Axb} \text { ee ff } \end{aligned}$ | ORPf ORPO OfRPP OfIfRPf OfIPRPf |  |
| EMAXM oprx0_xysppc EMAXM oprx9,xysppc EMAXM oprx16,xysppc EMAXM [D,xysppc] EMAXM [oprx16,xysppc] | Extended maximum in M; put larger of 2 <br> unsigned 16-bit values in M $\operatorname{MAX}[(D),(M: M+1)] \Rightarrow M: M+1$ $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(D)-(M:M+1)] | $\begin{array}{\|l} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \end{array}$ | 181 Exb 181 Exb ff 181 Exbeeff 181 Exb 181 Exb ee ff | ORPW ORPWO OfRPWP OfIfRPW OfIPRPW |  |
| EMIND oprx0_xysppc EMIND oprx9,xysppc EMIND oprx16,xysppc EMIND [D,xysppc] EMIND [oprx16,xysppc] | Extended minimum in D; put smaller of <br> 2 unsigned 16-bit values in D <br> $\operatorname{MIN}[(\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)] \Rightarrow \mathrm{D}$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(D)-(M:M+1)] | $\begin{array}{\|l} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \end{array}$ | 181 Bxb 18 Bxb ff 18 1B xb ee ff 18 1B xb 181 Bxb ee ff | ORPf ORPO OfRPP OfIfRPf OfIPRPf |  |
| EMINM oprx0_xysppc EMINM oprx9, xysppc EMINM oprx16,xysppc EMINM [D, xysppc] EMINM [oprx16,xysppc] | Extended minimum in M ; put smaller of <br> 2 unsigned 16-bit values in M $\operatorname{MIN}[(\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)] \Rightarrow \mathrm{M}: \mathrm{M}+1$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(D)-(M:M+1)] | IDX IDX1 IDX2 [D,IDX] $[$ IDX2] | 181 Fxb 181 Fxb ff 181 Fx ee ff 181 Fxb 181 Fxb ee ff | ORPW ORPWO OfRPWP OfIfRPW OfIPRPW |  |
| EMUL | Extended multiply, unsigned $(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D} ; 16$ by 16 to 32 -bit | INH | 13 | ffo | --\|-|-|-| $\Delta\|\Delta\|-\|\Delta\|$ |
| EMULS | Extended multiply, signed (D) $\times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D} ; 16$ by 16 to 32 -bit | INH | 1813 | Ofo <br> Offo (if followed by page 2 instruction) |  |
| EORA \#opr8i EORA opr8a EORA opr16a EORA oprx0_xysppc EORA oprx9, xysppc EORA oprx16,xysppc EORA [D, xysppc] EORA [oprx16,xysppc] | Exclusive OR A $(A) \oplus(M) \Rightarrow A$ or $(A) \oplus$ imm $\Rightarrow A$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 88 ii 98 dd B8 hh ll A8 xb A8 xb ff A8 xbee ff A8 xb A8 xb ee ff | $\begin{aligned} & \hline P \\ & r P f \\ & r P O \\ & r P f \\ & r P o \\ & \text { frPP } \\ & \text { fIfrPf } \\ & \text { fIPrPf } \\ & \hline \end{aligned}$ | --\|-|-|-| $\Delta\|\Delta\| 0 \mid-7$ |
| EORB \#opr8i EORB opr8a EORB opr16a EORB oprx0_xysppc EORB oprx9,xysppc EORB oprx16,xysppc EORB [D, xysppc] EORB [oprx16,xysppc] | Exclusive ORB (B) $\oplus(\mathrm{M}) \Rightarrow \mathrm{B}$ or (B) $\oplus i m m \Rightarrow B$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C8 ii D8 dd F8 hh ll E8 xb E8 xb ff E8 xb ee ff E8xb E8 xbee ff | $\begin{aligned} & \mathrm{P} \\ & \mathrm{rPf} \\ & \mathrm{rPO} \\ & \mathrm{rPf} \\ & \mathrm{rPO} \\ & \mathrm{frPP} \\ & \mathrm{fIfrPf} \\ & \mathrm{fIPrPf} \end{aligned}$ |  |
| ETBL oprx0_xysppc | $\begin{aligned} & \text { Extended table lookup and interpolate, } \\ & \text { 16-bit; }(\mathrm{M}: \mathrm{M}+1)+ \\ & {[(\mathrm{B}) \times((\mathrm{M}+2: \mathrm{M}+3)-(\mathrm{M}: M+1))] \Rightarrow \mathrm{D}} \\ & \hline \end{aligned}$ | IDX | 183 Fxb | ORRffffffP | --\|-|-|-| $\Delta\|\Delta\|-\|\Delta\|$ |
| Before executing ETBL, initialize B with fractional part of lookup value; initialize index register to point to first table entry (M:M+1). No extensions or indirect addressing allowed. |  |  |  |  |  |
| EXG abcdxysp,abcdxysp | Exchange register contents $(r 1) \Leftrightarrow(r 2) r 1$ and $r 2$ same size $\$ 00:(r 1) \Rightarrow r 2 r 1=8$-bit; r2=16-bit $\left(r 1_{\mathrm{L}}\right) \Leftrightarrow(\mathrm{r} 2) \mathrm{r} 1=16$-bit; $\mathrm{r} 2=8$-bit | INH | B7 eb | P |  |
| FDIV | Fractional divide; $(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X}$ remainder $\Rightarrow \mathrm{D}$; 16 by 16-bit | INH | 1811 | Offffffffffo |  |


| Source Form | Operation | $\begin{array}{\|c\|} \hline \text { Address } \\ \text { Mode } \end{array}$ | $\begin{gathered} \text { Machine } \\ \text { Coding (Hex) } \end{gathered}$ | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IBEQ abdxysp, rel9 | Increment and branch if equal to 0 (counter) $+1 \Rightarrow$ counter If (counter) $=0$, then branch | $\begin{aligned} & \mathrm{REL} \\ & \text { (9-bit) } \end{aligned}$ | 04 lbrr | PPP (branch) PPO (no branch) | ---------\|--- |
| IBNE abdxysp, rel9 | Increment and branch if not equal to 0 (counter) $+1 \Rightarrow$ counter If (counter) $\neq 0$, then branch | $\begin{aligned} & \mathrm{REL} \\ & \text { (9-bit) } \end{aligned}$ | 04 lb rr | PPP (branch) <br> PPO (no branch) | -----\|-|-|--|- |
| IDIV | Integer divide, unsigned; $(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X}$ Remainder $\Rightarrow \mathrm{D}$; 16 by 16 -bit | INH | 1810 | Offffffffffo | - ----\|-|-| ${ }^{\text {\| }} 0$ |
| IDIVS | Integer divide, signed; ( D$) \div(\mathrm{X}) \Rightarrow \mathrm{X}$ Remainder $\Rightarrow \mathrm{D}$; 16 by 16 -bit | INH | 1815 | Offffffffffo | ------- $\Delta \mid \Delta \Delta \Delta \Delta$ |
| INC opr16a <br> INC oprxO_xysppc <br> INC oprx9,xysppc <br> INC oprx16,xysppc <br> INC [D,xysppc] <br> INC [oprx16,xysppc] <br> INCA <br> INCB | Increment M; (M)+1 $\Rightarrow \mathrm{M}$ <br> Increment $A ;(A)+1 \Rightarrow A$ <br> Increment $\mathrm{B} ;(\mathrm{B})+1 \Rightarrow \mathrm{~B}$ | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & {[\text { IDX2] }} \\ & \text { INH } \\ & \text { INH } \end{aligned}$ | $\begin{aligned} & \hline 72 \mathrm{hh} \mathrm{ll} \\ & 62 \mathrm{xb} \\ & 62 \mathrm{xb} \mathrm{ff} \\ & 62 \mathrm{xb} \text { ee ff } \\ & 62 \mathrm{xb} \\ & 62 \mathrm{xb} \text { ee ff } \\ & 42 \\ & 52 \end{aligned}$ | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 | ------\| $\Delta \Delta \Delta \Delta$ |
| INSSame as LEAS 1,SP | Increment SP; (SP) $+1 \Rightarrow$ SP | IDX | 1B 81 | Pf | - ----------- |
| INX | Increment $X$; $(X)+1 \Rightarrow X$ | INH | 08 | 0 | - - - - - - - - - ${ }^{\text {a }}$ |
| INY | Increment $\mathrm{Y} ;(\mathrm{Y})+1 \Rightarrow \mathrm{Y}$ | INH | 02 | $\bigcirc$ | - ----\|-|-| ${ }^{\text {a }}$ |
| JMP opr16a JMP oprx0_xysppc JMP oprx9, xysppc JMP oprx16,xysppc JMP [D,xysppc] JMP [oprx16,xysppc] | Jump <br> Subroutine address $\Rightarrow \mathrm{PC}$ | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [DX2] } \end{aligned}$ | $\begin{aligned} & 06 \mathrm{hh} \text { ll } \\ & 05 \mathrm{xb} \\ & 05 \mathrm{xb} \mathrm{ff} \\ & 05 \mathrm{xb} \text { ee ff } \\ & 05 \mathrm{xb} \\ & 05 \mathrm{xb} \text { ee ff } \end{aligned}$ | PPP PPP PPP fPPP fIfPPP fIfPPP | - ---------1-- |
| JSR opr8a <br> JSR opr16a <br> JSR oprxO_xysppc <br> JSR oprx9,xysppc <br> JSR oprx16,xysppc <br> JSR [D,xysppc] <br> JSR [oprx16,xysppc] | Jump to subroutine (SP)-2 $\Rightarrow$ SP <br> $\operatorname{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ <br> Subroutine address $\Rightarrow P C$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | 17 dd <br> 16 hh 11 <br> 15 xb <br> 15 xb ff <br> 15 xb ee ff <br> 15 xb <br> 15 xb eeff | SPPP SPPP PPPS PPPS fPPPS fIfPPPS fIfPPPS | - ---1---1-1-\| |
| LBCC rel16Same as LBHS | Long branch if C clear; if $\mathrm{C}=0$, then (PC) $+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 1824 qq rr | OPPP (branch) opo (no branch) | ------------\| |
| LBCS rel16Same as LBLO | Long branch if C set; if $\mathrm{C}=1$, then (PC) $+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 1825 qq rr | OPPP (branch) OPO (no branch) | -----\|-|-|--|- |
| LBEQ rel16 | Long branch if equal; if $\mathrm{Z}=1$, then (PC) $+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 1827 qq rr | OPPP (branch) opo (no branch) | -----\|------- |
| LBGE rel16 | Long branch if $\geq 0$, signed If $\mathrm{N} \oplus \mathrm{V}=0$, then $(\mathrm{PC})+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 182C qq rr | OPPP (branch) opo (no branch) | ------------\| |
| LBGT rel16 | $\begin{aligned} & \text { Long branch if }>0 \text {, signed } \\ & \text { If } Z \mid(N \oplus V)=0 \text {, then }(P C)+4+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 18 2Eqq rr | OPPP (branch) opo (no branch) | -----\|------- |
| LBHI rel16 | Long branch if higher, unsigned If $\mathrm{C} \mid \mathrm{Z}=0$, then $(\mathrm{PC})+4+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 1822 qq rr | OPPP (branch) opo (no branch) | - ----\|---|---| |
| LBHS rel16Same as LBCC | Long branch if higher or same, unsigned; If $\mathrm{C}=0$, ( PC ) $+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 1824 qq rr | OPPP (branch) OPO (no branch) | ------------ |
| LBLE rel16 | $\begin{aligned} & \text { Long branch if } \leq 0 \text {, signed; if } \\ & Z \mid(N \oplus V)=1 \text {, then }(P C)+4+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 18 2F qq rr | OPPP (branch) opo (no branch) | - ----\|---|---| |
| LBLO rel16Same as LBCS | Long branch if lower, unsigned; if $\mathrm{C}=1$, then $(\mathrm{PC})+4+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 1825 qq rr | OPPP (branch) opo (no branch) | - ----\|---|---| |
| LBLS rel16 | Long branch if lower or same, unsigned; If $C \mid Z=1$, then (PC) $+4+$ rel $\Rightarrow$ PC | REL | 1823 qq rr | OPPP (branch) OPO (no branch) | ------------\| |
| LBLT rel16 | $\begin{aligned} & \text { Long branch if < } 0 \text {, signed } \\ & \text { If } \mathrm{N} \oplus \mathrm{~V}=1 \text {, then }(\mathrm{PC})+4+\text { rel } \Rightarrow \mathrm{PC} \\ & \hline \end{aligned}$ | REL | 18 2D qq rr | OPPP (branch) OPO (no branch) | - ----\|------- |

User Guide - S12CPU15Ftersscale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LBMI rel16 | $\begin{aligned} & \text { Long branch if minus } \\ & \text { If } \mathrm{N}=1 \text {, then }(\mathrm{PC})+4+\mathrm{rel} \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 18 2B qq rr | OPPP (branch) opo (no branch) | ------------ |
| LBNE rel16 | Long branch if not equal to 0 If $Z=0$, then ( PC ) $+4+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 1826 qq rr | OPPP (branch) opo (no branch) | - ------------ |
| LBPL rel16 | $\begin{aligned} & \text { Long branch if plus } \\ & \text { If } \mathrm{N}=0 \text {, then }(\mathrm{PC})+4+\mathrm{rel} \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 182A qq rr | OPPP (branch) opo (no branch) | \|---|-|--|---|- |
| LBRA rel16 | Long branch always | REL | 1820 qq rr | OPPP | ---\|---|---| |
| LBRN rel16 | Long branch never | REL | 1821 qq rr | OPO |  |
| LBVC rel16 | $\begin{aligned} & \text { Long branch if } \mathrm{V} \text { clear } \\ & \text { If } V=0 \text {, then }(\mathrm{PC})+4+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 1828 qq rr | OPPP (branch) OPO (no branch) | ------------- |
| LBVS rel16 | $\begin{aligned} & \text { Long branch if } V \text { set } \\ & \text { If } V=1 \text {, then }(P C)+4+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 1829 qq rr | OPPP (branch) OPO (no branch) | - $-1-\|-\|-\|-\|-\|-1$ |
| LDAA \#opr8i <br> LDAA opr8a <br> LDAA opr16a <br> LDAA oprx0_xysppc <br> LDAA oprx9,xysppc <br> LDAA oprx16,xysppc <br> LDAA [D, xysppc] <br> LDAA [oprx16,xysppc] | Load A <br> $(\mathrm{M}) \Rightarrow \mathrm{A}$ <br> or imm $\Rightarrow A$ | IMM DR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 86 ii <br> 96 dd <br> B6 hh 11 <br> A 6 xb <br> A 6 xb ff <br> A 6 xb eeff <br> A 6 xb <br> A6 xb eeff | $\begin{aligned} & \hline P \\ & \text { rPf } \\ & \text { rPo } \\ & \text { rPf } \\ & \text { rPo } \\ & \text { frPp } \\ & \text { fIfrPf } \\ & \text { fIPrPf } \end{aligned}$ |  |
| LDAB \#opr8i <br> LDAB opr8a <br> LDAB opr16a <br> LDAB oprx0_xysppc <br> LDAB oprx9,xysppc <br> LDAB oprx16,xysppc <br> LDAB [D,xysppc] <br> LDAB [oprx16,xysppc] | LoadB $(\mathrm{M}) \Rightarrow \mathrm{B}$ or imm $\Rightarrow B$ | IMM IMIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C6 ii D 6 dd F6 hh ll E6 xb E6 xb ff E6 xb ee ff E6 xb E6xb ee ff | $\begin{aligned} & \mathrm{P} \\ & \text { rPf } \\ & \text { rPO } \\ & \text { rPf } \\ & \text { rPo } \\ & \text { frPP } \\ & \text { fIfrPf } \\ & \text { fIPrPf } \end{aligned}$ | ----\|-| $\Delta\|\Delta\| 0 \mid$ |
| LDD \#opr16i <br> LDD opr8a <br> LDD opr16a <br> LDD oprx0_xysppc <br> LDD oprx9,xysppc <br> LDD oprx16,xysppc <br> LDD [D,xysppc] <br> LDD [oprx16,xysppc] | $\begin{aligned} & \text { Load D } \\ & (M: M+1) \Rightarrow A: B \\ & \text { or imm } \Rightarrow A: B \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | CC jjkk <br> DC dd <br> FC hh 11 <br> EC xb <br> EC xbff <br> EC xbeeff <br> EC xb <br> EC xbeeff |  | ---\|-|-| $\Delta \Delta \Delta 0 \mid-$ |
| LDS \#opr16i <br> LDS opr8a <br> LDS opr16a <br> LDS oprx0_xysppc <br> LDS oprx9,xysppc <br> LDS oprx16,xysppc <br> LDS [D,xysppc] <br> LDS [oprx16,xysppc] | $\begin{aligned} & \text { Load SP } \\ & (\mathrm{M}: M+1) \Rightarrow S P \\ & \text { or imm } \Rightarrow S P \end{aligned}$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{array}$ | CF jjkk <br> DF dd <br> FF hh 11 <br> EF xb <br> EF xb ff <br> EF xbeeff <br> EF xb <br> EF xbeeff | $\begin{aligned} & \hline \text { PO } \\ & \text { RPf } \\ & \text { RPO } \\ & \text { RPf } \\ & \text { RPO } \\ & \text { fRPP } \\ & \text { fIfRPf } \\ & \text { fIPRPf } \end{aligned}$ | -----\|-| $\Delta \Delta \Delta 0 \mid-$ |
| LDX \#opr16i <br> LDX opr8a <br> LDX opr16a <br> LDX oprx0_xysppc <br> LDX oprx9, xysppc <br> LDX oprx16,xysppc <br> LDX [D,xysppc] <br> LDX [oprx16,xysppc] | $\begin{aligned} & \text { Load X } \\ & (\mathrm{M}: M+1) \Rightarrow X \\ & \text { or } \mathrm{imm} \Rightarrow \mathrm{X} \end{aligned}$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | CE jjkk <br> DE dd <br> FE hh 11 <br> EE xb <br> EE xbff <br> EE xbeeff <br> EE xb <br> EE xbeeff |  | -----\|-| $\Delta \Delta \Delta 0 \mid-$ |
| LDY \#opr16i <br> LDY opr8a <br> LDY opr16a <br> LDY oprx0_xysppc <br> LDY oprx9,xysppc <br> LDY oprx16,xysppc <br> LDY [D,xysppc] <br> LDY [oprx16,xysppc] | Load Y <br> $(M: M+1) \Rightarrow Y$ <br> or $\mathrm{imm} \Rightarrow \mathrm{Y}$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{array}$ | CD jjkk <br> DD dd <br> FD hh 11 <br> ED xb <br> ED xbff <br> ED xb ee ff <br> ED xb <br> ED xb eeff | PO RPf RPO RPf RPO fRPP fIfRPf fIPRPf | -----\|-| $\Delta \Delta \Delta 0 \mid-$ |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H I Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LEAS oprx0_xysppc LEAS oprx9,xysppc LEAS oprx16,xysppc | Load effective address into SP $\mathrm{EA} \Rightarrow \mathrm{SP}$ | $\begin{array}{\|l\|} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | $\begin{aligned} & 1 \mathrm{Bxb} \\ & 1 \mathrm{~B} \times \mathrm{ff} \\ & 1 \mathrm{Bxb} \text { ee } \mathrm{ff} \end{aligned}$ | $\begin{aligned} & \mathrm{Pf} \\ & \mathrm{PO} \\ & \mathrm{PP} \end{aligned}$ | - ------------ |
| LEAX oprx0_xysppc LEAX oprx9, xysppc LEAX oprx16,xysppc | Load effective address into $X$ $E A \Rightarrow X$ | $\begin{aligned} & \mathrm{IDX} \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 1A xb <br> 1Axbff <br> 1 Axb eeff | $\begin{aligned} & \hline \mathrm{Pf} \\ & \mathrm{PO} \\ & \mathrm{PP} \end{aligned}$ | -----\|-|-|---| |
| LEAY oprx0_xysppc LEAY oprx9, xysppc LEAY oprx16,xysppc | $\begin{aligned} & \text { Load effective address into } Y \\ & E A \Rightarrow Y \end{aligned}$ | $\begin{array}{\|l} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \hline \end{array}$ | $\begin{aligned} & 19 \mathrm{xb} \\ & 19 \mathrm{xb} \mathrm{ff} \\ & 19 \mathrm{xb} \text { ee } \mathrm{ff} \end{aligned}$ | $\begin{aligned} & \mathrm{Pf} \\ & \mathrm{PO} \\ & \mathrm{PP} \\ & \hline \end{aligned}$ | - -1-\|-|-|-|-1-| |
| LSL opr16aSame as ASL <br> LSL oprxO_xysppc <br> LSL oprx9,xysppc <br> LSL oprx16,xysppc <br> LSL [D,xysppc] <br> LSL[oprx16,xysppc] <br> LSLASame as ASLA <br> LSLBSame as ASLB |  | EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> INH <br> INH | 78 hh ll 68 xb 68 xb ff 68 xb ee ff 68 xb 68 xb ee ff 48 58 | roPw rPw rPOw frPPw fIfrPw fIPrPw 0 0 | ------- $\Delta \Delta \Delta \Delta \Delta$ |
| LSLDSame as ASLD |  | INH | 59 | $\bigcirc$ | ------- $\Delta \Delta \Delta \Delta \Delta$ |
| LSR opr16a <br> LSR oprx0_xysppc <br> LSR oprx9,xysppc <br> LSR oprx16,xysppc <br> LSR [D,xysppc] <br> LSR [oprx16,xysppc] <br> LSRA <br> LSRB |  | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 74 hh ll 64 xb 64 xb ff 64 xb ee ff 64 xb 64 xb ee ff 44 54 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 |  |
| LSRD |  | INH | 49 | $\bigcirc$ | ------ $0 \mid \Delta \Delta \Delta$ |
| MAXA oprxO xysppc MAXA oprx9, xysppc MAXA oprx16,xysppc MAXA [D, xysppc] MAXA [oprx16,xysppc] | Maximum in A ; put larger of 2 unsigned 8-bit values in A $\operatorname{MAX[}(\mathrm{A}),(\mathrm{M})] \Rightarrow \mathrm{A}$ $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | $\begin{aligned} & \hline \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & {[\text { IDX2] }} \end{aligned}$ | $\begin{aligned} & 1818 \mathrm{xb} \\ & 1818 \mathrm{xb} \mathrm{ff} \\ & 1818 \mathrm{xb} \text { ee ff } \\ & 1818 \mathrm{xb} \\ & 1818 \mathrm{xb} \text { ee } \mathrm{ff} \end{aligned}$ | OrPf OrPO OfrPP OfIfrPf OfIPrPf | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| MAXM oprxO_xysppc MAXM oprx9,xysppc MAXM oprx16,xysppc MAXM [D, xysppc] MAXM [oprx16,xysppc] | Maximum in M; put larger of 2 unsigned 8 -bit values in M $\operatorname{MAX}[(A),(M)] \Rightarrow M$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | IDX IDX1 IDX2 [D,IDX] [IDX2] | 181 Cxb 18 Clb Cf 18 Cxbee ff 18 Clxb 18 Clxbeeff | OrPw OrPwo OfrPwP OfIfrPw OfIPrPw |  |
| MEM | Determine grade of membership; $\mu$ (grade) $\Rightarrow \mathrm{M}_{\mathrm{Y}} ;(\mathrm{X})+4 \Rightarrow \mathrm{X} ;(\mathrm{Y})+1 \Rightarrow \mathrm{Y}$ If $(A)<P 1$ or $(A)>P 2$, then $\mu=0$; else $\mu=$ $\operatorname{MIN}[((\mathrm{A})-\mathrm{P} 1) \times \mathrm{S} 1,(\mathrm{P} 2-(\mathrm{A})) \times \mathrm{S} 2, \$ \mathrm{SF}]$ (A)=current crisp input value; $X$ points at 4 data bytes (P1, P2, S1, S2) of a trapezoidal membership function; Y points at fuzzy input (RAM location) | Special | 01 | RRfOw | ---? ${ }^{\text {- }}$ - ? ? ? ? ${ }^{\text {a }}$ |
| MINA oprx0_xysppc MINA oprx9, xysppc MINA oprx16,xysppc MINA [D,xysppc] MINA [oprx16,xysppc] | Minimum in A; put smaller of 2 unsigned 8-bit values in A $\operatorname{MIN}[(A),(M)] \Rightarrow A$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | IDX IDX1 IDX2 $\left[\begin{array}{l}\text { ID,IDX] } \\ {[D X 2]}\end{array}\right]$ | $\begin{aligned} & 1819 \mathrm{xb} \\ & 1819 \mathrm{xb} \mathrm{ff} \\ & 1819 \mathrm{xb} \text { ee } \mathrm{ff} \\ & 1819 \mathrm{xb} \\ & 1819 \mathrm{xb} \text { ee } \mathrm{ff} \end{aligned}$ | OrPf OrPO OfrPP OfIfrPf OfIPrPf | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| MINM oprx0_xysppc MINM oprx9,xysppc MINM oprx16,xysppc MINM [D,xysppc] MINM [oprx16,xysppc] | Minimum in N ; put smaller of two unsigned 8 -bit values in M $\operatorname{MIN}[(A),(M)] \Rightarrow M$ $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | IDX IDX1 IDX2 [D,IDX] [IDX2] | $\begin{aligned} & 18 \text { 1D xb } \\ & 18 \text { 1D xb ff } \\ & 18 \text { 1D xb ee ff } \\ & 18 \text { 1D xb } \\ & 18 \text { 1D xb ee ff } \end{aligned}$ | OrPw <br> OrPwo <br> OfrPwP <br> OfIfrPw <br> OfIPrPw | ------- $\Delta \mid \Delta \Delta \Delta \Delta$ |

User Guide - S12CPU15F̛̣̂riscale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MOVB \#opr8, opr16a <br> MOVB \#opr8i, oprx0_xysppc <br> MOVB opr16a, opr16a <br> MOVB opr16a, oprx0_xysppc <br> MOVB oprx0_xysppc, opr16a <br> MOVB oprx0_xysppc, oprx0_xysppc | Move byte Memory-to-memory 8-bit byte-move $\left(M_{1}\right) \Rightarrow M_{2}$ <br> First operand specifies byte to move | $\begin{aligned} & \hline \text { IMM-EXT } \\ & \text { IMM } \\ & \text { EXT-EXT } \\ & \text { EXT-IDX } \\ & \text { IDX-EXT } \\ & \text { IDX-IDX } \end{aligned}$ | 180 B ii hh ll 1808 xb ii 180 Chh 1 hh 11 $1809 \mathrm{xb} h \mathrm{hh} 11$ $180 \mathrm{xb} h \mathrm{ll}$ 180 axb xb | OPwP <br> OPwO <br> OrPwPo <br> OPrPw <br> OrPwP <br> OrPwo | - ------------ |
| MOVW \#oprx16, opr16a MOVW \#opr16i, oprx0_xysppc MOVW opr16a, opr16a MOVW opr16a, oprxO_xysppc MOVW oprx0_xysppc, opr16a MOVW oprx0_xysppc, oprx0_xysppc | Move word <br> Memory-to-memory 16-bitword-move $\left(M_{1}: M_{1}+1\right) \Rightarrow M_{2}: M_{2}+1$ <br> First operand specifies word to move | $\begin{array}{\|l\|} \hline \text { IMM-EXT } \\ \text { IMM-IDX } \\ \text { EXT-EXT } \\ \text { EXT-IDX } \\ \text { IDX-EXT } \\ \text { IDX-IDX } \end{array}$ | $\begin{aligned} & 1803 \mathrm{jjkk} \mathrm{hhll} \\ & 1800 \mathrm{xb} \mathrm{j} \mathrm{jk} \\ & 1804 \mathrm{hh} \mathrm{ll} \mathrm{hhll} \\ & 1801 \mathrm{xb} \mathrm{hh} \mathrm{ll} \\ & 1805 \mathrm{xb} \mathrm{hh} l \mathrm{l} \\ & 1802 \mathrm{xb} \mathrm{xb} \end{aligned}$ | OPWPO OPPW ORPWPO OPRPW ORPWP ORPWO | ---------\|--- |
| MUL | Multiply, unsigned $(A) \times(B) \Rightarrow A: B ; 8$ by 8-bit | INH | 12 | O | - ----------- ${ }^{\text {a }}$ |
| NEG opr16a <br> NEG oprxO_xysppc <br> NEG oprx9, xysppc <br> NEG oprx16,xysppc <br> NEG [D,xysppc] <br> NEG [oprx16,xysppc] <br> NEGA <br> NEGB | Negate $\mathrm{M} ; 0-(\mathrm{M}) \Rightarrow \mathrm{M}$ or $(\overline{\mathrm{M}})+1 \Rightarrow \mathrm{M}$ <br> Negate $\mathrm{A} ; 0-(\mathrm{A}) \Rightarrow \mathrm{A}$ or $(\overline{\mathrm{A}})+1 \Rightarrow \mathrm{~A}$ <br> Negate $\mathrm{B} ; 0-(\mathrm{B}) \Rightarrow \mathrm{B}$ or $(\overline{\mathrm{B}})+1 \Rightarrow \mathrm{~B}$ |  <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> INH <br> INH | 70 hh 11 60 xb 60 xb ff 60 xb ee ff 60 xb 60 xb ee ff 40 50 | rPwo <br> rPw <br> rPwo frPwP fIfrPw fIPrPw | ------\| $\Delta \mid \Delta \Delta \Delta$ |
| NOP | No operation | INH | A7 | $\bigcirc$ | -----------\| |
| ORAA \#opr8i ORAA opr8a ORAA opr16a ORAA oprx0_xysppc ORAA oprx9,xysppc ORAA oprx16,xysppc ORAA [D,xysppc] ORAA [oprx16,xysppc] | OR accumulator A <br> (A) \| (M) $\Rightarrow A$ <br> or $(A) \mid$ imm $\Rightarrow A$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8A ii <br> 9A dd <br> BA hh 11 <br> AA xb <br> AA xb ff <br> AA xb ee ff <br> AA xb <br> AA xb ee $f f$ | P rPf rPo rPf rPo frPp fIfrPf fIPrPf |  |
| ORAB \#opr8i ORAB opr8a ORAB opr16a ORAB oprxO_xysppc ORAB oprx9,xysppc ORAB oprx16,xysppc ORAB [D,xysppc] ORAB [oprx16,xysppc] | OR accumulator B <br> (B) $\mid(M) \Rightarrow B$ <br> or (B) $\mid \mathrm{imm} \Rightarrow B$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | CA ii <br> DA dd <br> FA hh 11 <br> EA xb <br> EA $x b$ ff <br> EA xbeeff <br> EA xb <br> EA xb eeff | $\begin{aligned} & \hline P \\ & \text { rPf } \\ & \text { rPO } \\ & \text { rPf } \\ & \text { rPO } \\ & \text { frPp } \\ & \text { fIfrPf } \\ & \text { fIPrPf } \end{aligned}$ |  |
| ORCC \#opr8i | OR CCR; (CCR) \| imm $\Rightarrow$ CCR | IMM | 14 ii | P |  |
| PSHA | Push A; (SP)-1 $\Rightarrow$ SP; $(A) \Rightarrow M_{\text {SP }}$ | INH | 36 | Os | - ---\|----|--| |
| PSHB | Push B; (SP)-1 $\Rightarrow$ SP; $(B) \Rightarrow M_{\text {SP }}$ | INH | 37 | Os | ------------ |
| PSHC | $\begin{aligned} & \text { Push CCR; (SP) }-1 \Rightarrow \text { SP; } \\ & (C C R) \Rightarrow M_{S P} \end{aligned}$ | INH | 39 | Os | ----\|---|-|-| |
| PSHD | Push D $(S P)-2 \Rightarrow S P ;(A: B) \Rightarrow M_{S P}: M_{S P+1}$ | INH | 3B | OS | --------\|-|-| |
| PSHX | $\begin{aligned} & \text { Push } X \\ & (S P)-2 \Rightarrow S P ;\left(X_{H}: X_{L}\right) \Rightarrow M_{S P}: M_{S P+1} \end{aligned}$ | INH | 34 | os | -----\|---|---| |
| PSHY | $\begin{aligned} & \text { Push Y } \\ & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;\left(\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1} \end{aligned}$ | INH | 35 | os | - ----\|------- |
| PULA | $\begin{aligned} & \text { Pull A } \\ & \left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{A} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 32 | ufo | - ------------ |
| PULB | $\begin{aligned} & \text { Pull B } \\ & \left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{B} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 33 | ufo | - ---\|-|--|-|- |
| PULC | $\begin{aligned} & \text { Pull CCR } \\ & \left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{CCR} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 38 | ufo | $\Delta \\| \downarrow \Delta \Delta \Delta \Delta \Delta \Delta \Delta$ |
| PULD | $\begin{aligned} & \text { Pull D } \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow A: B ;(S P)+2 \Rightarrow S P \end{aligned}$ | INH | 3A | Ufo | ------------\| |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X HINZVC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PULX | Pull $X$ $\left(M_{\text {SPP }}: M_{S P+1}\right) \Rightarrow X_{H}: X_{L} ;(S P)+2 \Rightarrow S P$ | INH | 30 | Ufo | ---\|----|---|- |
| PULY | $\begin{aligned} & \text { Pull } Y \text { Y } \\ & \left(\mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 31 | Ufo | - ---\|----|--|- |
| REV | Rule evaluation, unweighted; find smallest rule input; store to rule outputs unless fuzzy output is larger | Special | 18 3A | $\begin{aligned} & \begin{array}{l} \text { Orf } \left.\left(t^{\wedge} \mathrm{tx}\right)\right)^{*} \\ \mathrm{ff}+\operatorname{Orft} \wedge * * \end{array} \end{aligned}$ |  |
| ${ }^{*}$ The $t^{\wedge}$ t $x$ loop is executed once for each element in the rule list. The ^ denotes a check for pending interrupt requests. <br> **These are additional cycles caused by an interrupt: ff is the exit sequence and orft^ is the re-entry sequence. |  |  |  |  |  |
| REVW | Rule evaluation, weighted; rule weights optional; find smallest rule input; store to rule outputs unless fuzzy output is larger | Special | 183 B | ORf (t^Tx) O* <br> or <br> ORf(r^ffRf) O** <br> fffftorft^*** <br> fffflorfr^**** |  |

${ }^{*}$ With weighting not enabled, the $t^{\wedge} T x$ loop is executed once for each element in the rule list. The ${ }^{\wedge}$ denotes a check for pending interrupt requests. $* *$ With weighting enabled, the $t^{\wedge} T x$ loop is replaced by $r^{\wedge} f f R f$.
${ }^{* * *}$ Additional cycles caused by an interrupt when weighting is not enabled: $f f f f$ is the exit sequence and $\operatorname{ORft}{ }^{\wedge}$ is the re-entry sequence. **** Additional cycles caused by an interrupt when weighting is enabled: $f f f f$ is the exit sequence and $O R f r^{\wedge}$ is the re-entry sequence.

| ROL opr16a ROL oprx0_xysppc ROL oprx9, xysppc ROL oprx16,xysppc ROL [D,xysppc] ROL [oprx16,xysppc] ROLA ROLB | Rotate left A <br> Rotate left B | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { IDX2] } \\ & \text { INH } \\ & \text { INH } \end{aligned}$ | 75 hh ll 65 xb 65 xb ff 65 xb ee ff 65 xb 65 xb ee ff 45 55 | $\begin{aligned} & \text { rPwo } \\ & \text { rPw } \\ & \text { rPwo } \\ & \text { frPwP } \\ & \text { fIfrPw } \\ & \text { fIPrPw } \\ & 0 \\ & 0 \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ROR opr16a ROR oprx0_xysppc ROR oprx9, xysppc ROR oprx16,xysppc ROR [D,xysppc] ROR [oprx16,xysppc] RORA RORB | Rotate right A <br> Rotate right B | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \\ & \text { INH } \\ & \text { INH } \end{aligned}$ | 76 hh ll 66 xb 66 xb ff 66 xb ee ff 66 xb 66 xb ee ff 46 56 | $\begin{aligned} & \hline \text { rPwo } \\ & \text { rPw } \\ & \text { rPwo } \\ & \text { frPwP } \\ & \text { fIfrPw } \\ & \text { fIPrPw } \\ & 0 \\ & 0 \end{aligned}$ | ------- $\Delta \Delta \Delta \Delta \Delta \Delta$ |
| RTC | $\begin{aligned} & \text { Return from call; }\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \text { PPAGE } \\ & (\mathrm{SP})+1 \Rightarrow \mathrm{SP} ; \\ & \left(\mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}} \\ & (\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 0A | UUnfPPP | ----\|----|---|- |
| RTI | $\begin{aligned} & \text { Return from interrupt } \\ & \left(M_{S P}\right) \Rightarrow C C R ;(S P)+1 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow B: A ;(S P)+2 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow X_{H}: X_{L} ;(S P)+4 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow P_{H}: P C_{L} ;(S P)+2 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow Y_{H}: Y_{L} ;(S P)+4 \Rightarrow S P \end{aligned}$ | INH | OB | uUUUUPPP or uUUUUfVfPPP* | $\Delta \backslash \Downarrow \mid \Delta \Delta \Delta \Delta \Delta \Delta \Delta \Delta$ |
| *RTI takes 11 cycles if an interrupt is pending. |  |  |  |  |  |
| RTS | $\begin{aligned} & \text { Return from subroutine } \\ & \left(\mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{H}: \mathrm{PC}_{\mathrm{L}} ; \\ & (\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 3D | UfPPP | -------------- |
| SBA | Subtract B from A; (A)-(B) $\Rightarrow$ A | INH | 1816 | 00 | $\boxed{------\Delta \Delta \Delta \Delta \Delta}$ |
| SBCA \#opr8i SBCA opr8a SBCA opr16a SBCA oprx0_xysppc SBCA oprx9,xysppc SBCA oprx16,xysppc SBCA [D, xysppc] SBCA [oprx16,xysppc] | Subtract with carry from A <br> (A)-(M)-C $\Rightarrow A$ <br> or (A)-imm-C $\Rightarrow A$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{array}$ | 82 ii <br> 92 dd <br> B2 hh 11 <br> A 2 xb <br> A2 xb ff <br> A2 xb eeff <br> A2 xb <br> A2 xb eeff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ------- $\Delta \Delta \Delta \Delta \Delta$ |

User Guide - S12CPU15F̛̣̂riscale Semiconductor, Inc.

| Source Form | Operation | Address Mode | $\begin{gathered} \text { Machine } \\ \text { Coding (Hex) } \end{gathered}$ | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SBCB \#opr8i SBCB opr8a SBCB opr16a SBCB oprx0_xysppc SBCB oprx9,xysppc SBCB opr16,xysppc SBCB [D,xypppc] SBCB [oprx16,xysppc] | Subtract with carry from B (B)-(M)-C $\Rightarrow B$ <br> or (B)-imm-C $\Rightarrow B$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | C2 ii <br> D2 dd <br> F2 hh 11 <br> E2 xb <br> E2 xb ff <br> E2 xbeeff <br> E2 xb <br> E2 xbeeff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf |  |
| SECSame as ORCC \#\$01 | Set C bit | IMM | 1401 | P | ------\|---|-1 |
| SEISame as ORCC \#\$10 | Set I bit | IMM | 1410 | P | ---1\|-|-|-| |
| SEVSame as ORCC \#\$02 | Set V bit | IMM | 1402 | P | ---------11] |
| SEX abc, dxyspSame as TFR r1, r2 | Sign extend; 8-bit r1 to 16 -bit r2 $\$ 00:(\mathrm{r} 1) \Rightarrow \mathrm{r} 2$ if bit 7 of r 1 is 0 \$FF:(r1) $\Rightarrow \mathrm{r} 2$ if bit 7 of $r 1$ is 1 | INH | B7 eb | P | - ---------\|-| |
| STAA opr8a STAA opr16a STAA oprx0_xysppc STAA oprx9, xysppc STAA oprx16,xysppc STAA [D, xysppc] STAA [oprx16,xysppc] | Store accumulator A $(\mathrm{A}) \Rightarrow \mathrm{M}$ | $\begin{array}{\|l} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{array}$ | 5A dd <br> 7A hh 11 <br> 6A xb <br> 6A xb ff <br> 6A xb ee ff <br> 6 A xb <br> 6A xb ee ff | Pw Pwo Pw Pwo Pwo PwP PIfw PIPw |  |
| STAB opr8a STAB opr16a STAB oprx0_xysppc STAB oprx9, xysppc STAB oprx16,xysppc STAB [D,xysppc] STAB [oprx16,xysppc] | Store accumulator B $(\mathrm{B}) \Rightarrow \mathrm{M}$ | $\begin{array}{\|l} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{array}$ | 5B dd <br> 7B hh 11 <br> 6B xb <br> 6B xb ff <br> 6B xb ee ff <br> 6B xb <br> 6B xb eeff | $\begin{aligned} & \hline \text { Pw } \\ & \text { Pwo } \\ & \text { Pw } \\ & \text { Pwo } \\ & \text { PwP } \\ & \text { PIfw } \\ & \text { PIPw } \end{aligned}$ | ------- $\Delta \Delta \Delta^{\text {a }} 0$ |
| STD opr8a STD opr16a STD oprx0_ xysppc STD oprx9,xysppc STD oprx16,xysppc STD [D, xysppc] STD [oprx16,xysppc] | $\begin{aligned} & \text { Store D } \\ & (A: B) \Rightarrow M: M+1 \end{aligned}$ | DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 5 C dd <br> 7C hh 11 <br> 6 Cxb <br> 6 C xb ff <br> 6 C xb ee ff <br> 6 Cxb <br> 6C xb ee ff | PW <br> PWO <br> PW <br> PWO <br> PWP <br> PIfW <br> PIPW |  |
| STOP | Stop processing; (SP)-2 $\Rightarrow$ SP RTN $_{\mathrm{H}}:$ RTN $_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ $(S P)-2 \Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ $(S P)-2 \Rightarrow S P ;\left(X_{H}: X_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ (SP) $-2 \Rightarrow S P ;(B: A) \Rightarrow M_{S P}: M_{S P+1}$ $(S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{S P}$ <br> Stop all clocks | INH | 18 3E | $\begin{aligned} & \text { OoSSSSsf (enter } \\ & \text { stop mode) } \\ & \text { fVfPPP (exit stop } \\ & \text { mode) } \\ & \text { ff (continue stop } \\ & \text { mode) } \\ & \text { Oo (if stop mode } \\ & \text { disabled by }=1 \text { ) } \\ & \hline \end{aligned}$ | ------------- |
| STS opr8a STS opr16a STS oprx0_xysppc STS oprx9,xysppc STS oprx16,xysppc STS [D,xysppc] STS [oprx16,xysppc] | $\begin{aligned} & \text { Store SP } \\ & \left(\mathrm{SP}_{\mathrm{H}}: S P_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1 \end{aligned}$ | $\begin{array}{\|l} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{array}$ | 5F dd <br> 7 F hh 11 <br> 6 F xb <br> 6 Fxb ff <br> $6 \mathrm{~F} x \mathrm{~b}$ ee ff <br> 6 F xb <br> 6 Fxb eeff | PW <br> PWo <br> PW <br> PWo <br> PWP <br> PWI <br> PIf <br> PIPW | ------\| $\Delta \Delta^{\text {a }} 0$ |
| STX opr8a STX opr16a STX oprxO_xysppc STX oprx9,xysppc STX oprx16,xysppc STX [D,xysppc] STX [oprx16,xysppc] | $\begin{aligned} & \text { Store } X \\ & \left(X_{H}: X_{L}\right) \Rightarrow M: M+1 \end{aligned}$ | $\begin{array}{\|l} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{array}$ | 5 E dd <br> 7E hh 11 <br> 6 Exb <br> 6 Exb ff <br> 6E xb ee ff <br> 6 Exb <br> 6E xb eeff | PW PWo PW PWO PWP PIfW PIPW |  |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| STY opr8a STY opr16a STY oprx0_xysppc STY oprx9,xysppc STY oprx16,xysppc STY [D,xysppc] STY [oprx16,xysppc] | $\begin{aligned} & \text { Store } \mathrm{Y} \\ & \left(\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1 \end{aligned}$ | DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 5D dd <br> 7D hh 11 <br> 6D xb <br> 6D xb ff <br> 6D xb ee ff <br> 6D xb <br> 6D xb ee ff | PW PWO PW PWO PWP PWIfW PIPW PIPW |  |
| SUBA \#opr8i <br> SUBA opr8a <br> SUBA opr16a <br> SUBA oprx0_xysppc <br> SUBA oprx9,xysppc <br> SUBA oprx16,xysppc <br> SUBA [D, xysppc] <br> SUBA [oprx16,xysppc] | Subtract from A <br> (A)-(M) $\Rightarrow A$ <br> or (A)-imm $\Rightarrow A$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> $\left[\begin{array}{l}\text { [D,IDX] } \\ \text { [IDX2] }\end{array}\right]$ | 80 ii <br> 90 dd <br> B0 hh 11 <br> A0 xb <br> A0 xb ff <br> A0 $x b$ ee ff <br> A0 xb <br> A0 xbeeff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf |  |
| SUBB \#opr8i <br> SUBB opr8a <br> SUBB opr16a <br> SUBB oprx0_xysppc <br> SUBB oprx9,xysppc <br> SUBB oprx16,xysppc <br> SUBB [D, xysppc] <br> SUBB [oprx16,xysppc] | $\begin{aligned} & \text { Subtract from B } \\ & \text { (B)-(M) } \Rightarrow B \\ & \text { or }(B) \text {-imm } \Rightarrow B \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C0 ii <br> D0 dd <br> F0 hh 11 <br> E0 xb <br> E0 xb ff <br> E0 xbeeff <br> E0 xb <br> E0 xb ee ff | P rPf rPo rPf rPo frPP fIfrPf fIPrPf | -----\|-| $\Delta \mid \Delta \Delta \Delta$, |
| SUBD \#opr16i <br> SUBD opr8a <br> SUBD opr16a <br> SUBD oprx0_xysppc <br> SUBD oprx9,xysppc <br> SUBD oprx16,xysppc <br> SUBD [D, xysppc] <br> SUBD [oprx16,xysppc] | Subtract from D $(A: B)-(M: M+1) \Rightarrow A: B$ or $(A: B)-i m m \Rightarrow A: B$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | 83 jjkk 93 dd B3 hh ll A3 xb A3 xb ff A3 xb ee ff A3 xb A3 xb ee ff | $\begin{array}{\|l\|} \hline \text { PO } \\ \text { RPf } \\ \text { RPO } \\ \text { RPf } \\ \text { RPO } \\ \text { fRPP } \\ \text { fIfRPf } \\ \text { fIPRPf } \end{array}$ | - ----\|-| $\Delta \mid \Delta \Delta \Delta \Delta$ |
| SWI | Software interrupt; (SP)-2 $\Rightarrow$ SP <br> RTN $_{\mathrm{H}}:$ RTN $_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ <br> (SP) $-2 \Rightarrow S P ;\left(\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ <br> (SP) $-2 \Rightarrow S P ;\left(X_{H}: X_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ <br> (SP) $-2 \Rightarrow S P ;(B: A) \Rightarrow M_{S P}: M_{S P}+1$ <br> (SP) $-1 \Rightarrow S P ;(C C R) \Rightarrow M_{S P} ; 1 \Rightarrow 1$ <br> (SWI vector) $\Rightarrow P C$ | INH | 3F | VSPSSPSsP* | -----\|1-|-|-| |
| *The CPU also uses vSPSSPSsP for hardware interrupts and unimplemented opcode traps. |  |  |  |  |  |
| TAB | Transfer A to $\mathrm{B} ;(\mathrm{A}) \Rightarrow \mathrm{B}$ | INH | 180 E | Oo | ------ $\Delta\|\Delta\| 0 \mid-$ |
| TAP | Transfer $A$ to $C C R ;(A) \Rightarrow C C R$ Assembled as TFR A, CCR | INH | B7 02 | P | $\Delta \\| \Delta \Delta \Delta \Delta \Delta \Delta \Delta$, |
| TBA | Transfer B to A ; B ) $\Rightarrow \mathrm{A}$ | INH | 180 F | 00 |  |
| TBEQ abdxysp,rel9 | Test and branch if equal to 0 If (counter) $=0$, then ( PC ) $+2+$ rel $\Rightarrow \mathrm{PC}$ | $\begin{aligned} & \hline \begin{array}{l} \text { REL } \\ \text { (9-bit) } \end{array} \end{aligned}$ | 04 lb rr | PPP (branch) PPO (no branch) | - ------------ |
| TBL oprx0_xysppc | Table lookup and interpolate, 8-bit $(\mathrm{M})+[(\mathrm{B}) \times((\mathrm{M}+1)-(\mathrm{M}))] \Rightarrow \mathrm{A}$ | IDX | 18 3D xb | ORfffP | - ---\|-|-| $\Delta\|\Delta\|-\mid$ - |
| TBNE abdxysp,rel9 | Test and branch if not equal to 0 If (counter) $=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | $\begin{aligned} & \hline \begin{array}{l} \text { REL } \\ \text { (9-bit) } \end{array} \end{aligned}$ | 04 lb rr | PPP (branch) PPO (no branch) | - ----\|---|---- |
| TFR $a b c d x y s p, a b c d x y s p$ | Transfer from register to register (r1) $\Rightarrow \mathrm{r} 2 \mathrm{r} 1$ and r 2 same size $\$ 00:(r 1) \Rightarrow r 2 r 1=8$-bit; $r 2=16$-bit $(r 1$ L $) \Rightarrow r 2 r 1=16$-bit; $r 2=8$-bit | INH | B7 eb | P |  |
| TPASame as TFR CCR ,A | Transfer CCR to A; (CCR) $\Rightarrow$ A | INH | B7 20 | P | -----\|---|--| |

: User Guide - S12CPU15Vters.2cale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TRAP trapnum |  | INH | $\begin{aligned} & 18 \mathrm{tn} \\ & \mathrm{tn}=\$ 30-\$ 39 \\ & \text { or } \\ & \mathrm{tn}=\$ 40-\$ \mathrm{FF} \end{aligned}$ | OVSPSSPSsP | - ----1\|-|---- |
| TST opr16a <br> TST oprx0 xysppc TST oprx9,xysppc TST oprx16,xysppc TST [D,xysppc] TST [oprx16,xysppc] TSTA TSTB | $\begin{aligned} & \text { Test M; (M)-0 } \\ & \\ & \text { Test A; (A)-0 } \\ & \text { Test B; (B) })=0 \end{aligned}$ | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | F7 hh ll E7 xb E7 xb ff E7 xb ee ff E7xb E7xb ee ff 97 D7 | rPO rPf rPO frPP fIfrPf fIPrPf 0 0 | ------- $\Delta \Delta \Delta^{0} 0$ |
| TSXSame as TFR SP, X | Transfer SP to X; (SP) $\Rightarrow \mathrm{X}$ | INH | B7 75 | P | ------------ |
| TSYSame as TFR SP, Y | Transfer SP to Y; (SP) $\Rightarrow \mathrm{Y}$ | INH | B7 76 | P | ------------ |
| TXSSame as TFRX,SP | Transfer X to $\mathrm{SP} ;(\mathrm{X}) \Rightarrow$ SP | INH | B7 57 | P | - ----------- |
| TYSSame as TFR Y,SP | Transfer Y to SP; $(\mathrm{Y}) \Rightarrow$ SP | INH | B7 67 | P | ----------- |
| WAI | Wait for interrupt; (SP)-2 $\Rightarrow$ SP RTN $_{\mathrm{H}}:$ RTN $_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ (SP)-2 $\Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ (SP)-2 $\Rightarrow \mathrm{SP} ;\left(\mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ (SP) $-2 \Rightarrow S P ;(B: A) \Rightarrow M_{S P}: M_{S P+1}$ $(S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{S P}$ | INH | 3E | OSSSSSf (before interrupt) fVfPPP (after interrupt) | $-\|-\|-\|-\|-\|-\|-\|-$ <br> or <br> $-\|-\|-\|1\|-\|-\|-\|-\|$ <br> $\frac{\text { or }}{}$ <br> $-\|1\|-\|1\|-\|-\|-\|-$ |
| WAV | Calculate weighted average; sum of products (SOP) and sum of weights (SOW)* $\begin{aligned} & \sum_{i=1}^{B} S_{i} F_{i} \Rightarrow Y: D \\ & \sum_{i=1}^{B} F_{i} \Rightarrow X \end{aligned}$ | Special | 183 C | $\begin{aligned} & \text { Of (frr^^fff) O** } \\ & \text { SSS+UUUrr^*** } \end{aligned}$ | ---\|?-|? ${ }^{\text {a }}$ ? ${ }^{\text {a }}$ |

*Initialize $\mathrm{B}, \mathrm{X}$, and $\mathrm{Y}: \mathrm{B}=$ number of elements; X points at first element in $\mathrm{S}_{\mathrm{i}}$ list; Y points at first element in $\mathrm{F}_{\mathrm{i}}$ list. $\mathrm{All}_{\mathrm{i}}$ and $\mathrm{F}_{\mathrm{i}}$ elements are 8-bit values.
${ }^{* *}$ The $f r r^{\wedge} \mathrm{ffff}$ sequence is the loop for one iteration of SOP and SOW accumulation. The ^ denotes a check for pending interrupt requests.
${ }^{* * *}$ Additional cycles caused by an interrupt: SSS is the exit sequence and UUUrr^ is the re-entry sequence. Intermediate values use six stack bytes.

| wavr* | Resume executing interrupted WAV | Special | 3 C | UUUrr^ffff(frr^ ffff) ${ }^{* * *}$ SSS+UUUrr^*** |  |
| :---: | :---: | :---: | :---: | :---: | :---: |

[^0]| XGDXSame as EXGD, X | Exchange D with $\mathrm{X} ;(\mathrm{D}) \Leftrightarrow(\mathrm{X})$ | INH | B7 C5 | P | ------------ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| XGDYSame as EXGD, Y | Exchange D with $\mathrm{Y} ;(\mathrm{D}) \Leftrightarrow(\mathrm{Y})$ | INH | B7 C6 | P | - - - - - - - - - - - |

### 1.8.1 Register and Memory Notation

Table 1-3 Register and Memory Notation

| A or a | Accumulator A |
| :---: | :---: |
| An | Bit n of accumulator A |
| B or b | Accumulator B |
| Bn | Bit n of accumulator B |
| D or d | Accumulator D |
| Dn | Bit n of accumulator D |
| X or $x$ | Index register X |
| $\mathrm{X}_{\mathrm{H}}$ | High byte of index register X |
| X | Low byte of index register X |
| Xn | Bit n of index register X |
| Y or $y$ | Index register Y |
| $\mathrm{Y}_{\mathrm{H}}$ | High byte of index register Y |
| $Y_{L}$ | Low byte of index register Y |
| Yn | Bit n of index register Y |
| SP or sp | Stack pointer |
| SPn | Bit n of stack pointer |
| PC or $p c$ | Program counter |
| $\mathrm{PC}_{\mathrm{H}}$ | High byte of program counter |
| $\mathrm{PC}_{\mathrm{L}}$ | Low byte of program counter |
| CCR or $c$ | Condition code register |
| M | Address of 8-bit memory location |
| Mn | Bit n of byte at memory location M |
| Rn | Bit n of the result of an arithmetic or logical operation |
| In | Bit n of the intermediate result of an arithmetic or logical operation |
| $\mathrm{RTN}_{\mathrm{H}}$ | High byte of return address |
| $\mathrm{RTN}_{\mathrm{L}}$ | Low byte of return address |
| () | Contents of |

### 1.8.2 Source Form Notation

The Source Form column of the summary in Table 1-2 gives essential information about assembler source forms. For complete information about writing source files for a particular assembler, refer to the documentation provided by the assembler vendor.

Everything in the Source Form column, except expressions in italic characters, is literal information which must appear in the assembly source file exactly as shown. The initial 3- to 5-letter mnemonic is always a literal expression. All commas, pound signs (\#), parentheses, square brackets ( [ or ] ), plus signs $(+)$, minus signs $(-)$, and the register designation ( $\mathrm{A}, \mathrm{B}, \mathrm{D})$, are literal characters.

The groups of italic characters shown in Table 1-4 represent variable information to be supplied by the programmer. These groups can include any alphanumeric character or the underscore character, but cannot
include a space or comma. For example, the groups xysppc and oprx0_xysppc are both valid, but the two groups oprx0 xysppc are not valid because there is a space between them.

Table 1-4 Source Form Notation

| $a b c$ | Register designator for A, B, or CCR |
| :---: | :---: |
| abcdxysp | Register designator for A, B, CCR, D, X, Y, or SP |
| abd | Register designator for $\mathrm{A}, \mathrm{B}$, or D |
| abdxysp | Register designator for A, B, D, X, Y, or SP |
| dxysp | Register designator for D, X, Y, or SP |
| msk8 | 8-bit mask value Some assemblers require the \# symbol before the mask value. |
| opr8i | 8-bit immediate value |
| opr16i | 16-bit immediate value |
| opr8a | 8-bit address value used with direct address mode |
| opr16a | 16-bit address value |
| oprx0_xysp | ```Indexed addressing postbyte code: oprx3,-xysp - Predecrement X , Y, or SP by 1-8 oprx3, \(+x y s p\) - Preincrement \(\mathrm{X}, \mathrm{Y}\), or SP by 1-8 oprx3,xysp- - Postdecrement X, Y, or SP by 1-8 oprx3,xysp+ - Postincrement X, Y, or SP by 1-8 oprx5,xysppc - 5-bit constant offset from X, Y, SP, or PC abd,xysppc - Accumulator A, B, or D offset from X, Y, SP, or PC``` |
| oprx3 | Any positive integer from 1 to 8 for pre/post increment/decrement |
| oprx5 | Any integer from -16 to +15 |
| oprx9 | Any integer from -256 to +255 |
| oprx16 | Any integer from $-32,768$ to $+65,535$ |
| page | 8-bit value for PPAGE register <br> Some assemblers require the \# symbol before this value. |
| rel8 | Label of branch destination within -256 to +255 locations |
| rel9 | Label of branch destination within -512 to +511 locations |
| rel16 | Any label within the 64-Kbyte memory space |
| trapnum | Any 8-bit integer from \$30 to \$39 or from \$40 to \$FF |
| xysp | Register designator for X or Y or SP |
| xysppc | Register designator for X or Y or SP or PC |

### 1.8.3 Operation Notation

Table 1-5 Operation Notation

| + | Add |
| :---: | :--- |
| - | Subtract |
| $\bullet$ | AND |
| $\boldsymbol{1}$ | OR |
| $\oplus$ | Exclusive OR |
| $\times$ | Multiply |
| $\div$ | Divide |
| $:$ | Concatenate |
| $\Rightarrow$ | Transfer |
| $\Leftrightarrow$ | Exchange |

### 1.8.4 Address Mode Notation

Table 1-6 Address Mode Notation

| INH | Inherent; no operands in instruction stream |
| ---: | :--- |
| IMM | Immediate; operand immediate value in instruction stream |
| DIR | Direct; operand is lower byte of address from \$0000 to \$00FF |
| EXT | Operand is a 16-bit address |
| REL | Two's complement relative offset; for branch instructions |
| IDX | Indexed (no extension bytes); includes: <br> 5-bit constant offset from X, Y, SP or PC <br> Pre/post increment/decrement by 1-8 <br> Accumulator A, B, or D offset |
| IDX1 | 9-bit signed offset from X, Y, SP, or PC; 1 extension byte |
| IDX2 | 16-bit signed offset from X, Y, SP, or PC; 2 extension bytes |
| [IDX2] | Indexed-indirect; 16-bit offset from X, Y, SP, or PC |
| [D, IDX] | Indexed-indirect; accumulator D offset from X, Y, SP, or PC |

### 1.8.5 Machine Code Notation

In the Machine Code (Hex) column of the summary in Table 1-2, digits 0-9 and upper case letters A-F represent hexadecimal values. Pairs of lower-case letters represent 8-bit values as shown in Table 1-7.

Table 1-7 Machine Code Notation

| dd | 8-bit direct address from \$0000 to \$00FF; high byte is \$00 |
| :---: | :--- |
| ee | High byte of a 16-bit constant offset for indexed addressing |
| eb | Exchange/transfer postbyte |
| ff | Low eight bits of a 9-bit signed constant offset in indexed addressing, or low byte of a 16-bit <br> constant offset in indexed addressing |
| hh | High byte of a 16-bit extended address |
| ii | 8-bit immediate data value |
| jj | High byte of a 16-bit immediate data value |
| kk | Low byte of a 16-bit immediate data value |
| lb | Loop primitive (DBNE) postbyte |
| ll | Low byte of a 16-bit extended address |
| mm | 8-bit immediate mask value for bit manipulation instructions; bits that are set indicate bits to be <br> affected |
| pg | Program page or bank number used in CALL instruction |
| qq | High byte of a 16-bit relative offset for long branches |
| tn | Trap number from $\$ 30$ to $\$ 39$ or from $\$ 40$ to $\$ F F$ |
| rr | Signed relative offset $\$ 80$ (-128) to $\$ 7 F(+127)$ relative to the byte following the relative offset byte, <br> or low byte of a 16-bit relative offset for long branches |
| xb | Indexed addressing postbyte |

### 1.8.6 Access Detail Notation

A single-letter code in the Access Detail column of Table 1-2 represents a single CPU access cycle. An upper-case letter indicates a 16-bit access.

## Table 1-8 Access Detail Notation

| f | Free cycle. During an f cycle, the CPU does not use the bus. An f cycle is always one cycle of the system bus clock. An $f$ cycle can be used by a queue controller or the background debug system to perform a single-cycle access without disturbing the CPU. |
| :---: | :---: |
|  | Read PPAGE register. A g cycle is used only in CALL instructions and is not visible on the external bus. Since PPAGE is an internal 8 -bit register, a g cycle is never stretched. |
|  | Read indirect pointer. Indexed-indirect instructions use the 16 -bit indirect pointer from memory to address the instruction operand. An I cycle is a 16 -bit read that can be aligned or misaligned. An I cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An I cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
|  | Read indirect PPAGE value. An i cycle is used only in indexed-indirect CALL instructions. The 8 -bit PPAGE value for the CALL destination is fetched from an indirect memory location. An i cycle is stretched only when controlled by a chip-select circuit that is programmed for slow memory. |
|  | Write PPAGE register. An n cycle is used only in CALL and RTC instructions to write the destination value of the PPAGE register and is not visible on the external bus. Since the PPAGE register is an internal 8-bit register, an n cycle is never stretched. |
| 0 | Optional cycle. An o cycle adjusts instruction alignment in the instruction queue. An o cycle can be a free cycle (f) or a program word access cycle (P). When the first byte of an instruction with an odd number of bytes is misaligned, the o cycle becomes a P cycle to maintain queue order. If the first byte is aligned, the o cycle is an f cycle. <br> The $\$ 18$ prebyte for a page-two opcode is treated as a special one-byte instruction. If the prebyte is misaligned, the o cycle at the beginning of the instruction becomes a P cycle to maintain queue order. If the prebyte is aligned, the o cycle is an f cycle. If the instruction has an odd number of bytes, it has a second o cycle at the end. If the first o cycle is a P cycle (prebyte misaligned), the second o cycle is an f cycle. If the first o cycle is an f cycle (prebyte aligned), the second o cycle is a P cycle. <br> An o cycle that becomes a P cycle can be extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An o cycle that becomes an f cycle is never stretched. |
|  | Program word access. Program information is fetched as aligned 16 -bit words. A P cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the program is stored externally. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. |
|  | 8-bit data read. An r cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
|  | 16 -bit data read. An R cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An R cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
|  | Stack 8-bit data. An s cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. | User Guide - S12CPU15Uteestcale Semiconductor, Inc.

Table 1-8 Access Detail Notation (Continued)

| S | Stack 16 -bit data. An s cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the SP is pointing to external memory. There can be additional stretching if the address space is assigned to a chip-select circuit programmed for slow memory. An scycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. The internal RAM is designed to allow single cycle misaligned word access. |
| :---: | :---: |
| w | 8 -bit data write. A w cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| W | 16 -bit data write. A w cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A w cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
|  | Unstack 8-bit data. A w cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| U | Unstack 16 -bit data. A U cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the SP is pointing to external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A u cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. The internal RAM is designed to allow single-cycle misaligned word access. |
| v | 16 -bit vector fetch. Vectors are always aligned 16 -bit words. $\mathrm{A} v$ cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. |
|  | 8-bit conditional read. A t cycle is either a data read cycle or a free cycle, depending on the data and flow of the REVW instruction. A t cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| T | 16 -bit conditional read. A t cycle is either a data read cycle or a free cycle, depending on the data and flow of the REV or REVW instruction. A T cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A т cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
| x | 8 -bit conditional write. An $\times$ cycle is either a data write cycle or a free cycle, depending on the data and flow of the REV or REVW instruction. An x cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| Special Notation for Branch Taken/Not Taken |  |
| PPP/P | A short branch requires three cycles if taken, one cycle if not taken. Since the instruction consists of a single word containing both an opcode and an 8-bit offset, the not-taken case is simple - the queue advances, another program word fetch is made, and execution continues with the next instruction. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address. |
| OPPP/OPO | A long branch requires four cycles if taken, three cycles if not taken. An o cycle is required because all long branches are page two opcodes and thus include the $\$ 18$ prebyte. The prebyte is treated as a one-byte instruction. If the prebyte is misaligned, the o cycle is a P cycle; if the prebyte is aligned, the o cycle is an f cycle. As a result, both the taken and not-taken cases use one o cycle for the prebyte. In the not-taken case, the queue must advance so that execution can continue with the next instruction, and another o cycle is required to maintain the queue. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address. |

### 1.8.7 Condition Code State Notation

Table 1-9 Condition Code State Notation

| - | Not changed by operation |
| :---: | :--- |
| 0 | Cleared by operation |
| 1 | Set by operation |
| $\Delta$ | Set or cleared by operation |
| $\Downarrow$ | May be cleared or remain set, but not set by operation |
| $\Uparrow$ | May be set or remain cleared, but not cleared by operation |
| $?$ | May be changed by operation but final state not defined |
| $!$ | Used for a special purpose |

: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 2 Nomenclature

This section describes the conventions and notation used to describe the Core operation.

### 2.1 References

This document uses the Sematech Official Dictionary and the JEDEC/EIA Reference Guide to Letter Symbols for Semiconductor Devices as references for terminology and symbology.

### 2.2 Units and Measures

SIU units and abbreviations are used throughout this guide.

### 2.3 Symbology

The symbols and operators used throughout this guide are shown in Table 2-1.
Table 2-1 Symbols and Operators

| Symbol | Function |
| :---: | :---: |
| + | Addition |
| - | Subtraction (two's complement) or negation |
| * | Multiplication |
| 1 | Division |
| > | Greater |
| < | Less |
| = | Equal |
| $\geq$ | Equal or greater |
| $\leq$ | Equal or less |
|  | Not equal |
| - | AND |
| + | Inclusive OR (OR) |
| $\oplus$ | Exclusive OR (EOR) |
| NOT | Complementation |
| : | Concatenation |
| $\Rightarrow$ | Transferred |
| $\Leftrightarrow$ | Exchanged |
|  | Tolerance |
| 0b0011 | Binary value |
| 0x0F | Hexadecimal value |

### 2.4 Terminology

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

## : User Guide - S12CPU15ƯGê.şcale Semiconductor, Inc.

Logic level zero is a voltage that corresponds to Boolean false (0) state.
To set a bit or bits means to establish logic level one on them.
To clear a bit or bits means to establish logic level zero on them.
A signal is an electronic construct whose state or changes in state convey information.
A pin is an external physical connection. The same pin can be used to connect a number of signals.
Asserted means that a discrete signal is in active logic state.

- Active low signals change from logic level one to logic level zero.
- Active high signals change from logic level zero to logic level one.

Negated means that an asserted discrete signal changes logic state.

- Active low signals change from logic level zero to logic level one.
- Active high signals change from logic level one to logic level zero.

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

Memory and registers use big-endian ordering. The most significant byte (byte 0 ) of word 0 is located at address 0 . Bits within a word are numbered downward from the MSB, bit 15.

Signal, bit field, and control bit mnemonics follow a general numbering scheme:

- A range of mnemonics is referred to by mnemonic and numbers that define the range, from highest to lowest. For example, $p_{-} a d d r[4: 0]$ are lines four to zero of an address bus.
- A single mnemonic stands alone or includes a single numeric designator when appropriate. For example, $m_{-} r s t$ is a unique mnemonic, while $p \_a d d r 15$ represents line 15 of an address bus.


## Section 3 Core Registers

This section provides detailed descriptions of the Core programming model, registers and accumulators. In addition, a general description of the complete Core register map which includes all Core sub-blocks is included.

### 3.1 Programming Model

The Core CPU12 programming model, shown in Figure 3-1, is the same as that of the 68 HC 12 and 68 HC 11 . The register set and data types used in the model are covered in the subsections that follow.


Figure 3-1 Programming Model

### 3.1.1 Accumulators

General-purpose 8-bit accumulators A and B hold operands and results of operations. Some instructions use the combined 8 -bit accumulators, $\mathrm{A}: \mathrm{B}$, as a 16 -bit double accumulator, D , with the most significant byte in A. User Guide - S12CPU15UGefscale Semiconductor, Inc.


Figure 3-2 Accumulator A


Figure 3-3 Accumulator B

Most operations can use accumulator A or B interchangeably. However, there are a few exceptions. Add, subtract, and compare instructions involving both A and B (ABA, SBA, and CBA) only operate in one direction, so it is important to verify that the correct operand is in the correct accumulator. The decimal adjust accumulator A (DAA) instruction is used after binary-coded decimal (BCD) arithmetic operations. There is no equivalent instruction to adjust accumulator B.

### 3.1.2 Index Registers (X and Y)

16-bit index registers X and Y are used for indexed addressing. In indexed addressing, the contents of an index register are added to a 5-bit, 9-bit, or 16-bit constant or to the contents of an accumulator to form the effective address of the instruction operand. Having two index registers is especially useful for moves and in cases where operands from two separate tables are used in a calculation.


Figure 3-4 Index Register X


Figure 3-5 Index Register Y


Figure 3-5 Index Register Y

### 3.1.3 Stack Pointer (SP)

The stack stores system context during subroutine calls and interrupts, and can also be used for temporary data storage. It can be located anywhere in the standard 64 K byte address space and can grow to any size up to the total amount of memory available in the system.
SP holds the 16-bit address of the last stack location used. Normally, SP is initialized by one of the first instructions in an application program. The stack grows downward from the address pointed to by SP. Each time a byte is pushed onto the stack, the stack pointer is automatically decremented, and each time a byte is pulled from the stack, the stack pointer is automatically incremented.

When a subroutine is called, the address of the instruction following the calling instruction is automatically calculated and pushed onto the stack. Normally, a return from subroutine (RTS) is executed at the end of a subroutine. The return instruction loads the program counter with the previously stacked return address and execution continues at that address.


Figure 3-6 Stack Pointer (SP)

When an interrupt occurs, the CPU:

- Completes execution of the current instruction
- Calculates the address of the next instruction and pushes it onto the stack
- Pushes the contents of all the CPU registers onto the stack
- Loads the program counter with the address pointed to by the interrupt vector, and begins execution at that address

The stacked CPU registers are referred to as an interrupt stack frame. The Core stack frame is the same as that of the CPU.

### 3.1.4 Program Counter (PC)

PC is a 16-bit register that holds the address of the next instruction to be executed. The address in PC is automatically incremented each time an instruction is executed.


Figure 3-7 Program Counter (PC)

### 3.1.5 Condition Code Register (CCR)

CCR has five status bits, two interrupt mask bits, and a STOP instruction mask bit. It is named for the five conditions indicated by the status bits.

The status bits reflect the results of CPU operations. The five status bits are half-carry $(\mathrm{H})$, negative $(\mathrm{N})$, zero (Z), overflow (V), and carry/borrow (C). The half-carry bit is used only for BCD arithmetic operations. The N, Z, V, and C status bits allow for branching based on the results of a CPU operation.

Most instructions automatically update condition codes, so it is rarely necessary to execute extra instructions to load and test a variable. The condition codes affected by each instruction are shown in Appendix A of this guide.

The following paragraphs describe common uses of the condition codes. There are other, more specialized uses. For instance, the C status bit is used to enable weighted fuzzy logic rule evaluation. Specialized usages are described in the relevant portions of this guide and in Appendix A.


Figure 3-8 Condition Code Register (CCR)

S - STOP Mask Bit
Clearing the $S$ bit enables the STOP instruction. Execution of a STOP instruction causes the on-chip oscillator to stop. This may be undesirable in some applications. When the S bit is set, the CPU treats the STOP instruction as a no-operation (NOP) instruction and continues on to the next instruction.
Reset sets the S bit.
$1=$ STOP instruction disabled
$0=$ STOP instruction enabled

X - $\overline{\text { XIRQ }}$ Mask Bit
Clearing the X bit enables interrupt requests on the $\overline{\text { XIRQ }}$ pin. The $\overline{\text { XIRQ }}$ input is an updated version of the nonmaskable interrupt ( $\overline{\mathrm{NMI}}$ ) input found on earlier generations of Motorola microcontroller units (MCUs). Nonmaskable interrupts are typically used to deal with major system failures such as loss of power. However, enabling nonmaskable interrupts before a system is fully powered and initialized can lead to spurious interrupts. The X bit provides a mechanism for masking nonmaskable interrupts until the system is stable.
Reset sets the X bit. As long as the X bit remains set, interrupt service requests made via the $\overline{\mathrm{XIRQ}} \mathrm{pin}$ are not recognized. Software must clear the X bit to enable interrupt service requests from the $\overline{\mathrm{XIRQ}}$ pin. Once software clears the X bit, enabling $\overline{\mathrm{XIRQ}}$ interrupt requests, only a reset can set it again. The $X$ bit does not affect I bit maskable interrupt requests.
When the X bit is clear and an $\overline{\mathrm{XIRQ}}$ interrupt request occurs, the CPU stacks the cleared X bit. It then automatically sets the X and I bits in the CCR to disable $\overline{\mathrm{XIRQ}}$ and maskable interrupt requests during the $\overline{\text { XIRQ }}$ interrupt service routine.
An RTI instruction at the end of the interrupt service routine restores the cleared X bit to the CCR, re-enabling $\overline{\text { XIRQ }}$ interrupt requests.
$1=\overline{\text { XIRQ }}$ interrupt requests disabled
$0=\overline{\mathrm{XIRQ}}$ interrupt requests enabled

## H - Half-Carry Bit

The H bit indicates a carry from bit 3 of the result during an addition operation. The DAA instruction uses the value of the H bit to adjust the result in accumulator A to BCD format. ABA, ADD, and ADC are the only instructions that update the H bit.
$1=$ Carry from bit 3 after ABA, ADD, or ADC instruction
$0=$ No carry from bit 3 after ABA, ADD, or ADC instruction
I — Interrupt Mask Bit
Clearing the I bit enables maskable interrupt sources. Reset sets the I bit. To enable maskable interrupt requests, software must clear the I bit. Maskable interrupt requests that occur while the I bit is set remain pending until the I bit is cleared.
When the I bit is clear and a maskable interrupt request occurs, the CPU stacks the cleared I bit. It then automatically sets the I bit in the CCR to prevent other maskable interrupt requests during the interrupt service routine.
An RTI instruction at the end of the interrupt service routine restores the cleared I bit to the CCR, reenabling maskable interrupt requests. The I bit can be cleared within the service routine, but implementing a nested interrupt scheme requires great care, and seldom improves system performance.
$1=$ Maskable interrupt requests disabled
$0=$ Maskable interrupt requests enabled

## N - Negative Bit

The N bit is set when the MSB of the result is set. N is most commonly used in two's complement arithmetic, where the MSB of a negative number is one and the MSB of a positive number is zero, but it has other uses. For instance, if the MSB of a register or memory location is used as a status bit, the user can test the bit by loading an accumulator.
$1=$ MSB of result set
$0=$ MSB of result clear
Z—Zero Bit
The Z bit is set when all the bits of the result are zeros. Compare instructions perform an internal implied subtraction, and the condition codes, including Z , reflect the results of that subtraction. The INX, DEX, INY, and DEY instructions affect the Z bit and no other condition bits. These operations can only determine $=$ and $\neq$.
$1=$ Result all zeros
$0=$ Result not all zeros

## V — Overflow Bit

The V bit is set when a two's complement overflow occurs as a result of an operation.
1 = Overflow
$0=$ No overflow

## C-Carry Bit

The C bit is set when a carry occurs during addition or a borrow occurs during subtraction. The C bit also acts as an error flag for multiply and divide operations. Shift and rotate instructions operate through the C bit to facilitate multiple-word shifts.
$1=$ Carry or borrow
$0=$ No carry or borrow

### 3.2 Core Register Map

The Core registers are those that are part of the sub-blocks that support the CPU to makeup the entire Core block. In addition to the registers contributed by the Core sub-blocks, sections of the Core space are reserved for registers contributed by the system peripherals and memory sub-blocks. These registers are configured at integration of the Core into the SoC design. The Core register map summary is shown in Figure 3-9 below.

The Core registers, with the exception of those associated with the BDM sub-block (addresses \$FF00 through \$FF07), can be mapped to any 2 K byte block within the first 32 K byte space of the standard 64 K byte address area by configuring the INITRG register.

For detailed descriptions of the Core register and bit functionality please refer to Core sub-block description sections of this guide. To assist in locating this more detailed information, Table 3-1 below lists the Core registers, the sub-block they are associated with and a brief description of function.

| Address | Name |  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$0000 | PORTA | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0001 | PORTB | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0002 | DDRA | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0003 | DDRB | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0004 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  | write |  |  |  |  |  |  |  |  |
| \$0005 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$0005 | Reserved | write |  |  |  |  |  |  |  |  |
| \$0006 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Reserved | write |  |  |  |  |  |  |  |  |
| \$0007 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Reserved | write |  |  |  |  |  |  |  |  |
| \$0008 | PORTE | read | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|  |  | write |  |  |  |  |  |  |  |  |
| \$0009 | DDRE | read | Bit 7 | 6 | 5 | 4 | 3 | 2 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$000A | PEAR | read | NOACCE | 0 | PIPOE | NECLK | LSTRE | RDWE | 0 | 0 |
| \$000B | MODE | read | MODC | MODB | MODA | 0 | IVIS | 0 | FMK | FME |
|  |  | write |  |  |  |  |  |  |  |  |
| \$000C | PUCR | read | PUPKE | 0 | 0 | PUPEE | 0 | 0 | PUPBE | PUPAE |
|  |  | write |  |  |  |  |  |  |  |  |
| \$000D | RDRIV | read | RDPK | 0 | 0 | RDPE | 0 | 0 | RDPB | RDPA |
|  |  | write |  |  |  | RDPE |  |  | RDPB | RDPA |
| \$000E | FBICTL | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ESTR |
|  |  | write |  |  |  |  |  |  |  |  |
| \$000F | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  | write |  |  |  |  |  |  |  |  |
| \$0010 | INITRM | read | RAM15 | RAM14 | RAM13 | RAM12 | RAM11 | 0 | 0 | RAMHAL |
|  |  | write |  |  |  |  |  |  |  |  |
| \$0011 | INITRG | read | 0 | REG14 | REG13 | REG12 | REG11 | 0 | 0 | 0 |
|  | INTRG | write |  | REG14 | REG13 | REG12 | REG1 |  |  |  |
| \$0012 | INITEE | read | EE15 | EE14 | EE13 | EE12 | EE11 | 0 | 0 | EEON |
|  |  | write |  |  |  |  |  |  |  |  |
| \$0013 | MISC | read | 0 | 0 | 0 | 0 | EXSTR1 | EXSTR0 | ROMHM | ROMON |
|  |  | write |  |  |  |  | EXSTR1 | EXSTRO | ROMHM | ROMON |
| \$0014 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Reserved | write |  |  |  |  |  |  |  |  |
| \$0015 | ITCR | read | 0 | 0 | 0 | WRTINT | ADR3 | ADR2 | ADR1 | ADR0 |
|  | ITR | write |  |  |  | Wrint | ADR3 | ADR2 | ADR1 |  |


| \$0016 | ITEST | read | INTE | INTC | INTA | INT8 | INT6 | INT4 | INT2 | INT0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$0017 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  | write |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \$ 0018 \\ & \text { to } \\ & \$ 001 \mathrm{~B} \end{aligned}$ | Reserved |  | Reserved for Peripheral Block Registers |  |  |  |  |  |  |  |
| \$001C | MEMSIZO | read write | reg_sw0 | 0 | eeo_sw1 | eep_sw0 | 0 | ram_sw2 | ram_sw1 | ram_sw0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$001D | MEMSIZ1 | read | rom_sw1 | rom_sw0 | 0 | 0 | 0 | 0 | pag_sw1 | pag_sw0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$001E | IRQCR |  | IRQE | IRQEN | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$001F | HPRIO | read write | PSEL7 | PSEL6 | PSEL5 | PSEL4 | PSEL3 | PSEL2 | PSEL1 | 0 |
| $\begin{array}{cc} \$ 0020 \\ \text { to } & \text { Reserved } \end{array}$ |  |  | Reserved for Peripheral Block Registers |  |  |  |  |  |  |  |
| \$0028 | BKPCTO | read write | BKEN | BKFULL | BKBDM | BKTAG | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$0029 | BKPCT1 | read <br> write | BKOMBH | BKOMBL | BK1MBH | BK1MBL | BKORWE | BKORW | BK1RWE | BK1RW |
| \$002A | BKPOX | read write | 0 | 0 | BK0V5 | BK0V4 | BKOV3 | BK0V2 | BK0V1 | BKOVO |
|  |  |  |  |  |  |  |  |  |  |  |
| \$002B | BKPOH | read write | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 |
| \$002C | BKPOL | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$002D | BKP1X | read <br> write | 0 | 0 | BK1V5 | BK1V4 | BK1V3 | BK1V2 | BK1V1 | BK1V0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$002E | BKP1H | read write | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 |
| \$002F | BKP1L | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0030 | PPAGE | read write | 0 | 0 | PIX5 | PIX4 | PIX3 | PIX2 | PIX1 | PIXO |
| \$0031 | Reserved | read write | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$0032 | PORTK | read write read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0033 | DDRK |  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| $\begin{aligned} & \$ 0034 \\ & \text { to } \end{aligned}$ | Reserved |  |  | Reserved for Peripheral Block Registers |  |  |  |  |  |  |
| $\begin{aligned} & \$ 0100 \\ & \text { to } \\ & \$ 010 \mathrm{~F} \end{aligned}$ | Reserved |  | Reserved for Flash EEPROM or ROM Registers |  |  |  |  |  |  |  |



Figure 3-9 Core Register Map Summary

Table 3-1 Core Register Map Reference
Address Name Sub-block Description

| $\$ 0000$ | PORTA | MEBI | Port A 8-bit Data Register |
| :--- | :--- | :--- | :--- |
| $\$ 0001$ | PORTB | MEBI | Port B 8-bit Data Register |
| $\$ 0002$ | DDRA | MEBI | Port A 8-bit Data Direction Register |
| $\$ 0003$ | DDRB | MEBI | Port B 8-bit Data Direction Register |
| $\$ 0008$ | PORTE | MEBI | Port E 8-bit Data Register |
| $\$ 0009$ | DDRE | MEBI | Port E 8-bit Data Direction Register |
| $\$ 000$ A | PEAR | MEBI | Port E Assignment Register - configures functionality of Port E as <br> general purpose I/O and/or alternate functions |
| $\$ 000 B$ | MODE | MEBI | Used to establish mode of operation of the Core and configure <br> other miscellaneous functions |
| $\$ 000 C$ | PUCR | MEBI | Pullup Control Register to configure state of pullups on Ports A, B, <br> E and K |

Table 3-1 Core Register Map Reference

| Address | Name | Sub-block | Description |
| :---: | :---: | :---: | :---: |
| \$000D | RDRIV | MEBI | Reduced Drive Register to configure drive strength of pins associated with Ports A, B, E and K |
| \$000E | EBICTL | MEBI | External Bus Interface Control Register to configure functionality of external E-clock signal |
| \$0010 | INITRM | MMC | Initialization of Internal RAM Position Register |
| \$0011 | INITRG | MMC | Initialization of Internal Registers Position Register |
| \$0012 | INITEE | MMC | Initialization of Internal EEPROM Registers Position Register |
| \$0013 | MISC | MMC | Miscellaneous Register to configure various system functions |
| \$0015 | ITCR | INT | Interrupt Test Control Register used in special modes of operation for testing interrupt logic |
| \$0016 | ITEST | INT | Interrupt Test Register used in special modes of operation testing interrupt logic |
| \$001C | MEMSIZO | MMC | Memory Size Register 0 to allow capability to read the state of the system memory configuration switches |
| \$001D | MEMSIZ1 | MMC | Memory Size Register 1 to allow capability to read the state of the system memory configuration switches |
| \$001E | IRQCR | MEBI | IRQ Control Register to configure IRQ pin functionality |
| \$001F | HPRIO | INT | Highest Priority I Interrupt Register (optional) |
| \$0028 | BKPCT0 | BKP | Breakpoint Control Register 0 to configure mode of operation of breakpoint functions |
| \$0029 | BKPCT1 | BKP | Breakpoint Control Register 1 to configure mode of operation of breakpoint functions |
| \$002A | BKPOX | BKP | First Address Memory Expansion Breakpoint Register to assign first address match value for expanded addresses |
| \$002B | BKPOH | BKP | First Address High Byte Breakpoint Register to assign high byte of first address within system memory space to be matched |
| \$002C | BKPOL | BKP | First Address Low Byte Breakpoint Register to assign low byte of first address within system memory space to be matched |
| \$002D | BKP1X | BKP | Second Address Memory Expansion Breakpoint Register to assign second address match value for expanded addresses |
| \$002E | BKP1H | BKP | Second Address High Byte Breakpoint Register to assign high byte of first address within system memory space to be matched |
| \$002F | BKP1L | BKP | Second Address Low Byte Breakpoint Register to assign low byte of first address within system memory space to be matched |
| \$0030 | PPAGE | MMC | Program Page Index Register to configure the active memory page viewed through the program page window from \$8000-\$BFFF |
| \$0032 | PORTK | MEBI | Port K 8-bit Data Register |
| \$0033 | DDRK | MEBI | Port K 8-bit Data Direction Register |
| \$FF01 | BDMSTS | BDM | BDM Status Register |
| \$FF06 | BDMCCR | BDM | BDM CCR Holding Register for interaction of BDM with CPU |
| \$FF07 | BDMINR | BDM | BDM Internal Register Position Register to configure BDM register mapping |

## Section 4 Instructions

This section describes the instruction set of the Core. This discussion includes descriptions of instructions grouped by type, the addressing modes used and the opcode map. Please refer to Appendix A of this guide for a detailed instruction-by-instruction description of each opcode.

### 4.1 Instruction Types

All memory and I/O are mapped in a common 64 K byte address space, allowing the same set of instructions to access memory, I/O, and control registers. Load, store, transfer, exchange, and move instructions facilitate movement of data to and from memory and peripherals.

There are instructions for signed and unsigned addition, division and multiplication with 8-bit, 16-bit, and some larger operands.

Special arithmetic and logic instructions aid stacking operations, indexing, BCD calculation, and condition code register manipulation. There are also dedicated instructions for multiply and accumulate operations, table interpolation, and specialized mathematical calculations for fuzzy logic operations.

### 4.2 Addressing Modes

A summary of the addressing modes used by the Core is given in Table 4-1 below. The operation of each of these modes is discussed in the subsections that follow.

Table 4-1 Addressing Mode Summary

| Addressing Mode | Source Form | Abbreviation | Description |
| :---: | :--- | :---: | :--- |
| Inherent | INST <br> (no externally supplied <br> operands) | INH | Operands (if any) are in CPU registers. |
| Immediate | INST \#opr8i <br> or <br> INST \#opr16i | IMM | Operand is included in instruction stream; 8-bit or <br> 16 -bit size implied by context. |
| Direct | INST opr8a | DIR | Operand is the lower 8-bits of an address in the range <br> \$0000-\$00FF. |
| Extended | INST opr16a | EXT | Operand is a 16-bit address. |
| Relative | INST rel8 <br> or <br> INST rel16 | REL | Effective address is the value in PC plus an 8-bit or <br> $16-b i t ~ r e l a t i v e ~ o f f s e t ~ v a l u e . ~$ |
| Indexed <br> (5-bit offset) | INST oprx5,xysp | IDX | Effective address is the value in X, Y, SP, or PC plus a <br> 5-bit signed constant offset. |
| Indexed <br> (predecrement) | INST oprx3,-xys | IDX | Effective address is the value in X, Y, or SP <br> autodecremented by 1 to 8. |
| Indexed <br> (preincrement) | INST oprx3,+xys | IDX | Effective address is the value in X, Y, or SP <br> autoincremented by 1 to 8. |
| Indexed <br> (postdecrement) | INST oprx3,xys- | IDX | Effective address is the value in X, Y, or SP. The value <br> is postdecremented by 1 to 8. |

Table 4-1 Addressing Mode Summary

| Addressing Mode | Source Form | Abbreviation | Description |
| :---: | :--- | :---: | :--- |
| Indexed <br> (postincrement) | INST oprx3,xys+ | IDX | Effective address is the value in X, Y, or SP. The value <br> is postincremented by 1 to 8. |
| Indexed <br> (accumulator offset) | INST abd,xysp | IDX | Effective address is the value in X, Y, SP, or PC plus <br> the value in A, B, or D. |
| Indexed <br> (9-bit offset) | INST oprx9,xysp | IDX1 | Effective address is the value in X, Y, SP, or PC plus a <br> 9-bit signed constant offset. |
| Indexed <br> (16-bit offset) | INST oprx16,xysp | IDX2 | Effective address is the value in X, Y, SP, or PC plus a <br> 16-bit constant offset. |
| Indexed-indirect <br> (16-bit offset) | INST [oprx16,xysp] | [IDX2] | The value in X, Y, SP, or PC plus a 16-bit constant <br> offset points to the effective address. |
| Indexed-indirect <br> (D accumulator offset) | INST [D,xysp] | [D,IDX] | The value in X, Y, SP, or PC plus the value in D points <br> to the effective address. |

### 4.2.1 Effective Address

Every addressing mode except inherent mode generates a 16-bit effective address. The effective address is the address of the memory location that the instruction acts on. Effective address computations do not require extra execution cycles.

### 4.2.2 Inherent Addressing Mode

Instructions that use this addressing mode either have no operands or all operands are in internal CPU registers. In either case, the CPU does not need to access any memory locations to complete the instruction.

```
NOP ;this instruction has no operands
INX ;operand is a CPU register
```


### 4.2.3 Immediate Addressing Mode

Operands for immediate mode instructions are included in the instruction and are fetched into the instruction queue one 16 -bit word at a time during normal program fetch cycles. Since program data is read into the instruction queue several cycles before it is needed, when an immediate addressing mode operand is called for by an instruction, it is already present in the instruction queue.

The pound symbol (\#) is used to indicate an immediate addressing mode operand. One very common programming error is to accidentally omit the \# symbol. This causes the assembler to misinterpret the following expression as an address rather than explicitly provided data. For example LDAA \#\$55 means to load the immediate value $\$ 55$ into the A accumulator, while LDAA $\$ 55$ means to load the value from address $\$ 0055$ into the A accumulator. Without the \# symbol the instruction is erroneously interpreted as a direct addressing instruction.

$$
\text { LDAA } \quad \# \$ 55
$$

| LDX | \#\$1234 |
| :--- | :---: |
| LDY | $\# \$ 67$ |

The size of the immediate operand is implied by the instruction context. In the third example, the instruction implies a 16-bit immediate value but only an 8-bit value is supplied. In this case the assembler generates the 16 -bit value $\$ 0067$ because the CPU expects a 16 -bit value in the instruction stream.

```
BRSET FOO,#$03,THERE
```

In this example, extended addressing is used to access the operand FOO, immediate addressing is used to access the mask value $\$ 03$, and relative addressing is used to identify the destination address of a branch in case the branch-taken conditions are met. BRSET is listed as an extended mode instruction even though immediate and relative modes are also used.

### 4.2.4 Direct Addressing Mode

This addressing mode is sometimes called zero-page addressing because it accesses operands in the address range $\$ 0000$ through $\$ 00 \mathrm{FF}$. Since these addresses always begin with $\$ 00$, only the low byte of the address needs to be included in the instruction, which saves program space and execution time. A system can be optimized by placing the most commonly accessed data in this area of memory. The low byte of the operand address is supplied with the instruction and the high byte of the address is assumed to be zero.

```
LDAA $55
```

The value $\$ 55$ is taken to be the low byte of an address in the range $\$ 0000$ through $\$ 00 \mathrm{FF}$. The high byte of the address is assumed to be zero. During execution, the CPU combines the value $\$ 55$ from the instruction with the assumed value of $\$ 00$ to form the address $\$ 0055$, which is then used to access the data to be loaded into accumulator A.

```
LDX $20
```

In this example, the value $\$ 20$ is combined with the assumed value of $\$ 00$ to form the address $\$ 0020$. Since the LDX instruction requires a 16-bit value, a 16-bit word of data is read from addresses $\$ 0020$ and $\$ 0021$. After execution, the X index register has the value from address $\$ 0020$ in its high byte and the value from address $\$ 0021$ in its low byte.

### 4.2.5 Extended Addressing Mode

In extended addressing, the full 16-bit address of the memory location to be operated on is provided in the instruction. Extended addressing can access any location in the 64 K byte memory map.

```
LDAA $F03B
```

The value from address $\$$ F03B is loaded into the A accumulator.

### 4.2.6 Relative Addressing Mode

Relative addressing is for branch instructions only. Relative addressing determines the branch destination. The short and long versions of conditional branch instructions use relative addressing exclusively. The branching bit-condition instructions, BRSET and BRCLR, use multiple addressing modes, including relative mode.

A conditional branch instruction tests a status bit in the condition code register. If the bit tests true, execution begins at the destination formed by adding an offset to the address of the memory location after the offset. If the bit does not test true, execution continues with the instruction that follows the branch instruction.

A short conditional branch instruction has an 8-bit opcode and a signed 8-bit relative offset in the byte that follows the opcode. A long conditional branch instruction has an 8-bit prebyte, an 8-bit opcode and a signed 16-bit relative offset in the two bytes that follow the opcode.

A branching bit-condition instruction, BRCLR or BRSET, tests the state of one or more bits in a memory byte. Direct, extended, or indexed addressing can determine the location of the memory byte. The instruction includes an immediate 8 -bit mask operand to test the bits and an 8 -bit relative offset. If the bits test true, execution begins at the destination formed by adding the 8-bit offset to the address of the memory location after the offset. If the bits do not test true, execution continues with the instruction that follows the branch instruction.

Both 8-bit and 16-bit offsets are signed two's complement numbers to support branching upward and downward in memory. The numeric range of short branch offset values is $\$ 80(-128)$ to $\$ 7 \mathrm{~F}(127)$. The numeric range of long branch offset values is $\$ 8000(-32768)$ to $\$ 7 \mathrm{FFF}(32767)$. If the offset is zero, the CPU executes the instruction that follows the branch instruction.

Since the offset is at the end of a branch instruction, using a negative offset value can cause the PC to point to the opcode and initiate a loop. For instance, a branch always (BRA) instruction consists of two bytes, so using an offset of \$FE sets up an infinite loop; the same is true of a long branch always (LBRA) instruction with an offset of \$FFFC.

An offset that points to the opcode can cause a branching bit-condition instruction to repeat execution until the specified bit condition is satisfied. Since branching bit-condition instructions can consist of four, five, or six bytes depending on the addressing mode used, the offset value that sets up a loop can vary. For instance, an offset of \$FC in a 4-byte BRCLR instruction sets up a loop that executes until all the bits in the tested memory byte are clear.

### 4.2.7 Indexed Addressing Modes

There are seven indexed addressing modes:

- 5-bit constant offset
- Autodecrement/increment
- 9-bit constant offset
- 16-bit constant offset
- 16-bit constant offset indexed-indirect
- Accumulator offset
- Accumulator D offset indexed-indirect

Features of indexed addressing include:

- The stack pointer can be used as an indexing register in all indexed operations
- The program counter can be used as an indexing register in all but autoincrement and autodecrement modes
- A, B, or D accumulators can be used for accumulator offsets
- Automatic pre- or postincrement or pre- or postdecrement by -8 to +8
- A choice of 5-, 9-, or 16-bit signed constant offsets
- Two indexed-indirect modes:
- Indexed-indirect mode with 16-bit offset
- Indexed-indirect mode with accumulator D offset


### 4.2.7.1 Indexed Addressing Postbyte

A postbyte follows all indexed addressing opcodes. There may be 0,1 , or 2 extension bytes after the postbyte. The postbyte and extensions do the following tasks:

1. Select a register for indexing ( $\mathrm{X}, \mathrm{Y}, \mathrm{SP}, \mathrm{PC}, \mathrm{A}, \mathrm{B}$, or D )
2. Enable automatic pre- or postincrementing or decrementing of $\mathrm{X}, \mathrm{Y}$, or SP and select the pre- or postincrement value
3. Select 5-bit, 9-bit, or 16-bit signed constant offsets

Table 4-2 shows how the postbyte enhances indexed addressing capabilities.

Table 4-2 Summary of Indexed Operations
5-bit constant offset indexed addressing (IDX)

Effective address $=5$-bit signed offset $+(\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC)
Accumulator offset addressing (IDX)

|  |
| :---: |
|  | | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Effective address $=(X, Y, S P$, or PC) $+(A, B$, or $D)$
Autodecrement/autoincrement) indexed addressing (IDX)
Postbyte:

| 7 | 6 | 5 | 4 | 3 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{rr}^{1,3}$ | 1 | $\mathrm{p}^{4}$ | 4 | 4 -bit inc/dec value ${ }^{5}$ |  |

Effective address $=(X, Y$, or SP) $\pm 1$ to 8

## 9-bit constant offset indexed addressing (IDX1)

|  | 7 | 6 | 5 |  | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Postbyte: | 1 | 1 | 1 | rr ${ }^{1}$ |  | 0 | 0 | $\mathrm{s}^{6}$ |

Effective address $=\mathrm{s}$ :(offset extension byte) $+(\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC)
16-bit constant offset indexed addressing (IDX2)

|  | 7 | 6 | 5 | 4 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Postbyte: | 1 | 1 | 1 | rr ${ }^{1}$ | 0 | 1 | 0 |

Effective address = (two offset extension bytes) $+(\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC)

## 16-bit constant offset indexed-indirect addressing ([IDX2])

|  |  |  | 7 | 6 | 5 | 4 | 3 | 2 |
| ---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

(two offset extension bytes) $+(\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC) is address of pointer to effective address
Accumulator D offset indexed-indirect addressing ([D,IDX])

Postbyte:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 1 | $r r^{1}$ | 1 | 1 | 1 |  |

$(\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC$)+(\mathrm{D})$ is address of pointer to effective address
NOTES:

1. rr selects $X(00), Y(01), S P(10)$, or $P C$ (11).
2. aa selects $A(00), B(01)$, or $D(10)$.
3. In autoincrement/decrement indexed addressing, PC is not a valid selection.
4. p selects pre- (0) or post- (1) increment/decrement.
5. Increment values range from $0000(+1)$ to $0111(+8)$. Decrement values range from $1111(-1)$ to $1000(-8)$.

6 . $s$ is the sign bit of the offset extension byte.
All indexed addressing modes use a 16-bit CPU register and additional information to create an indexed address. In most cases the indexed address is the effective address of the instruction, that is, the address of the memory location that the instruction acts on. In indexed-indirect addressing, the indexed address is the location of a value that points to the effective address.

PC offsets are calculated from the location immediately following the current instruction.

```
1000 18 09 C2 20 00 MOVB $2000 2,PC
1005 A7 NOP
```

This example moves a byte of data from $\$ 2000$ to $\$ 1007$.

### 4.2.7.2 5-Bit Constant Offset Indexed Addressing

This addressing mode calculates the effective address by adding a 5-bit signed offset in the postbyte to the indexing register ( $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC ). The value in the indexing register does not change. The 5 -bit signed offset gives a range of -16 through +15 from the value in the indexing register. The majority of indexed instructions use offsets that fit in the 5-bit offset range.

For these examples, assume $X$ contains $\$ 1000$ and $Y$ contains $\$ 2000$ :

```
LDAA 0,X
```

The value at address $\$ 1000$ is loaded into A.

$$
\text { STAB } \quad-8, Y
$$

The value in B is stored at address $\$ 2000-\$ 8$, or $\$ 1 F F 8$.

### 4.2.7.3 9-Bit Constant Offset Indexed Addressing

This addressing mode calculates the effective address by adding a 9-bit signed offset in an extension byte to the indexing register ( $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC ). The value in the indexing register does not change. The sign bit of the offset is in the postbyte. The 9 -bit offset gives a range of -256 through +255 from the value in the indexing register.

For these examples assume X contains \$1000 and Y contains \$2000:

```
LDAA $FF,X
```

The value at address $\$ 10 \mathrm{FF}$ is loaded into A.

$$
\text { LDAB } \quad-20, Y
$$

The value at address $\$ 2000-\$ 14$, or $\$ 1 \mathrm{FEC}$, is loaded into B.

### 4.2.7.4 16-Bit Constant Offset Indexed Addressing

This addressing mode calculates the effective address by adding a 16-bit offset in two extension bytes to the indexing register ( $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC). The value in the indexing register does not change. The 16 -bit offset allows access to any address in the 64 K byte address space. The address bus and the offset are both

User Guide - S12CPu Fitueps.rcale Semiconductor, Inc.

16 bits, so it does not matter whether the offset is considered to be signed or unsigned (\$FFFF may be thought of as $+65,535$ or as -1 ).

### 4.2.7.5 16-Bit Constant Indexed-Indirect Addressing

This addressing mode calculates the address of a pointer to the effective address. It adds a 16 -bit offset in two extension bytes to the indexing register ( $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC ). The value in the indexing register does not change. The square brackets distinguish this addressing mode from 16-bit constant offset indexed addressng.

For this example, assume X contains $\$ 1000$ and the value at address $\$ 100 \mathrm{~A}$ is $\$ 2000$ :

$$
\text { LDAA } \quad[10, \mathrm{x}]
$$

The value 10 is added to the value in X to form the address $\$ 100 \mathrm{~A}$. The CPU fetches the effective address pointer, $\$ 2000$, from address $\$ 100 \mathrm{~A}$ and loads the value at address $\$ 2000$ into A .

### 4.2.7.6 Autodecrement/Autoincrement Indexed Addressing

This addressing mode calculates the effective address by adding an integer value between -8 and -1 or between 1 and 8 to the indexing register ( $\mathrm{X}, \mathrm{Y}$, or SP ). The indexing register retains its changed value.

NOTE: Autodecrementing and autoincrementing do not apply to the program counter.
When predecremented or preincremented, the indexing register changes before indexing takes place. When postdecremented or postincremented, the indexing register changes after indexing takes place.

This addressing mode adjusts the indexing value without increasing execution time by using an additional instruction.

In this example, the instruction compares X with the value that X points to and then increments X by one:

```
CPX 1,X+
```

The next two examples are equivalent to common push instructions. In the first example, the instruction predecrements the stack pointer by one and then stores A to the address contained in the stack pointer:

```
STAA 1,-SP ; equivalent to PSHA
STX 2,-SP ;equivalent to PSHX
```

The next two examples are equivalent to common pull instructions. In the first example, the instruction loads X from the address in the stack pointer and then postincrements the stack pointer by two:

```
LDX 2,SP+ ;equivalent to PULX
LDAA 1,SP+ ;equivalent to PULA
```

The next example demonstrates how to work with data structures larger than bytes and words. With this instruction in a program loop, it is possible to move words of data from a list having one word per entry into a second table that has four bytes per table element. The instruction postincrements the source pointer after reading the data from memory and preincrements the destination pointer before accessing memory:

$$
\text { MOVW } \quad 2, X+, 4,+Y
$$

Using a predecrement/increment version of LEAS, LEAX, or LEAY when SP, X, or Y is the respective indexing register changes the value in the indexing register. Using a postdecrement/increment version of LEAS, LEAX, LEAY when $\mathrm{SP}, \mathrm{X}$, or Y is the respective indexing register has no effect.

### 4.2.7.7 Accumulator Offset Indexed Addressing

This addressing mode calculates the effective address by adding the value in the indexing register to an unsigned offset value in one of the accumulators. The value in the indexing register is not changed. The indexing register can be $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC , and the accumulator can be $\mathrm{A}, \mathrm{B}$, or D .

Example:

$$
\text { LDAA } \quad B, X
$$

This instruction adds B to X to form the address from which A will be loaded. B and X are not changed by this instruction. This example is similar to the following two-instruction combination in an M68HC11.

### 4.2.7.8 Accumulator $\mathbf{D}$ Indexed-Indirect Addressing

This addressing mode calculates address of a pointer to the effective address. It adds the value in D to the value in the indexing register ( $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC ) The value in the indexing register does not change. The square brackets distinguish this addressing mode from D accumulator offset indexing.

In this example, accumulator D indexed-indirect addressing is used in a computed GOTO:

| JMP | $[\mathrm{D}, \mathrm{PC}]$ |  |
| :--- | :--- | :--- |
| GO1 | DC.W | PLACE1 |
| GO2 | DC.W | PLACE2 |
| GO3 | DC.W | PLACE3 |

The values beginning at GO1 are addresses of potential destinations of the jump instruction. At the time the JMP [D, PC] instruction is executed, PC points to the address GO1, and D holds one of the values $\$ 0000$, $\$ 0002$, or $\$ 0004$, determined by the program some time before the JMP.

Assume that the value in D is $\$ 0002$. The JMP instruction adds the values in D and PC to form the address of GO2. Next the CPU reads the address PLACE2 from memory at GO2 and jumps to PLACE2. The locations of PLACE1 through PLACE3 were known at the time of program assembly but the destination of the JMP depends upon the value in D computed during program execution.

### 4.2.8 Instructions Using Multiple Modes

Several instructions use more than one addressing mode in the course of execution.

### 4.2.8.1 Move Instructions

Move instructions can use one addressing mode to access the source of the move and another addressing mode to access the destination. There are move variations for most combinations of immediate, extended, and indexed addressing modes.

The only combinations of addressing modes that are not allowed are those with an immediate mode destination; the operand of an immediate instruction is data, not an address. For indexed moves, the indexing register can be $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC .

Move instructions do not have indirect modes, or 9-bit or 16-bit offset modes.

### 4.2.8.2 Bit Manipulation Instructions

Bit manipulation instructions use a combination of two or three addressing modes.
A BCLR or BSET instruction has an 8-bit mask to clear or set bits in a memory byte. The mask is an immediate value supplied with the instruction. Direct, extended, or indexed addressing determines the location of the memory byte.

A BRCLR or BRSET instruction has an 8-bit mask to test the states of bits in a memory byte. The mask is an immediate value supplied with the instruction. Direct, extended, or indexed addressing determines the location of the memory byte. Relative addressing determines the branch address. A signed 8-bit offset must be supplied with the instruction.

### 4.3 Instruction Descriptions

A brief discussion of the CPU instructions group by type is given in the subsections below. For a detailed instruction-by-instruction description please consult Appendix A of this guide.

### 4.3.1 Load and Store Instructions

Load instructions copy a value in memory or an immediate value into a CPU register. The value in memory is not changed by the operation. Load instructions (except LEAS, LEAX, and LEAY) affect condition code bits so no separate test instructions are needed to check the loaded values for negative or zero conditions.

Store instructions copy the value in a CPU register to memory. The CPU register value is not changed by the operation. Store instructions automatically update the N and Z condition code bits, which can eliminate the need for a separate test instruction in some programs.

A summary of the load and store instructions is given in Table 4-3.
Table 4-3 Load and Store Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| LDAA | Load A from memory Load A with immediate value | $\begin{aligned} & (\mathrm{M}) \Rightarrow A \\ & \mathrm{imm} \Rightarrow A \end{aligned}$ |
| LDAB | Load B from memory Load B with immediate value | $\begin{aligned} & (\mathrm{M}) \Rightarrow B \\ & \mathrm{imm} \Rightarrow B \end{aligned}$ |
| LDD | Load D from memory Load D with immediate value | $\begin{aligned} & (\mathrm{M}) \Rightarrow \mathrm{A},(\mathrm{M}+1) \Rightarrow B \\ & \mathrm{imm}_{\mathrm{H}} \Rightarrow \mathrm{~A}, \mathrm{imm}_{\mathrm{L}} \Rightarrow B \end{aligned}$ |
| LDS | Load SP from memory Load SP with immediate value | $\begin{aligned} & (\mathrm{M}) \Rightarrow S P_{\mathrm{H}},(\mathrm{M}+1) \Rightarrow S P_{\mathrm{L}} \\ & \mathrm{imm}_{\mathrm{H}} \Rightarrow \mathrm{SP}_{\mathrm{H}}, \text { imm }_{\mathrm{L}} \Rightarrow \mathrm{SP}_{\mathrm{L}} \end{aligned}$ |
| LDX | Load X from memory Load $X$ with immediate value | $\begin{aligned} & (\mathrm{M}) \Rightarrow X_{H},(\mathrm{M}+1) \Rightarrow X_{\mathrm{L}} \\ & \mathrm{imm}_{\mathrm{H}} \Rightarrow \mathrm{X}_{\mathrm{H}}, \text { imm } \end{aligned} \Rightarrow \mathrm{X}_{\mathrm{L}}$ |
| LDY | Load $Y$ from memory Load Y with immediate value | $\begin{aligned} & (\mathrm{M}) \Rightarrow Y_{\mathrm{H}},(\mathrm{M}+1) \Rightarrow Y_{\mathrm{L}} \\ & \text { imm }_{\mathrm{H}} \Rightarrow Y_{\mathrm{H}}, \text { imm }_{\mathrm{L}} \Rightarrow Y_{\mathrm{L}} \end{aligned}$ |
| LEAS | Load effective address into SP | Effective address $\Rightarrow$ SP |
| LEAX | Load effective address into $X$ | Effective address $\Rightarrow \mathrm{X}$ |
| LEAY | Load effective address into $Y$ | Effective address $\Rightarrow \mathrm{Y}$ |
| STAA | Store A in memory | (A) $\Rightarrow \mathrm{M}$ |
| STAB | Store B in memory | (B) $\Rightarrow \mathrm{M}$ |
| STD | Store D in memory | $(\mathrm{A}) \Rightarrow \mathrm{M}, \mathrm{B}) \Rightarrow \mathrm{M}+1$ |
| STS | Store SP in memory | $\left(\mathrm{SP}_{\mathrm{H}}\right) \Rightarrow \mathrm{M},\left(\mathrm{SP}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}+1$ |
| STX | Store X in memory | $\left(\mathrm{X}_{\mathrm{H}}\right) \Rightarrow \mathrm{M},\left(\mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}+1$ |
| STY | Store Y in memory | $\left(\mathrm{Y}_{\mathrm{H}}\right) \Rightarrow \mathrm{M},\left(\mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}+1$ |

### 4.3.2 Transfer and Exchange Instructions

Transfer instructions copy the value in a CPU register into another CPU register. The source value is not changed by the operation. TFR is a universal transfer instruction, but other mnemonics are accepted for compatibility with the M68HC12. The TAB and TBA instructions affect the $\mathrm{N}, \mathrm{Z}$, and V condition code bits in the same way as M68HC12 instructions. The TFR instruction does not affect the condition code bits.

Exchange instructions exchange the values in pairs of CPU registers.
The sign-extend instruction, SEX, is a special case of the universal transfer instruction. It adds a sign extension to an 8 -bit two's complement number so that the number can be used in 16 -bit operations. The 8 -bit number is copied from accumulator $\mathrm{A}, \mathrm{B}$, or the condition code register to accumulator D , the X index register, the Y index register, or the stack pointer. All the bits in the upper byte of the 16-bit result are given the value of the MSB of the 8 -bit number.

A summary of the transfer and exchange instructions is given in Table 4-4.
Table 4-4 Transfer and Exchange Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| TAB | Transfer A to B | $(\mathrm{A}) \Rightarrow \mathrm{B}$ |
| TAP | Transfer A to CCR | $(\mathrm{A}) \Rightarrow \mathrm{CCR}$ |
| TBA | Transfer B to A | $(\mathrm{B}) \Rightarrow \mathrm{A}$ |
| TFR | Transfer register | $(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP $) \Rightarrow \mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP |
| TPA | Transfer CCR to $A$ | $(\mathrm{CCR}) \Rightarrow \mathrm{A}$ |
| TSX | Transfer SP to $X$ | $(\mathrm{SP}) \Rightarrow \mathrm{X}$ |
| TSY | Transfer SP to Y | $(\mathrm{SP}) \Rightarrow \mathrm{Y}$ |
| TXS | Transfer X to SP | $(\mathrm{X}) \Rightarrow$ SP |
| TYS | Transfer Y to SP | $(\mathrm{Y}) \Rightarrow$ SP |
| EXG | Exchange registers | $(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) $\Leftrightarrow(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) |
| XGDX | Exchange D with $X$ | $(\mathrm{D}) \Leftrightarrow(\mathrm{X})$ |
| XGDY | Exchange D with Y | $(\mathrm{D}) \Leftrightarrow(\mathrm{Y})$ |
| SEX | Sign-extend 8-bit operand | $00:(\mathrm{A}, \mathrm{B}$, or CCR) or FF:(A, B, or CCR $) \Rightarrow \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP |

### 4.3.3 Move Instructions

These instructions move bytes or words from a source in memory, $\mathrm{M}_{1}$ or $\mathrm{M}_{1}: \mathrm{M}_{1}+1$, to a destination in memory, $\mathrm{M}_{2}$ or $\mathrm{M}_{2}: \mathrm{M}_{2}+1$. Six combinations of immediate, extended, and indexed addressing can specify source and destination addresses: IMM/EXT, IMM/IDX, EXT/EXT, EXT/IDX, IDX/EXT, and IDX/IDX. A summary of the move instructions is given in Table 4-5.

Table 4-5 Move Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| MOVB | Move byte (8-bit) | $\left(M_{1}\right) \Rightarrow M_{2}$ |
| MOVW | Move word (16-bit) | $\left(M_{1}\right):\left(M_{1}+1\right) \Rightarrow M_{2}: M_{2}+1$ |

### 4.3.4 Add and Subtract Instructions

Signed and unsigned 8-bit and 16-bit addition and subtraction can be performed on CPU registers, on a CPU register and memory, or on a CPU register and an immediate value. Special instructions support index calculation. Instructions that add or subtract the carry bit, C, in the CCR facilitate multiple precision computation. A summary of the add and subtract instructions is given in Table 4-6.

Table 4-6 Add and Subtract Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| ABA | Add A to B | $(A)+(B) \Rightarrow A$ |
| ABX | Add B to X | $(\mathrm{B})+(\mathrm{X}) \Rightarrow \mathrm{X}$ |
| ABY | Add B to Y | $(B)+(Y) \Rightarrow Y$ |
| ADCA | Add memory and carry to $A$ Add immediate value and carry to A | $\begin{aligned} & (A)+(M)+C \Rightarrow A \\ & (A)+i m m+C \Rightarrow A \end{aligned}$ |
| ADCB | Add memory and carry to B Add immediate value and carry to $B$ | $(\mathrm{B})+(\mathrm{M})+\mathrm{C} \Rightarrow \mathrm{~B}$ $\text { (B) }+\mathrm{imm}+\mathrm{C} \Rightarrow \mathrm{~B}$ |
| ADDA | Add memory to A Add immediate value to A | $\begin{aligned} & (A)+(M) \Rightarrow A \\ & (A)+i m m \Rightarrow A \end{aligned}$ |
| ADDB | Add memory to $B$ Add immediate value to $B$ | $\begin{aligned} & (B)+(M) \Rightarrow B \\ & (B)+i m m \Rightarrow B \end{aligned}$ |
| ADDD | Add memory to D Add immediate value to $D$ | (A): $(B)+(M):(M+1) \Rightarrow A: B$ <br> (A):(B) +imm $\Rightarrow A: B$ |
| SBA | Subtract B from A | (A) - (B) $\Rightarrow$ A |
| SBCA | Subtract memory and carry from A Subtract immediate value and carry from A | (A) $-(M)-C \Rightarrow A$ <br> (A) $-\mathrm{imm}-\mathrm{C} \Rightarrow \mathrm{A}$ |
| SBCB | Subtract memory and carry from B Subtract immediate value and carry from B | (B) $-(\mathrm{M})-\mathrm{C} \Rightarrow \mathrm{B}$ <br> (B) - imm $-C \Rightarrow B$ |
| SUBA | Subtract memory from A Subtract immediate value from A | (A) $-(M) \Rightarrow A$ <br> (A) $-\mathrm{imm} \Rightarrow A$ |
| SUBB | Subtract memory from B Subtract immediate value from B | (B) $-(M) \Rightarrow B$ <br> (B) $-\mathrm{imm} \Rightarrow B$ |
| SUBD | Subtract memory from D Subtract immediate value from D | (A): $(B)-(M):(M+1) \Rightarrow A: B$ <br> (A):(B) $-\mathrm{imm} \Rightarrow A: B$ |

### 4.3.5 Binary Coded Decimal Instructions

To add binary coded decimal (BCD) operands, use addition instructions that set the half-carry bit, H , in the CCR. Then adjust the result with the DAA instruction. A summary of the BCD instructions is given in Table 4-7.

Table 4-7 BCD Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| ABA | Add B to $A$ | $(A)+(B) \Rightarrow A$ |
| ADCA | Add memory and carry to $A$ <br> Add immediate value and carry to $A$ | $(A)+(M)+C \Rightarrow A$ <br> $(A)+i m m+C \Rightarrow A$ |
| ADCB | Add memory and carry to $B$ <br> Add immediate value and carry to $B$ | $(B)+(M)+C \Rightarrow B$ <br> $(B)+i m m+C \Rightarrow B$ |
| ADDA | Add memory to $A$ <br> Add immediate value to $A$ | $(A)+(M) \Rightarrow A$ <br> $(A)+i m m \Rightarrow A$ |
| ADDB | Add memory to $B$ <br> Add immediate value to $B$ | $(B)+(M) \Rightarrow B$ <br> $(B)+i m m \Rightarrow B$ |
| DAA | Decimal adjust $A$ | $(A) 10 \Rightarrow A$ |

### 4.3.6 Decrement and Increment Instructions

These instructions are optimized 8 -bit and 16-bit addition and subtraction operations. They are used to implement counters. Because they do not affect the carry bit, C, in the CCR, they are particularly well suited for loop counters in multiple-precision computation routines. See 4.3.17.4 Loop Primitive Instructions for information concerning automatic counter branches. A summary of the decrement and increment instructions is given in Table 4-8 Decrement and Increment Instructions.

Table 4-8 Decrement and Increment Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| DEC | Decrement memory | $(\mathrm{M})-\$ 01 \Rightarrow \mathrm{M}$ |
| DECA | Decrement A | $(\mathrm{A})-\$ 01 \Rightarrow \mathrm{~A}$ |
| DECB | Decrement B | $(\mathrm{B})-\$ 01 \Rightarrow \mathrm{~B}$ |
| DES | Decrement SP | $(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP}$ |
| DEX | Decrement X | $(\mathrm{X})-\$ 0001 \Rightarrow \mathrm{X}$ |
| DEY | Decrement Y | $(\mathrm{Y})-\$ 0001 \Rightarrow \mathrm{Y}$ |
| INC | Increment memory | $(\mathrm{M})+\$ 01 \Rightarrow \mathrm{M}$ |
| INCA | Increment A | $(\mathrm{A})+\$ 01 \Rightarrow \mathrm{~A}$ |
| INCB | Increment B | $(\mathrm{B})+\$ 01 \Rightarrow \mathrm{~B}$ |
| INS | Increment SP | $(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$ |
| INX | Increment $X$ | $(\mathrm{X})+\$ 0001 \Rightarrow \mathrm{X}$ |
| INY | Increment $Y$ | $(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y}$ |

### 4.3.7 Compare and Test Instructions

Compare and test instructions perform subtraction on a pair of CPU registers, on a CPU register and memory, or on a CPU register and an immediate value. The result is not stored, but the operation can affect condition codes in the CCR. These instructions are used to establish conditions for branch instructions. However, most instructions update condition codes automatically, so it is often unnecessary to include separate compare or test instructions. A summary of the compare and test instructions is given in Table 4-9.

Table 4-9 Compare and Test Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| CBA | Compare A to B | $(\mathrm{A})-(\mathrm{B})$ |
| CMPA | Compare A to memory <br> Compare A to immediate value | $(\mathrm{A})-(\mathrm{M})$ <br> $(\mathrm{A})-\mathrm{imm}$ |
| CMPB | Compare B to memory <br> Compare B to immediate value | $(\mathrm{B})-(\mathrm{M})$ <br> $(\mathrm{B})-\mathrm{imm}$ |
| CPD | Compare D to memory <br> Compare D to immediate value | $(\mathrm{A}):(\mathrm{B})-(\mathrm{M}):(\mathrm{M}+1)$ <br> $(\mathrm{A}):(\mathrm{B})-\mathrm{imm}$ |
| CPS | Compare SP to memory <br> Compare SP to immediate value | $(\mathrm{SP})-(\mathrm{M}):(\mathrm{M}+1)$ <br> $(\mathrm{SP})-\mathrm{imm}$ |
| CPX | Compare X to memory <br> Compare X to immediate value | $(\mathrm{X})-(\mathrm{M}):(\mathrm{M}+1)$ <br> $(\mathrm{X})-\mathrm{imm}$ |
| CPY | Compare Y to memory <br> Compare Y to immediate value | $(\mathrm{Y})-(\mathrm{M}):(\mathrm{M}+1)$ <br> $(\mathrm{Y})-\mathrm{imm}$ |
| TST | Test memory for zero or minus | (M) -\$00 |
| TSTA | Test A for zero or minus | $(\mathrm{A})-\$ 00$ |
| TSTB | Test B for zero or minus | $(\mathrm{B})-\$ 00$ |

User Guide - S12CPU155teresscale Semiconductor, Inc.

### 4.3.8 Boolean Logic Instructions

These instructions perform a logic operation on the A or B accumulator and a memory value or immediate value, or on the CCR and an immediate value. A summary of the boolean logic instructions is given in Table 4-10.

Table 4-10 Boolean Logic Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| ANDA | AND A with memory <br> AND A with immediate value | $(A) \bullet(M) \Rightarrow A$ <br> $(A) \bullet i m m \Rightarrow A$ |
| ANDB | AND B with memory <br> AND B with immediate value | $(B) \bullet(M) \Rightarrow B$ <br> $(B) \bullet$ imm $\Rightarrow B$ |
| ANDCC | AND CCR with immediate value (to clear CCR bits) | $(C C R) \bullet$ imm $\Rightarrow C C R$ |
| EORA | Exclusive OR A with memory <br> Exclusive OR A with immediate value | $(A) \oplus(M) \Rightarrow A$ <br> $(A) \oplus i m m \Rightarrow A$ |
| EORB | Exclusive OR B with memory <br> Exclusive OR B with immediate value | $(B) \oplus(M) \Rightarrow B$ <br> $(B) \oplus i m m \Rightarrow B$ |
| ORAA | OR A with memory <br> OR A with immediate value | $(A)+(M) \Rightarrow A$ <br> $(A)+i m m \Rightarrow A$ |
| ORAB | OR B with memory <br> OR B with immediate value | $(B)+(M) \Rightarrow B$ <br> $(B)+i m m \Rightarrow B$ |
| ORCC | OR CCR with immediate value (to set CCR bits) | $(C C R)+i m m \Rightarrow C C R$ |

### 4.3.9 Clear, Complement, and Negate Instructions

These instructions perform binary operations on values in an accumulator or in memory. Clear operations clear the value, complement operations replace the value with its one's complement, and negate operations replace the value with its two's complement. A summary of the clear, complement and negate instructions is given in Table 4-11.

Table 4-11 Clear, Complement, and Negate Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| CLC | Clear C bit in CCR | $0 \Rightarrow C$ |
| CLI | Clear I bit in CCR | $0 \Rightarrow I$ |
| CLR | Clear memory | $\$ 00 \Rightarrow M$ |
| CLRA | Clear $A$ | $\$ 00 \Rightarrow A$ |
| CLRB | Clear B | $\$ 00 \Rightarrow B$ |
| CLV | Clear V bit in CCR | $0 \Rightarrow V$ |
| COM | One's complement memory | $\$ F F-(M) \Rightarrow M$ or $(\bar{M}) \Rightarrow M$ |
| COMA | One's complement $A$ | $\$ F F-(A) \Rightarrow A$ or $(\overline{\mathrm{A}}) \Rightarrow A$ |
| COMB | One's complement B | $\$ F F-(B) \Rightarrow B$ or $(\bar{B}) \Rightarrow B$ |
| NEG | Two's complement memory | $\$ 00-(M) \Rightarrow M$ or $(\bar{M})+1 \Rightarrow M$ |
| NEGA | Two's complement $A$ | $\$ 00-(A) \Rightarrow A$ or $(\bar{A})+1 \Rightarrow A$ |
| NEGB | Two's complement $B$ | $\$ 00-(B) \Rightarrow B$ or $(\bar{B})+1 \Rightarrow B$ |

### 4.3.10 Multiply and Divide Instructions

The multiply instructions perform signed and unsigned, 8-bit and 16-bit multiplication. An 8-bit multiplication gives a 16-bit product. A 16-bit multiplication gives a 32 -bit product.

An integer divide or fractional divide instruction has a 16-bit dividend, divisor, quotient, and remainder. Extended divide instructions use a 32 -bit dividend and a 16 -bit divisor to produce a 16 -bit quotient and a 16-bit remainder.

A summary of the multiply and divide instructions is given in Table 4-12.
Table 4-12 Multiplication and Division Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| EMUL | 16 by 16 multiply (unsigned) | $(\mathrm{Y}) \times(\mathrm{D}) \Rightarrow \mathrm{Y}: \mathrm{D}$ |
| EMULS | 16 by 16 multiply (signed) | $(\mathrm{Y}) \times(\mathrm{D}) \Rightarrow \mathrm{Y}: \mathrm{D}$ |
| MUL | 8 by 8 multiply (unsigned) | $(\mathrm{A}) \times(\mathrm{B}) \Rightarrow \mathrm{A}: B$ |
| EDIV | 32 by 16 divide (unsigned) | $(\mathrm{Y}):(\mathrm{D}) \div(\mathrm{X})$, quotient $\Rightarrow \mathrm{Y}$, remainder $\Rightarrow \mathrm{D}$ |
| EDIVS | 32 by 16 divide (signed) | $(\mathrm{Y}):(\mathrm{D}) \div(\mathrm{X})$, quotient $\Rightarrow \mathrm{Y}$, remainder $\Rightarrow \mathrm{D}$ |
| FDIV | 16 by 16 fractional divide (unsigned) | $(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X}$, remainder $\Rightarrow \mathrm{D}$ |
| IDIV | 16 by 16 integer divide (unsigned) | $(\mathrm{D}) \div(X) \Rightarrow X$, remainder $\Rightarrow \mathrm{D}$ |
| IDIVS | 16 by 16 integer divide (signed) | $(\mathrm{D}) \div(X) \Rightarrow X$, remainder $\Rightarrow \mathrm{D}$ |

### 4.3.11 Bit Test and Bit Manipulation Instructions

These operations use a mask value to test or change the value of individual bits in an accumulator or in memory. BITA and BITB provide a convenient means of testing bits without altering the value of either operand. A summary of the bit test and bit manipulation instructions is given in Table 4-13.

Table 4-13 Bit Test and Bit Manipulation Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| BCLR | Clear bit(s) in memory | $(M) \bullet$ mask byte $\Rightarrow \mathrm{M}$ |
| BITA | Bit test A | $(\mathrm{A}) \bullet(\mathrm{M})$ |
| BITB | Bit test B | $(\mathrm{B}) \bullet(\mathrm{M})$ |
| BSET | Set bits in memory | $(\mathrm{M})+$ mask byte $\Rightarrow \mathrm{M}$ |

### 4.3.12 Shift and Rotate Instructions

There are shifts and rotates for accumulators and memory bytes. For multiple-byte operations, all shifts and rotates pass the shifted-out bit through the carry bit, C. Because logical and arithmetic left shifts are identical, there are no separate logical left shift operations. LSL mnemonics are assembled as ASL operations. A summary of the shift and rotate instructions is given in Table 4-14.

Table 4-14 Shift and Rotate Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| $\begin{aligned} & \hline \text { LSL } \\ & \text { LSLA } \\ & \text { LSLB } \end{aligned}$ | Logic shift left memory Logic shift left A Logic shift left B | $\square_{\mathrm{C}}^{\square} \leftarrow \square_{7} \square \square \square \square_{0} \leftarrow 0$ |
| LSLD | Logic shift left D |  |
| $\begin{array}{\|l\|} \hline \text { LSR } \\ \text { LSRA } \\ \text { LSRB } \end{array}$ | Logic shift right memory Logic shift right A Logic shift right B |  |
| LSRD | Logic shift right D |  |
| ASL ASLA ASLB | Arithmetic shift left memory Arithmetic shift left A Arithmetic shift left B | ${\underset{C}{C}}_{\square}^{\square} \leqslant \square_{7} \square \square \square \square_{0} \leqslant 0$ |
| ASLD | Arithmetic shift left D |  |
| ASR ASRA ASRB | Arithmetic shift right memory Arithmetic shift right A Arithmetic shift right B |  |
| ROL ROLA ROLB | Rotate left memory <br> Rotate left A <br> Rotate left B |  |
| ROR RORA RORB | Rotate right memory <br> Rotate right A <br> Rotate right B |  |

### 4.3.13 Fuzzy Logic Instructions

The instruction set supports efficient processing of fuzzy logic operations. A summary of the fuzzy logic instructions is given in Table 4-15.

Table 4-15 Fuzzy Logic Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| MEM | Membership evaluation | $\mu$ (grade) $\Rightarrow M_{(Y)},(X)+4 \Rightarrow X,(Y)+1 \Rightarrow Y, A$ unchanged <br> If $(A)<P 1$ or $(A)>P 2$, then $\mu=0$, else $\mu=\operatorname{MIN}[((A)-P 1) \times$ S1, $(P 2-(A)) \times$ S2, \$FF] <br> A contains current crisp input value. <br> X points to 4 -byte data structure describing trapezoidal membership function as base intercept points and slopes (P1, P2, S1, S2). <br> Y points to fuzzy input (RAM location). |
| REV | MIN-MAX rule evaluation | Find smallest rule input (MIN). <br> Store to rule outputs unless fuzzy output is larger (MAX). Rules are unweighted. <br> Each rule input is 8 -bit offset from base address in Y . <br> Each rule output is 8-bit offset from base address in Y . <br> \$FE separates rule inputs from rule outputs. \$FF terminates rule list. <br> REV can be interrupted. |
| REVW | Weighted MIN-MAX rule evaluation | Find smallest rule input (MIN). Multiply by rule-weighting factor (optional). <br> Store to rule outputs unless fuzzy output is larger (MAX). <br> Each rule input is 16-bit address of a fuzzy input. <br> Each rule output is 16 -bit address of fuzzy output. <br> Address \$FFFE separates rule inputs from rule outputs. \$FFFF terminates rule list. <br> Weights are 8-bit values in separate table. <br> REVW can be interrupted. |
| WAV | Weighted average calculation | Calculate numerator (sum of products) and denominator (sum of weights). $\begin{aligned} & \sum_{i \not B 1}^{B} S_{i} F_{i} \Rightarrow Y: D \\ & \sum_{i=1} F_{i} \Rightarrow X \end{aligned}$ <br> Put results in correct CPU registers for EDIV immediately after WAV. |
| wavr | Return to interrupted WAV instruction | Recover intermediate results from stack rather than initializing to zero. |

### 4.3.14 Maximum and Minimum Instructions

### 4.3.14.1 Fuzzy Logic Membership Instruction

The MEM instruction is used during the fuzzification process. During fuzzification, current system input values are compared to stored input membership functions to determine the degree to which each label of each system input is true. This is accomplished by finding the $y$ value for the current input on a trapezoidal membership function for each label of each system input. The MEM instruction performs this calculation for one label of one system input. To perform the complete fuzzification task for a system, several MEM instructions must be executed, usually in a program loop structure.

### 4.3.14.2 Fuzzy Logic Rule Evaluation Instructions

The REV and REVW instructions perform MIN-MAX rule evaluations that are central elements of a fuzzy logic inference program. Fuzzy input values are processed using a list of rules from the knowledge base to produce a list of fuzzy outputs. The REV instruction treats all rules as equally important. The REVW instruction allows each rule to have a separate weighting factor. REV and REVW also differ in the way rules are encoded into the knowledge base.

Because they require a number of cycles to execute, rule evaluation instructions can be interrupted. Once the interrupt has been serviced, instruction execution resumes at the point the interrupt occurred.

### 4.3.14.3 Fuzzy Logic Averaging Instruction

The WAV instruction calculates weighted averages. In order to be usable, the fuzzy outputs produced by rule evaluation must be defuzzified to produce a single output value which represents the combined effect of all of the fuzzy outputs. Fuzzy outputs correspond to the labels of a system output and each is defined by a membership function in the knowledge base. The CPU typically uses singletons for output membership functions rather than the trapezoidal shapes used for inputs. As with inputs, the x-axis represents the range of possible values for a system output. Singleton membership functions consist of the x -axis position for a label of the system output. Fuzzy outputs correspond to the y -axis height of the corresponding output membership function. The WAV instruction calculates the numerator and denominator sums for a weighted average of the fuzzy outputs.

Because WAV requires a number of cycles to execute, it can be interrupted. The wavr pseudoinstruction causes execution to resume at the point where it was interrupted.
These instructions make comparisons between an accumulator and a memory location. They can be used for linear programming operations such as Simplex-method optimization or for fuzzification.

MAX and MIN instructions use accumulator A to perform 8-bit comparisons, while EMAX and EMIN instructions use accumulator D to perform 16-bit comparisons. The result (maximum or minimum value) can be stored in the accumulator or in the memory location. A summary of the minimum and maximum instructions is given in Table 4-16.

Table 4-16 Minimum and Maximum Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| EMIND | Put smaller of two unsigned 16-bit values in D | MIN [(D), (M):(M+1)] $\Rightarrow$ D |
| EMINM | Put smaller of two unsigned 16-bit values in memory | MIN [(D), (M):(M+1)] $\Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| MINA | Put smaller of two unsigned 8-bit values in A | $\mathrm{MIN}[(\mathrm{A}),(\mathrm{M})] \Rightarrow \mathrm{A}$ |
| MINM | Put smaller of two unsigned 8-bit values in memory | MIN [(A), (M)] $\Rightarrow \mathrm{M}$ |
| EMAXD | Put larger of two unsigned 16-bit values in D | $\operatorname{MAX}[(\mathrm{D}),(\mathrm{M}):(\mathrm{M}+1)] \Rightarrow \mathrm{D}$ |
| EMAXM | Put larger of two unsigned 16-bit values in memory | MAX [(D), (M):(M+1)] $\Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| MAXA | Put larger of two unsigned 8-bit values in A | $\operatorname{MAX}[(\mathrm{A}),(\mathrm{M})] \Rightarrow \mathrm{A}$ |
| MAXM | Put larger of two unsigned 8-bit values in memory | $\operatorname{MAX}[(\mathrm{A}),(\mathrm{M})] \Rightarrow \mathrm{M}$ |

### 4.3.15 Multiply and Accumulate Instruction

The EMACS instruction multiplies two 16-bit operands stored in memory and accumulates the 32-bit result in a third memory location. EMACS can be used to implement simple digital filters and defuzzification routines that use 16 -bit operands. The WAV instruction incorporates an 8 -bit to 16 -bit multiply and accumulate operation that obtains a numerator for the weighted average calculation. The EMACS instruction can automate this portion of the averaging operation when 16 -bit operands are used. A summary of the multiply and accumulate instructions is given in Table 4-17.

Table 4-17 Multiply and Accumulate Instruction

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| EMACS | Multiply and <br> accumulate <br> (signed $)$ <br> $16 \times 16$ bit $\Rightarrow 32$ bit | $\left.\left(M_{X}\right):\left(M_{X+1}\right) \times\left(M_{Y}\right): M_{Y+1}\right)+(M):(M+1):(M+2):(M+3) \Rightarrow M: M+1: M+2: M+3$ |

### 4.3.16 Table Interpolation Instructions

The TBL and ETBL instructions interpolate values from tables stored in memory. Any function that can be represented as a series of linear equations can be represented by a table. Interpolation can be used for many purposes, including tabular fuzzy logic membership functions. TBL uses 8-bit table entries and returns an 8 -bit result; ETBL uses 16 -bit table entries and returns a 16-bit result. Indexed addressing modes provide flexibility in structuring tables.

Consider each of the successive values stored in a table as $y$-values for the endpoint of a line segment. The value in the B accumulator before instruction execution begins represents change in x from the beginning of the line segment to the lookup point divided by total change in x from the beginning to the end of the line segment. B is treated as an 8-bit binary fraction with radix point left of the MSB, so each line segment is effectively divided into 256 smaller segments. During instruction execution, the change in y between the beginning and end of the segment (a signed byte for TBL or a signed word for ETBL) is multiplied by the value in B to obtain an intermediate delta-y term. The result (stored in the A accumulator by TBL, in the D accumulator by ETBL) is the y -value of the beginning point plus the signed intermediate delta-y value.

A summary of the table interpolation instructions is given in Table 4-18.
Table 4-18 Table Interpolation Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| ETBL | 16-bit table lookup and interpolate <br> (indirect addressing not allowed) | $(M):(M+1)+[(B) \times[(M+2):(M+3)-(M):(M+1)]] \Rightarrow D$ <br> Initialize B, and index before ETBL. <br> Effective address points to the first 16-bit table entry $(M):(M+1)$ <br> $B$ is fractional part of lookup value |
| TBL | 8-bit table lookup and interpolate <br> (indirect addressing not allowed) | $(M)+[(B) \times[(M+1)-(M)]] \Rightarrow A$ <br> Initialize B, and index before TBL. <br> Effective address points to the first 8-bit table entry (M) <br> $B$ is fractional part of lookup value. | User Guide - S12CPu Fitueprscale Semiconductor, Inc.

### 4.3.17 Branch Instructions

A branch instruction causes a program sequence change when specific conditions exist. There are three types of branch instructions: short, long, and bit-conditional.

Branch instructions can also be classified by the type of condition that must be satisfied in order for a branch to be taken:

- Unary branch instructions are always executed
- Simple branch instructions are executed when a specific bit in the condition code register is in a specific state as a result of a previous operation
- Unsigned branch instructions are executed when a comparison or test of unsigned quantities results in a specific combination of bit states in the condition code register
- Signed branch instructions are executed when a comparison or test of signed quantities results in a specific combination of bit states in the condition code register

Some branch instructions belong to more than one type.

### 4.3.17.1 Short Branch Instructions

When a specified condition is met, a short branch instruction adds a signed 8-bit offset to the value in the program counter. Program execution continues at the new address. The numeric range of short branch offset values is $\$ 80(-128)$ to $\$ 7 \mathrm{~F}(127)$ from the address of the next memory location after the offset value. A summary of the short branch instructions is given in Table 4-19.

Table 4-19 Short Branch Instructions

| Mnemonic | Type | Function | Condition Equation |
| :---: | :---: | :---: | :---: |
| BRA | Unary | Branch always | $1=1$ |
| BRN |  | Branch never | $1=0$ |
| BCC | Simple | Branch if carry clear | $\mathrm{C}=0$ |
| BCS |  | Branch if carry set | $C=1$ |
| BEQ |  | Branch if equal | $\mathrm{Z}=1$ |
| BMI |  | Branch if minus | $\mathrm{N}=1$ |
| BNE |  | Branch if not equal | $\mathrm{Z}=0$ |
| BPL |  | Branch if plus | $\mathrm{N}=0$ |
| BVC |  | Branch if overflow clear | $\mathrm{V}=0$ |
| BVS |  | Branch if overflow set | $\mathrm{V}=1$ |
| BHI | Unsigned | Branch if higher ( $\mathrm{R}>\mathrm{M}$ ) | $C+Z=0$ |
| BHS |  | Branch if higher or same ( $R \geq \mathrm{M}$ ) | C = 0 |
| BLO |  | Branch if lower ( $\mathrm{R}<\mathrm{M}$ ) | $\mathrm{C}=1$ |
| BLS |  | Branch if lower or same (R $\leq M$ ) | $C+Z=1$ |
| BGE | Signed | Branch if greater than or equal ( $\mathrm{R} \geq \mathrm{M}$ ) | $\mathrm{N} \oplus \mathrm{V}=0$ |
| BGT |  | Branch if greater than ( $R>M$ ) | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ |
| BLE |  | Branch if less than or equal ( $\mathrm{R} \leq \mathrm{M}$ ) | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ |
| BLT |  | Branch if less than ( $\mathrm{R}<\mathrm{M}$ ) | $\mathrm{N} \oplus \mathrm{V}=1$ |

### 4.3.17.2 Long Branch Instructions

When a specified condition is met, a long branch instruction adds a signed 16 -bit offset to the value in the program counter. Program execution continues at the new address. Long branches are used when large displacements between decision-making steps are necessary. The numeric range of long branch offset values is $\$ 8000(-32,768)$ to $\$ 7 F F F(32,767)$ from the address of the next memory location after the offset value. This permits branching from any location in the standard 64 K byte address map to any other location in the map. A summary of the long branch instructions is given in Table 4-20.

Table 4-20 Long Branch Instructions

| Mnemonic | Class | Function | Condition Equation |
| :---: | :---: | :---: | :---: |
| LBRA | Unary | Long branch always | $1=1$ |
| LBRN |  | Long branch never | $1=0$ |
| LBCC | Simple | Long branch if carry clear | $C=0$ |
| LBCS |  | Long branch if carry set | $C=1$ |
| LBEQ |  | Long branch if equal | Z = 1 |
| LBMI |  | Long branch if minus | $\mathrm{N}=1$ |
| LBNE |  | Long branch if not equal | $\mathrm{Z}=0$ |
| LBPL |  | Long branch if plus | $\mathrm{N}=0$ |
| LBVC |  | Long branch if overflow clear | $\mathrm{V}=0$ |
| LBVS |  | Long branch if overflow set | $V=1$ |
| LBHI | Unsigned | Long branch if higher ( P > M ) | $C+Z=0$ |
| LBHS |  | Long branch if higher or same ( $R \geq \mathrm{M}$ ) | C = 0 |
| LBLO |  | Long branch if lower ( $\mathrm{R}<\mathrm{M}$ ) | Z = 1 |
| LBLS |  | Long branch if lower or same ( $\mathrm{R} \leq \mathrm{M}$ ) | $C+Z=1$ |
| LBGE | Signed | Long branch if greater than or equal ( $R \geq \mathrm{M}$ ) | $\mathrm{N} \oplus \mathrm{V}=0$ |
| LBGT |  | Long branch if greater than ( $\mathrm{R}>\mathrm{M}$ ) | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ |
| LBLE |  | Long branch if less than or equal ( $R \leq M$ ) | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ |
| LBLT |  | Long branch if less than ( $R<M$ ) | $\mathrm{N} \oplus \mathrm{V}=1$ |

### 4.3.17.3 Bit Condition Branch Instructions

Bit condition branches are taken when bits in a memory byte are in a specific state. A mask operand is used to test the location. If all bits in that location that correspond to ones in the mask are set (BRSET) or cleared (BRCLR), the branch is taken. The numeric range of 8-bit offset values is $\$ 80(-128)$ to $\$ 7 \mathrm{~F}$ (127) from the address of the next memory location after the offset value. A summary of the bit condition branch instructions is given in Table 4-21.

Table 4-21 Bit Condition Branch Instructions

| Mnemonic | Function | Condition Equation |
| :--- | :--- | :--- |
| BRCLR | Branch if selected bits clear | $(M) \bullet(\mathrm{mm})=0$ |
| BRSET | Branch if selected bits set | $(\overline{\mathrm{M}}) \bullet(\mathrm{mm})=0$ |

### 4.3.17.4 Loop Primitive Instructions

Loop primitive instructions test a counter value in a CPU register (A, B, D, X, Y, or SP) for a zero or nonzero value as a branch condition. There are predecrement, preincrement and test-only versions of these instructions. The numeric range of 9 -bit offset values is -256 to +255 from the address of the next memory location after the offset value. A summary of the loop primitive instructions is given in Table 4-22.

Table 4-22 Loop Primitive Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| DBEQ | Decrement counter <br> and branch if zero | (counter) $-1 \Rightarrow$ counter <br> If (counter) $=0$, then branch, else continue to next instruction |
| DBNE | Decrement counter <br> and branch if not zero | (counter) $-1 \Rightarrow$ counter <br> If (counter) $\neq 0$, then branch, else continue to next instruction |
| IBEQ | Increment counter <br> and branch if zero | (counter) $+1 \Rightarrow$ counter <br> If (counter) $=0$, then branch, else continue to next instruction |
| IBNE | Increment counter <br> and branch if not zero | (counter) $+1 \Rightarrow$ counter <br> If (counter) $\neq 0$, then branch, else continue to next instruction |
| TBEQ | Test counter <br> and branch if zero | If (counter) $=0$, then branch, else continue to next instruction |
| TBNE | Test counter <br> and branch if not zero | If (counter) $\neq 0$, then branch, else continue to next instruction |

### 4.3.18 Jump and Subroutine Instructions

Jump instructions cause immediate changes in program sequence. The JMP instruction loads the PC with an address in the 64 K byte memory map, and program execution continues at that address. The address can be provided as an absolute 16-bit address or determined by various forms of indexed addressing.

Subroutine instructions transfer control to a code segment that performs a particular task. A short branch to subroutine (BSR), a jump to subroutine (JSR), or an expanded-memory call (CALL) can be used to initiate subroutines. There is no long branch to subroutine instruction (LBSR), but a PC-relative JSR performs the same function. A return address is stacked, then execution begins at the subroutine address. Subroutines in the normal 64K byte address space are terminated with an RTS instruction. RTS unstacks the return address so that execution resumes with the instruction after BSR or JSR.

The CALL instruction is intended for use with expanded memory. CALL stacks the value in the PPAGE register and the return address, then writes a new value to PPAGE to select the memory page where the subroutine resides. The page value is an immediate operand in all addressing modes except indexed indirect modes; in these modes, an operand points to locations in memory where the new page value and subroutine address are stored. The RTC instruction ends subroutines in expanded memory. RTC unstacks the PPAGE value and the return address so that execution resumes with the next instruction after CALL. For software compatibility, CALL and RTC operate correctly on devices that do not have expanded addressing capability.

A summary of the jump and subroutine instructions is given in Table 4-23.
Table 4-23 Jump and Subroutine Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| BSR | Branch to subroutine | $(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}, \mathrm{RTN}_{\mathrm{H}}: R T N_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$, subroutine address $\Rightarrow \mathrm{PC}$ |
| CALL | Call subroutine <br> in expanded memory | $(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}, \mathrm{RTN}_{\mathrm{H}}: R T N_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1},(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP}$, <br> $(\mathrm{PPAGE}) \Rightarrow \mathrm{M}_{\mathrm{SP}}$ page $\Rightarrow \mathrm{PPAGE}$, subroutine address $\Rightarrow \mathrm{PC}$ |
| JMP | Jump | Subroutine address $\Rightarrow \mathrm{PC}$ |
| JSR | Jump to subroutine | $(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}, \mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$, subroutine address $\Rightarrow \mathrm{PC}$ |
| RTS | Return from subroutine | $\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{PPAGE},(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP},\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}}+1\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}}$, <br> $(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$ |
| RTC | Return from call | $\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{H}: \mathrm{PC}_{\mathrm{L}},(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$ |

### 4.3.19 Interrupt Instructions

Interrupt instructions handle transfer of control to and from interrupt service routines.
The SWI instruction initiates a software interrupt. It stacks the return address and the values in the CPU registers. Then execution begins at the address pointed to by the SWI vector.

The SWI instruction causes an interrupt without an interrupt request. The global mask bits I and X in the CCR do not inhibit SWI. SWI sets the I bit, inhibiting maskable interrupts until the I bit is cleared.

The TRAP instruction The CPU uses the software interrupt for unimplemented opcode trapping. There are opcodes in all 256 positions in the page 1 opcode map, but only 54 of the 256 positions on page 2 of the opcode map are used. If the CPU attempts to execute one of the unimplemented opcodes on page 2 , an opcode trap interrupt occurs. Traps are essentially interrupts that share the \$FFF8:\$FFF9 interrupt vector.
The RTI instruction is used to terminate all exception handlers, including interrupt service routines. RTI first restores the $\mathrm{CCR}, \mathrm{B}: \mathrm{A}, \mathrm{X}, \mathrm{Y}$, and the return address from the stack. If no other interrupt is pending, normal execution resumes with the instruction following the last instruction that executed prior to interrupt. A summary of the interrupt instructions is given in Table 4-24.

Table 4-24 Interrupt Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| RTI | Return from interrupt | $\begin{aligned} & \left(M_{S P}\right) \Rightarrow C C R,(S P)+\$ 0001 \Rightarrow S P \\ & \left(M_{S P}\right):\left(M_{S P}+1\right) \Rightarrow B: A,(S P)+\$ 0002 \Rightarrow S P \\ & \left(M_{S P}\right):\left(M_{S P}+1\right) \Rightarrow X_{H}: X_{L},(S P)+\$ 0004 \Rightarrow S P \\ & \left(M_{S P}\right):\left(M_{S P}+1\right) \Rightarrow P_{H}: P C_{L},(S P)+\$ 0002 \Rightarrow S P \\ & \left(M_{S P}\right):\left(M_{S P}+1\right) \Rightarrow Y_{H}: Y_{L},(S P)+\$ 0004 \Rightarrow S P \end{aligned}$ |
| SWI <br> TRAP | Software interrupt | $\begin{aligned} & (S P)-\$ 0002 \Rightarrow \text { SP, } \text { RTN }:\left(R T N_{L} \Rightarrow M_{S P}: M_{S P}+1\right. \\ & (S P)-\$ 0002 \Rightarrow S P,\left(Y_{H}\right):\left(Y_{L}\right) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,\left(X_{H}\right):\left(X_{L}\right) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,(B):(A) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0001 \Rightarrow S P,(C C R) \Rightarrow M_{S P}, 1 \Rightarrow 1 \end{aligned}$ |

### 4.3.20 Index Manipulation Instructions

Index manipulation instructions perform 8-bit and 16-bit operations on CPU registers or memory. A summary of the index manipulation instructions is given in Table 4-25.

Table 4-25 Index Manipulation Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| ABX | Add B to X | $(\mathrm{B})+(\mathrm{X}) \Rightarrow \mathrm{X}$ |
| ABY | Add B to Y | $(\mathrm{B})+(\mathrm{Y}) \Rightarrow \mathrm{Y}$ |
| CPS | Compare SP to memory | (SP) - (M):(M+1) |
| CPX | Compare X to memory | (X) - (M): $(M+1)$ |
| CPY | Compare Y to memory | (Y) - (M): $(\mathrm{M}+1)$ |
| LDS | Load SP from memory | (M): $(\mathrm{M}+1) \Rightarrow \mathrm{SP}$ |
| LDX | Load X from memory | (M): $(M+1) \Rightarrow X$ |
| LDY | Load Y from memory | (M):(M+1) $\Rightarrow Y$ |
| LEAS | Load effective address into SP | Effective address $\Rightarrow$ SP |
| LEAX | Load effective address into $X$ | Effective address $\Rightarrow \mathrm{X}$ |
| LEAY | Load effective address into Y | Effective address $\Rightarrow \mathrm{Y}$ |
| STS | Store SP in memory | (SP) $\Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| STX | Store X in memory | $(\mathrm{X}) \Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| STY | Store Y in memory | $(\mathrm{Y}) \Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| TFR | Transfer registers | (A, B, CCR, D, X, Y, or SP) $\Rightarrow \mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP |
| TSX | Transfer SP to X | $(\mathrm{SP}) \Rightarrow \mathrm{X}$ |
| TSY | Transfer SP to Y | $(\mathrm{SP}) \Rightarrow \mathrm{Y}$ |
| TXS | Transfer X to SP | $(\mathrm{X}) \Rightarrow \mathrm{SP}$ |
| TYS | Transfer Y to SP | $(\mathrm{Y}) \Rightarrow \mathrm{SP}$ |
| EXG | Exchange registers | $(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP$) \Leftrightarrow(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) |
| XGDX | Exchange D with X | (D) $\Leftrightarrow(\mathrm{X})$ |
| XGDY | Exchange D with Y | (D) $\Leftrightarrow(\mathrm{Y})$ |

### 4.3.21 Stacking Instructions

There are two types of stacking instructions:

- Stack pointer manipulation
- Stack operation (saving and retrieving CPU register contents)

A summary of the stacking instructions is given in Table 4-26.

Table 4-26 Stacking Instructions

| Function | Operation |
| :---: | :---: |
| Compare SP to memory | (SP) - (M):(M+1) |
| Decrement SP | $(\mathrm{SP})-\$ 0001 \Rightarrow$ SP |
| Increment SP | (SP) + \$0001 $\Rightarrow$ SP |
| Load SP | (M):(M + 1) $\Rightarrow$ SP |
| Load effective address into SP | Effective address $\Rightarrow$ SP |
| Store SP | (SP) $\Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| Transfer SP to X | $(\mathrm{SP}) \Rightarrow \mathrm{X}$ |
| Transfer SP to Y | $(\mathrm{SP}) \Rightarrow \mathrm{Y}$ |
| Transfer X to SP | $(\mathrm{X}) \Rightarrow \mathrm{SP}$ |
| Transfer Y to SP | $(\mathrm{Y}) \Rightarrow \mathrm{SP}$ |
| Push A | $(\mathrm{SP})-$ \$0001 $\Rightarrow \mathrm{SP},(\mathrm{A}) \Rightarrow \mathrm{M}_{\text {SP }}$ |
| Push B | $(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP},(\mathrm{B}) \Rightarrow \mathrm{M}_{\text {SP }}$ |
| Push CCR | $(\mathrm{SP})-\$ 0001 \Rightarrow S P,(C C R) \Rightarrow \mathrm{M}_{\text {SP }}$ |
| Push D | $(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},(\mathrm{A}):(\mathrm{B}) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ |
| Push X | (SP) - \$0002 $\Rightarrow$ SP, (X) $\Rightarrow \mathrm{M}_{\text {SP }}: \mathrm{M}_{\text {SP }+1}$ |
| Push Y | (SP) - \$0002 $\Rightarrow \mathrm{SP},(\mathrm{Y}) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ |
| Pull A | $\left.\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{A}, \mathrm{SP}\right)+1 \Rightarrow \mathrm{SP}$ |
| Pull B | $\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{B},(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ |
| Pull CCR | $\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{CCR},(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ |
| Pull D | $\left(M_{S P}\right):\left(M_{S P}+1\right) \Rightarrow A: B,(S P)+2 \Rightarrow S P$ |
| Pull X | $\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{X},(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ |
| Pull Y | $\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{Y},(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ |

### 4.3.22 Load Effective Address Instructions

Load effective address instructions add a constant or the value in an accumulator to the value in an index register, the stack pointer, or the program counter. The constant can be a 5-, 8-, or 16-bit value. The accumulator can be A, B, or D. A summary of the load effective address instructions is given in Table 4-27.

Table 4-27 Load Effective Address Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| LEAS | Load effective address into $S P$ | $(X),(Y),(\mathrm{SP})$, or $(\mathrm{PC}) \pm$ constant $\Rightarrow \mathrm{SP}$ <br> $(\mathrm{X},(\mathrm{Y}),(\mathrm{SP})$, or $(\mathrm{PC})+(\mathrm{A}, \mathrm{B}$, or D$) \Rightarrow \mathrm{SP}$ |
| LEAX | Load effective address into X | $(\mathrm{X}),(\mathrm{Y}),(\mathrm{SP})$, or (PC) $\pm$ constant $\Rightarrow \mathrm{X}$ <br> $(\mathrm{X}),(\mathrm{Y}),(\mathrm{SP})$, or (PC) $+(\mathrm{A}, \mathrm{B}$, or D$) \Rightarrow \mathrm{X}$ |
| LEAY | Load effective address into Y | $(\mathrm{X}),(\mathrm{Y}),(\mathrm{SP})$, or (PC) $\pm$ constant $\Rightarrow \mathrm{Y}$ <br> $(\mathrm{R})+(\mathrm{A}),(\mathrm{B})$, or (D) $\Rightarrow \mathrm{Y}$ |

### 4.3.23 Condition Code Instructions

A summary of the condition code instructions is given in Table 4-28.
Table 4-28 Condition Code Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| ANDCC | Logical AND CCR with immediate value | $(\mathrm{CCR}) \bullet$ imm $\Rightarrow \mathrm{CCR}$ |
| CLC | Clear C bit | $0 \Rightarrow \mathrm{C}$ |
| CLI | Clear I bit | $0 \Rightarrow \mathrm{I}$ |
| CLV | Clear V bit | $0 \Rightarrow \mathrm{~V}$ |
| ORCC | Logical OR CCR with immediate value | $(\mathrm{CCR})+\mathrm{imm} \Rightarrow \mathrm{CCR}$ |
| PSHC | Push CCR onto stack | $(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP},(\mathrm{CCR}) \Rightarrow \mathrm{M}_{\text {SP }}$ |
| PULC | Pull CCR from stack | $\left(\mathrm{M}_{\text {SP }}\right) \Rightarrow \mathrm{CCR},(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$ |
| SEC | Set C bit | $1 \Rightarrow \mathrm{C}$ |
| SEI | Set I bit | $1 \Rightarrow \mathrm{I}$ |
| SEV | Set V bit | $1 \Rightarrow \mathrm{~V}$ |
| TAP | Transfer $A$ to CCR | $(\mathrm{A}) \Rightarrow \mathrm{CCR}$ |
| TPA | Transfer CCR to $A$ | $(C C R) \Rightarrow \mathrm{A}$ |

### 4.3.24 STOP and WAI Instructions

The STOP and WAI instructions put the MCU in a standby state to reduce power consumption.
The STOP instruction stacks a return address and the values in the CPU registers, then stops all system clocks, halting program execution. A reset or an external interrupt request recovers the stacked values and restarts the system clocks, and program execution resumes.

The WAI instruction stacks a return address and the values in the CPU registers, then stops the CPU clocks, halting program execution. A reset or any enabled interrupt request recovers the stacked values and restarts the CPU clocks, and program execution resumes.

Although recovery from STOP or WAI takes the same number of clock cycles, restarting after STOP requires extra time for the oscillator to reach operating speed.

A summary of the STOP and WAI instructions is given in Table 4-29.
Table 4-29 STOP and WAI Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| STOP | Stop | $\begin{aligned} & (S P)-\$ 0002 \Rightarrow S P, R_{H}: R T N_{L} \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,\left(Y_{H}\right):\left(Y_{L}\right) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,\left(X_{H}\right):\left(X_{L}\right) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,(B):(A) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0001 \Rightarrow S P,(C C R) \Rightarrow M_{S P} \end{aligned}$ <br> Stop all clocks |
| WAI | Wait for interrupt | $\begin{aligned} & (S P)-\$ 0002 \Rightarrow S P, R_{H}: R T N_{L} \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,\left(Y_{H}\right):\left(Y_{L}\right) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,\left(X_{H}\right):\left(X_{L}\right) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0002 \Rightarrow S P,(B):(A) \Rightarrow M_{S P}: M_{S P}+1 \\ & (S P)-\$ 0001 \Rightarrow S P,(C C R) \Rightarrow M_{S P} \end{aligned}$ <br> Stop CPU clocks |

### 4.3.25 Background Mode and Null Operation Instructions

Executing the BGND instruction when BDM is enabled puts the MCU in background debug mode for system development and debugging.

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

A summary of the background mode and null operation instructions is given in Table 4-30.
Table 4-30 Background Mode and Null Operation Instructions

| Mnemonic | Function | Operation |
| :--- | :--- | :--- |
| BGND | Enter background debug mode | If BDM enabled, enter BDM, else resume normal processing |
| BRN | Branch never | Does not branch |
| LBRN | Long branch never | Does not branch |
| NOP | Null operation | Does nothing | Frtertscale Semiconductor, Inc.

### 4.4 High-Level Language Support

Many programmers are turning to high-level languages such as C as an alternative to coding in native assembly languages. High-level language (HLL) programming can improve productivity and produce code that is more easily maintained than assembly language programs. Historically, the most serious drawback to the use of HLL in microcontrollers has been the relatively large size of programs written in HLL. Larger program memory space size requirements translate into increased system costs.

Motorola solicited the cooperation of third-party software developers to assure that the HCS12 instruction set would meet the needs of a more efficient generation of compilers. Several features of the HCS12 were specifically designed to improve the efficiency of compiled HLL, and thus minimize cost.

This subsection identifies HCS12 instructions and addressing modes that provide improved support for high-level language. C language examples are provided to demonstrate how these features support efficient HLL structures and concepts. Since the HCS12 instruction set is a superset of the M68HC11 instruction set, some of the discussions use the M68HC11 as a basis for comparison.

### 4.4.1 Data Types

The HCS12 CPU supports the bit-sized data type with bit-manipulation instructions that are available in extended, direct, and indexed variations. The char data type is a simple 8 -bit value that is commonly used to specify variables in a small microcontroller system because it requires less memory space than a 16 -bit integer (provided the variable has a range small enough to fit into eight bits). The 16-bit HCS12 CPU can easily handle 16 -bit integer types and the set of conditional branches, including long branches, allows branching based on signed or unsigned arithmetic results. Some of the higher math functions allow for division and multiplication involving 32-bit values, although it is somewhat less common to use such long values in a microcontroller system.

Special sign-extension instructions allow easy type-casting from smaller data types to larger ones, such as from char to integer. This sign extension is automatically performed when an 8 -bit value is transferred to a 16-bit register.

### 4.4.2 Parameters and Variables

High-level languages make extensive use of the stack, both to pass variables and for temporary and local storage. It follows that there should be easy ways to push and pull all CPU registers, that stack pointer-based indexing should be allowed, and that direct arithmetic manipulation of the stack pointer value should be allowed. The HCS12 instruction set provides for all of these needs with improved indexed addressing, the addition of an LEAS instruction, and the addition of push and pull instructions for the D accumulator and the CCR.

### 4.4.2.1 Register Pushes and Pulls

The M68HC11 has push and pull instructions for A, B, X, and Y, but requires separate 8 -bit pushes and pulls of accumulators A and B to stack or unstack the $16-$ bit D accumulator (the concatenated combination $\mathrm{A}: \mathrm{B})$. The PSHD and PULD instructions allow directly stacking the D accumulator in the expected 16-bit order.

Adding PSHC and PULC improved orthogonality by completing the set of stacking instructions so that any of the CPU registers can be pushed or pulled. These instructions are also useful for preserving the CCR value during a function call subroutine.

### 4.4.2.2 Allocating and Deallocating Stack Space

The LEAS instruction can be used to allocate or deallocate space on the stack for temporary variables:

```
LEAS -10,S ;Allocate space for 5 16-bit integers
LEAS 10,S ;Deallocate space for 5 16-bit ints
```

The (de)allocation can even be combined with a register push or pull as in the following example:
LDX 8,S+ ;Load return value and deallocate
X is loaded with the 16-bit integer value at the top of the stack, and the stack pointer is adjusted up by eight to deallocate space for eight bytes' worth of temporary storage. Postincrement indexed addressing is used in this example, but all four combinations of pre/post increment/decrement are available (offsets from - 8 to +8 inclusive, from $\mathrm{X}, \mathrm{Y}$, or SP ). This form of indexing can often be used to get an index or stack pointer adjustment for free during an indexed operation: the instruction requires no more code space or cycles than a zero-offset indexed instruction.

### 4.4.2.3 Frame Pointer

In the C language, it is common to have a frame pointer in addition to the CPU stack pointer. The frame is an area of memory within the system stack which is used for parameters and local storage of variables used within a function subroutine. The following is a description of how a frame pointer can be set up and used.

First, parameters (typically values in CPU registers) are pushed onto the system stack prior to using a JSR or CALL to get to the function subroutine. At the beginning of the called subroutine, the frame pointer of the calling program is pushed onto the stack. Typically, an index register, such as X , is used as the frame pointer, so a PSHX instruction would save the frame pointer from the calling program.

Next, the called subroutine establishes a new frame pointer by executing a TFR S,X. Space is allocated for local variables by executing an LEAS $-\mathrm{n}, \mathrm{S}$, where n is the number of bytes needed for local variables.

Notice that parameters are at positive offsets from the frame pointer while locals are at negative offsets. In the M68HC11, the indexed addressing mode uses only positive offsets, so the frame pointer always points to the lowest address of any parameter or local. After the function subroutine finishes, calculations are required to restore the stack pointer to the midframe position between the locals and the parameters before returning to the calling program. The HCS12 CPU requires only the execution of TFR X,S to deallocate the local storage and return.

The concept of a frame pointer is supported in the HCS12 through a combination of improved indexed addressing, universal transfer/exchange, and the LEA instruction. These instructions work together to achieve more efficient handling of frame pointers. It is important to consider the complete instruction set as a complex system with subtle interrelationships rather than simply examining individual instructions when trying to improve an instruction set. Adding or removing a single instruction can have unexpected consequences.

### 4.4.3 Increment and Decrement Operators

In C, the notation ++i or $\mathrm{i}--$ is often used to form loop counters. Within limited constraints, the HCS12 loop primitives can speed up the loop-count-and-branch function.

The HCS12 includes a set of six basic loop-control instructions that decrement, increment, or test a loop-count register and then branch if the register is either equal to zero or not equal to zero. The loop-count register can be A, B, D, X, Y, or SP. A or B could be used if the loop count fits in an 8-bit char variable; the other choices are all 16-bit registers. The relative offset for the loop branch is a 9-bit signed value, so these instructions can be used with loops as long as 256 bytes.

In some cases, the pre- or postincrement operation can be combined with an indexed instruction to eliminate the cost of the increment operation. This is typically done by postcompile optimization because the indexed instruction that could absorb the increment/decrement operation may not be apparent at compile time.

### 4.4.4 Higher Math Functions

In the HCS12 CPU, subtle characteristics of higher math operations such as IDIVS and EMUL are arranged so a compiler can handle inputs and outputs more efficiently.

The most apparent case is the IDIVS instruction, which divides two 16-bit signed numbers to produce a 16-bit result. While the same function can be accomplished with the EDIVS instruction (a 32 by 16 divide), doing so is much less efficient because extra steps are required to prepare inputs to the EDIVS, and because EDIVS uses the Y index register. EDIVS uses a 32-bit signed numerator and the Compiler would typically want to use a 16-bit value (the size of an integer data type). The 16 -bit C value would need to be sign-extended into the upper 16-bits of the 32-bit EDIVS numerator before the divide operation.

Operand size is also a potential problem in the extended multiply operations but the difficulty can be minimized by putting the results in CPU registers. Having higher-precision math instructions is not necessarily a requirement for supporting high-level language because these functions can be performed as library functions. However, if an application requires these functions, the code is much more efficient if the CPU can use native instructions instead of relatively large, slow routines.

### 4.4.5 Conditional If Constructs

In the HCS12 instruction set, most arithmetic and data manipulation instructions automatically update the condition code register, unlike other architectures that only change condition codes during a few specific compare instructions. The HCS12 includes branch instructions that perform conditional branching based on the state of the indicators in the condition code register. Short branches use a single byte-relative offset that allows branching to a destination within about $\pm 128$ locations from the branch. Long branches use a 16 -bit relative offset that allows conditional branching to any location in the 64 K byte map.

### 4.4.6 Case and Switch Statements

Case and switch statements (and computed GOTOs) can use PC-relative indexed-indirect addressing to determine which path to take. Depending upon the situation, cases can use either the constant offset variation or the accumulator D offset variation of indexed-indirect addressing.

### 4.4.7 Pointers

The HCS12 supports pointers with direct arithmetic operations on the 16-bit index registers (LEAS, LEAX, and LEAY instructions) and with indexed-indirect addressing modes.

### 4.4.8 Function Calls

Bank switching is a common way of adapting a CPU with a 16-bit address bus to accommodate more than 64 K bytes of program memory space. One of the most significant drawbacks of this technique is the requirement of masking interrupts while the bank page value is being changed. Another problem is that the physical location of the bank page register can change from one system to another or even due to a change to mapping controls by a user program. In these situations, an operating system program has to keep track of the physical location of the page register. The HCS12 addresses both of these problems with the uninterruptible CALL and return from call (RTC) instructions.

The CALL instruction is similar to a JSR instruction, except that the programmer supplies a destination page value as part of the instruction. When CALL executes, the old page value is saved on the stack and the new page value is written to the bank page register. Since the CALL instruction is uninterruptible, this eliminates the need to separately mask off interrupts during the context switch.

The HCS12 has dedicated signal lines that allow the CPU to access the bank page register without having to use an address in the normal 64 K byte address space. This eliminates the need for the program to know where the page register is physically located.

The RTC instruction is similar to the RTS instruction, except that RTC uses the byte of information that was saved on the stack by the corresponding CALL instruction to restore the bank page register to its old value. A CALL/RTC pair can be used to access any function subroutine on any page. But when the called subroutine is on the current page or in an area of memory that is always visible, it is more efficient to access it with JSR/RTS instructions.

Push and pull instructions can be used to stack some or all the CPU registers during a function call. The HCS12 CPU can push and pull any of the CPU registers A, B, D, CCR, X, Y, or SP.

### 4.4.9 Instruction Set Orthogonality

One very helpful aspect of the HCS12 instruction set, orthogonality, is difficult to quantify in terms of direct benefit to an HLL compiler. Orthogonality refers to the regularity of the instruction set. A completely orthogonal instruction set would allow any instruction to operate in any addressing mode, would have identical code sizes and execution times for similar operations, and would include both signed and unsigned versions of all mathematical instructions. Greater regularity of the instruction set makes it
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.
possible to implement compilers more efficiently because operation is more consistent, and fewer special cases must be handled.


| $00{ }^{00}{ }^{5 G N D}$ | ANDCC | 20 BRA | ${ }_{\text {PULX }}^{30}{ }^{3}$ |  |  | NEG | $\begin{gathered} 70 \\ \text { NEG } \end{gathered}$ | SUBA | SUBA |  | $\underset{\text { SUBA }}{3}$ | SUBB | SU | $\begin{gathered} \text { EO } 3 / 4 / 6 \\ \text { SUBB } \end{gathered}$ | B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 31 | 4 |  |  | 4 |  | 3 |  | B1 3 |  | D1 3 |  |  |
|  |  |  |  |  |  | COM |  |  |  |  |  |  |  | CMPB |  |
| IH 1 | IH 1 | RL 2 | IH 1 | H | IH 1 | ID 2- | EX 3 | IM 2 | D | 2 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX 3 |
| $02$ |  | $22$ |  |  | 52 | $62$ | 4 | 8 | $92{ }_{\text {SBCA }}{ }^{3}$ | A2 | $\mathrm{B}_{\text {SBCA }}{ }^{3}$ | C2 | D2 | E2 3/4 | $\mathrm{F}_{\text {SBCB }}{ }^{3}$ |
|  | IH 1 | RL 2 | IH | IH 1 |  | ID | EX 3 | IM 2 | DI 2 | ID | EX | IM 2 | DI 2 | ID | EX 3 |
| $03{ }^{0}{ }^{1}$ | $3$ | $23$ |  | 43 | 53 | 63 DEC | 4 | 83 | $93{ }^{93}{ }^{3}$ | A3 | 3 | C3 | D3 | E3 | F3 ADDD ${ }^{3}$ |
| IH 1 | IH 1 | RL 2 | IH 1 | IH 1 | IH 1 | ID 2- | EX 3 | IM 3 | D | 2 | - | IM 3 | D | ID 2-4 | EX 3 |
| $04{ }^{0} 3$ | JR | $B C$ |  | LS | 54 | LSR | 4 | 84 | 94 ANDA ${ }^{3}$ | A4 | AN | C4 ${ }_{\text {ANDB }}$ | D4 ${ }^{\text {ANDB }}$ | E4 | ANDB |
| RL 3 | 2 | RL 2 | IH | IH 1 | IH | ID | EX 3 | IM 2 | DI 2 | ID 2- | X | , | I | ID | - |
| $05 \text { 3/4/6 }$ | 15 4/5/7 | $25 \quad 3 / 1$ |  | 45 | 55 | $\begin{gathered} 65 \text { 3- } \\ \text { ROL } \end{gathered}$ | 4 | $85$ | $95 \quad 3$ | A5 3/4 | BI | C5 BITB | D5 BITB | $\begin{array}{r} \text { E5 3/4 } \\ \text { BITB } \end{array}$ | F5 BITB |
| ID 2-4 | 2-4 | RL 2 | $\mathrm{IH} \quad 1$ | IH 1 | IH 1 | ID 2-4 | - 3 |  | D | ID 2- | EX | IM | D1 | ID | EX 3 |
| $3$ |  | $26 \quad 3 / 1$ |  |  |  | $66$ |  |  |  | A6 3/4/ | 6 | C6 | D6 | $\begin{array}{r} \text { E6 3/4 } \\ \text { LDAB } \end{array}$ | B |
| EX | EX 3 | RL | H | , | , | ID 2-4 | EX 3 | , | D1 2 | ID 2-4 | EX |  | DI 2 | ID | EX |
|  | $17 \underset{\text { JSR }}{ }{ }^{4}$ | $\begin{array}{cr} 27 & 3 / 1 \\ \text { BEQ } \end{array}$ |  |  |  |  |  |  |  |  | 7 ${ }^{\text {FR/EXG }}$ |  |  |  | F7 TST ${ }^{3}$ |
| RL 2 | D | RL | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | 1 H | IH | IH | ID 2 | EX |
|  | $18$ | $\begin{gathered} 28 \\ B V C \end{gathered}$ | 38 | 48 |  | $\begin{array}{ll} 68 & 3- \\ & \text { ASL } \end{array}$ |  | 88 | ${ }_{\text {EORA }}{ }^{3}$ |  | ${ }_{\text {EORA }}^{\text {EX }}$ | C8 | D8 EORB | E8 | $\mathrm{EORB}^{3}$ |
| IH |  | RL | IH | IH 1 | IH | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI 2 | ID 2- | EX 3 |
| DEX | $19$ <br> LE | $\begin{gathered} 29 \\ \text { BVS } \end{gathered}$ | 39 | 49 | 59 | 69 | 3 | 89 | 99 ADCA | A9 3/4 | B9 ADCA | C9 ${ }^{\text {ADCB }}$ | D9 ADCB | $\begin{array}{r} \mathrm{E} 93 / 4 \\ \mathrm{ADC} \end{array}$ | ADCB |
| IH 1 | ID 2-4 | R | IH 1 | IH | IH | ID 2- | EX | IM | DI 2 | ID 2- | EX | IM | DI 2 | D 2-4 | EX 3 |
| 0A RTC | 1A | $2 \mathrm{~A}$ | 3A | $4 \mathrm{~A}$ $\mathrm{CA}$ | $5 A$ ST | $\begin{array}{r} 6 A \\ \text { STA } \end{array}$ | ${ }_{\text {7A STAA }}{ }^{3}$ | 8A ORAA | 9A ORAA | AA 3/4 | ORAA | CA | DA ORAB | $\begin{gathered} \text { EA 3/ } \\ \text { ORA } \end{gathered}$ | ARAB |
| IH | ID 2-4 | RL | IH | EX | DI | ID 2- | EX 3 | IM | DI | ID 2- | 3 | M | DI | ID 2- | EX 3 |
| $\begin{array}{\|rr} \hline 0 \mathrm{~B} & 8 / \\ \mathrm{RTI} \end{array}$ | 1B LEAS ${ }^{2}$ | ${ }_{\mathrm{BI}}^{2 \mathrm{~B}}$ |  | 4B 7/8/10 |  | 6B 2 ${ }^{\text {STAB }}$ |  |  | 9B ADDA ${ }^{3}$ | AB 3/4 | ADDA | CB ${ }^{\text {ADDB }}$ | DB ADDB | A 3/4 | B |
| IH | ID 2-4 | RL | IH | ID 2-5 | D | ID | EX 3 | IM | DI 2 | ID 2- | E | IM | DI | D 2 | EX 3 |
| $\begin{gathered} 0 \mathrm{OC} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | ${ }^{1 \mathrm{C}} \mathrm{BSET}^{4}$ | BGE | 3C |  |  | 6C ${ }^{2}$ |  | 8C | $9 \mathrm{CPD}{ }^{3}$ | D | $\mathrm{BC} \mathrm{CPD}^{3}$ | CC | DC LDD | $\begin{gathered} \text { EC } 3 / 4 \\ \text { LDD } \end{gathered}$ | LD |
| ID 3-5 | EX | RL | SP | DI | DI | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI | D 2- |  |
| OD 4/6 | 1D ${ }_{\text {BCLR }}{ }^{4}$ | 2D $\begin{gathered}\text { BLT }\end{gathered}$ | 3D | 4D ${ }_{\text {BCLR }}{ }^{4}$ | 5D | 6D ${ }^{2-}$ STY | 7D 3 | 8D |  | D 3/4 | BD | CD | DD LDY | $\begin{gathered} \text { D 3/4 } \\ \text { LDY } \end{gathered}$ | FD ${ }_{\text {LDY }}{ }^{3}$ |
| ID 3-5 | EX | RL | IH | DI | DI | ID | EX 3 | IM | DI 2 | D 2-4 | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OE 4-6 | 1E 5 | 2E 3 3 | 3E | 4E ${ }_{\text {BRSET }}$ | 5E | 6E ${ }^{\text {STX }}$ | F 3 | 8E | 9E 3 | AE 3/4 | BE 3 | CE LDX | DE LDX ${ }^{3}$ | EE 3/4 | - 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI 2 | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OF ${ }_{\text {BRCLR }}$ | $\begin{array}{cc}1 F & 5 \\ \text { BRCLR }\end{array}$ | 2F 3LE | 3F | 4F ${ }_{\text {BRCLR }}$ | 5F STS | ${ }^{6 F}$ STS | F 3 |  | ${ }^{9 F} \mathrm{CPS} 3$ | CPS | $\mathrm{BF}^{\text {CPS }}$ | CF | DF LDS ${ }^{3}$ | LDS | F 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE.Address mode abbreviations: DI direct 1 H - inherent SP - specialEX— extended IM - immediate |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $00{ }^{00}{ }^{5 G N D}$ | ANDCC | 20 BRA | ${ }_{\text {PULX }}^{30}{ }^{3}$ |  |  | NEG | $\begin{gathered} 70 \\ \text { NEG } \end{gathered}$ | SUBA | SUBA |  | $\underset{\text { SUBA }}{3}$ | SUBB | SU | $\begin{gathered} \text { EO } 3 / 4 / 6 \\ \text { SUBB } \end{gathered}$ | B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 31 | 4 |  |  | 4 |  | 3 |  | B1 3 |  | D1 3 |  |  |
|  |  |  |  |  |  | COM |  |  |  |  |  |  |  | CMPB |  |
| IH 1 | IH 1 | RL 2 | IH 1 | H | IH 1 | ID 2- | EX 3 | IM 2 | D | 2 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX 3 |
| $02$ |  | $22$ |  |  | 52 | $62$ | 4 | 8 | $92{ }_{\text {SBCA }}{ }^{3}$ | A2 | $\mathrm{B}_{\text {SBCA }}{ }^{3}$ | C2 | D2 | E2 3/4 | $\mathrm{F}_{\text {SBCB }}{ }^{3}$ |
|  | IH 1 | RL 2 | IH | IH 1 |  | ID | EX 3 | IM 2 | DI 2 | ID | EX | IM 2 | DI 2 | ID | EX 3 |
| $03{ }^{0}{ }^{1}$ | $3$ | $23$ |  | 43 | 53 | 63 DEC | 4 | 83 | $93{ }^{93}{ }^{3}$ | A3 | 3 | C3 | D3 | E3 | F3 ADDD ${ }^{3}$ |
| IH 1 | IH 1 | RL 2 | IH 1 | IH 1 | IH 1 | ID 2- | EX 3 | IM 3 | D | 2 | - | IM 3 | D | ID 2-4 | EX 3 |
| $04{ }^{0} 3$ | JR | $B C$ |  | LS | 54 | LSR | 4 | 84 | 94 ANDA ${ }^{3}$ | A4 | AN | C4 ${ }_{\text {ANDB }}$ | D4 ${ }^{\text {ANDB }}$ | E4 | ANDB |
| RL 3 | 2 | RL 2 | IH | IH 1 | IH | ID | EX 3 | IM 2 | DI 2 | ID 2- | X | , | I | ID | - |
| $05 \text { 3/4/6 }$ | 15 4/5/7 | $25 \quad 3 / 1$ |  | 45 | 55 | $\begin{gathered} 65 \text { 3- } \\ \text { ROL } \end{gathered}$ | 4 | $85$ | $95 \quad 3$ | A5 3/4 | BI | C5 BITB | D5 BITB | $\begin{array}{r} \text { E5 3/4 } \\ \text { BITB } \end{array}$ | F5 BITB |
| ID 2-4 | 2-4 | RL 2 | $\mathrm{IH} \quad 1$ | IH 1 | IH 1 | ID 2-4 | - 3 |  | D | ID 2- | EX | IM | D1 | ID | EX 3 |
| $3$ |  | $26 \quad 3 / 1$ |  |  |  | $66$ |  |  |  | A6 3/4/ | 6 | C6 | D6 | $\begin{array}{r} \text { E6 3/4 } \\ \text { LDAB } \end{array}$ | B |
| EX | EX 3 | RL | H | , | , | ID 2-4 | EX 3 | , | D1 2 | ID 2-4 | EX |  | DI 2 | ID | EX |
|  | $17 \underset{\text { JSR }}{ }{ }^{4}$ | $\begin{array}{cr} 27 & 3 / 1 \\ \text { BEQ } \end{array}$ |  |  |  |  |  |  |  |  | 7 ${ }^{\text {FR/EXG }}$ |  |  |  | F7 TST ${ }^{3}$ |
| RL 2 | D | RL | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | 1 H | IH | IH | ID 2 | EX |
|  | $18$ | $\begin{gathered} 28 \\ B V C \end{gathered}$ | 38 | 48 |  | $\begin{array}{ll} 68 & 3- \\ & \text { ASL } \end{array}$ |  | 88 | ${ }_{\text {EORA }}{ }^{3}$ |  | ${ }_{\text {EORA }}^{\text {EX }}$ | C8 | D8 EORB | E8 | $\mathrm{EORB}^{3}$ |
| IH |  | RL | IH | IH 1 | IH | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI 2 | ID 2- | EX 3 |
| DEX | $19$ <br> LE | $\begin{gathered} 29 \\ \text { BVS } \end{gathered}$ | 39 | 49 | 59 | 69 | 3 | 89 | 99 ADCA | A9 3/4 | B9 ADCA | C9 ${ }^{\text {ADCB }}$ | D9 ADCB | $\begin{array}{r} \mathrm{E} 93 / 4 \\ \mathrm{ADC} \end{array}$ | ADCB |
| IH 1 | ID 2-4 | R | IH 1 | IH | IH | ID 2- | EX | IM | DI 2 | ID 2- | EX | IM | DI 2 | D 2-4 | EX 3 |
| 0A RTC | 1A | $2 \mathrm{~A}$ | 3A | $4 \mathrm{~A}$ $\mathrm{CA}$ | $5 A$ ST | $\begin{array}{r} 6 A \\ \text { STA } \end{array}$ | ${ }_{\text {7A STAA }}{ }^{3}$ | 8A ORAA | 9A ORAA | AA 3/4 | ORAA | CA | DA ORAB | $\begin{gathered} \text { EA 3/ } \\ \text { ORA } \end{gathered}$ | ARAB |
| IH | ID 2-4 | RL | IH | EX | DI | ID 2- | EX 3 | IM | DI | ID 2- | 3 | M | DI | ID 2- | EX 3 |
| $\begin{array}{\|rr} \hline 0 \mathrm{~B} & 8 / \\ \mathrm{RTI} \end{array}$ | 1B LEAS ${ }^{2}$ | ${ }_{\mathrm{BI}}^{2 \mathrm{~B}}$ |  | 4B 7/8/10 |  | 6B 2 ${ }^{\text {STAB }}$ |  |  | 9B ADDA ${ }^{3}$ | AB 3/4 | ADDA | CB ${ }^{\text {ADDB }}$ | DB ADDB | A 3/4 | B |
| IH | ID 2-4 | RL | IH | ID 2-5 | D | ID | EX 3 | IM | DI 2 | ID 2- | E | IM | DI | D 2 | EX 3 |
| $\begin{gathered} 0 \mathrm{OC} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | ${ }^{1 \mathrm{C}} \mathrm{BSET}^{4}$ | BGE | 3C |  |  | 6C ${ }^{2}$ |  | 8C | $9 \mathrm{CPD}{ }^{3}$ | D | $\mathrm{BC} \mathrm{CPD}^{3}$ | CC | DC LDD | $\begin{gathered} \text { EC } 3 / 4 \\ \text { LDD } \end{gathered}$ | LD |
| ID 3-5 | EX | RL | SP | DI | DI | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI | D 2- |  |
| OD 4/6 | 1D ${ }_{\text {BCLR }}{ }^{4}$ | 2D $\begin{gathered}\text { BLT }\end{gathered}$ | 3D | 4D ${ }_{\text {BCLR }}{ }^{4}$ | 5D | 6D ${ }^{2-}$ STY | 7D 3 | 8D |  | D 3/4 | BD | CD | DD LDY | $\begin{gathered} \text { D 3/4 } \\ \text { LDY } \end{gathered}$ | FD ${ }_{\text {LDY }}{ }^{3}$ |
| ID 3-5 | EX | RL | IH | DI | DI | ID | EX 3 | IM | DI 2 | D 2-4 | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OE 4-6 | 1E 5 | 2E 3 3 | 3E | 4E ${ }_{\text {BRSET }}$ | 5E | 6E ${ }^{\text {STX }}$ | F 3 | 8E | 9E 3 | AE 3/4 | BE 3 | CE LDX | DE LDX ${ }^{3}$ | EE 3/4 | - 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI 2 | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OF ${ }_{\text {BRCLR }}$ | $\begin{array}{cc}1 F & 5 \\ \text { BRCLR }\end{array}$ | 2F 3LE | 3F | 4F ${ }_{\text {BRCLR }}$ | 5F STS | ${ }^{6 F}$ STS | F 3 |  | ${ }^{9 F} \mathrm{CPS} 3$ | CPS | $\mathrm{BF}^{\text {CPS }}$ | CF | DF LDS ${ }^{3}$ | LDS | F 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE.Address mode abbreviations: DI direct 1 H - inherent SP - specialEX— extended IM - immediate |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $00{ }^{00}{ }^{5 G N D}$ | ANDCC | 20 BRA | ${ }_{\text {PULX }}^{30}{ }^{3}$ |  |  | NEG | $\begin{gathered} 70 \\ \text { NEG } \end{gathered}$ | SUBA | SUBA |  | $\underset{\text { SUBA }}{3}$ | SUBB | SU | $\begin{gathered} \text { EO } 3 / 4 / 6 \\ \text { SUBB } \end{gathered}$ | B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 31 | 4 |  |  | 4 |  | 3 |  | B1 3 |  | D1 3 |  |  |
|  |  |  |  |  |  | COM |  |  |  |  |  |  |  | CMPB |  |
| IH 1 | IH 1 | RL 2 | IH 1 | H | IH 1 | ID 2- | EX 3 | IM 2 | D | 2 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX 3 |
| $02$ |  | $22$ |  |  | 52 | $62$ | 4 | 8 | $92{ }_{\text {SBCA }}{ }^{3}$ | A2 | $\mathrm{B}_{\text {SBCA }}{ }^{3}$ | C2 | D2 | E2 3/4 | $\mathrm{F}_{\text {SBCB }}{ }^{3}$ |
|  | IH 1 | RL 2 | IH | IH 1 |  | ID | EX 3 | IM 2 | DI 2 | ID | EX | IM 2 | DI 2 | ID | EX 3 |
| $03{ }^{0}{ }^{1}$ | $3$ | $23$ |  | 43 | 53 | 63 DEC | 4 | 83 | $93{ }^{93}{ }^{3}$ | A3 | 3 | C3 | D3 | E3 | F3 ADDD ${ }^{3}$ |
| IH 1 | IH 1 | RL 2 | IH 1 | IH 1 | IH 1 | ID 2- | EX 3 | IM 3 | D | 2 | - | IM 3 | D | ID 2-4 | EX 3 |
| $04{ }^{0} 3$ | JR | $B C$ |  | LS | 54 | LSR | 4 | 84 | 94 ANDA ${ }^{3}$ | A4 | AN | C4 ${ }_{\text {ANDB }}$ | D4 ${ }^{\text {ANDB }}$ | E4 | ANDB |
| RL 3 | 2 | RL 2 | IH | IH 1 | IH | ID | EX 3 | IM 2 | DI 2 | ID 2- | X | , | I | ID | - |
| $05 \text { 3/4/6 }$ | 15 4/5/7 | $25 \quad 3 / 1$ |  | 45 | 55 | $\begin{gathered} 65 \text { 3- } \\ \text { ROL } \end{gathered}$ | 4 | $85$ | $95 \quad 3$ | A5 3/4 | BI | C5 BITB | D5 BITB | $\begin{array}{r} \text { E5 3/4 } \\ \text { BITB } \end{array}$ | F5 BITB |
| ID 2-4 | 2-4 | RL 2 | $\mathrm{IH} \quad 1$ | IH 1 | IH 1 | ID 2-4 | - 3 |  | D | ID 2- | EX | IM | D1 | ID | EX 3 |
| $3$ |  | $26 \quad 3 / 1$ |  |  |  | $66$ |  |  |  | A6 3/4/ | 6 | C6 | D6 | $\begin{array}{r} \text { E6 3/4 } \\ \text { LDAB } \end{array}$ | B |
| EX | EX 3 | RL | H | , | , | ID 2-4 | EX 3 | , | D1 2 | ID 2-4 | EX |  | DI 2 | ID | EX |
|  | $17 \underset{\text { JSR }}{ }{ }^{4}$ | $\begin{array}{cr} 27 & 3 / 1 \\ \text { BEQ } \end{array}$ |  |  |  |  |  |  |  |  | 7 ${ }^{\text {FR/EXG }}$ |  |  |  | F7 TST ${ }^{3}$ |
| RL 2 | D | RL | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | 1 H | IH | IH | ID 2 | EX |
|  | $18$ | $\begin{gathered} 28 \\ B V C \end{gathered}$ | 38 | 48 |  | $\begin{array}{ll} 68 & 3- \\ & \text { ASL } \end{array}$ |  | 88 | ${ }_{\text {EORA }}{ }^{3}$ |  | ${ }_{\text {EORA }}^{\text {EX }}$ | C8 | D8 EORB | E8 | $\mathrm{EORB}^{3}$ |
| IH |  | RL | IH | IH 1 | IH | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI 2 | ID 2- | EX 3 |
| DEX | $19$ <br> LE | $\begin{gathered} 29 \\ \text { BVS } \end{gathered}$ | 39 | 49 | 59 | 69 | 3 | 89 | 99 ADCA | A9 3/4 | B9 ADCA | C9 ${ }^{\text {ADCB }}$ | D9 ADCB | $\begin{array}{r} \mathrm{E} 93 / 4 \\ \mathrm{ADC} \end{array}$ | ADCB |
| IH 1 | ID 2-4 | R | IH 1 | IH | IH | ID 2- | EX | IM | DI 2 | ID 2- | EX | IM | DI 2 | D 2-4 | EX 3 |
| 0A RTC | 1A | $2 \mathrm{~A}$ | 3A | $4 \mathrm{~A}$ $\mathrm{CA}$ | $5 A$ ST | $\begin{array}{r} 6 A \\ \text { STA } \end{array}$ | ${ }_{\text {7A STAA }}{ }^{3}$ | 8A ORAA | 9A ORAA | AA 3/4 | ORAA | CA | DA ORAB | $\begin{gathered} \text { EA 3/ } \\ \text { ORA } \end{gathered}$ | ARAB |
| IH | ID 2-4 | RL | IH | EX | DI | ID 2- | EX 3 | IM | DI | ID 2- | 3 | M | DI | ID 2- | EX 3 |
| $\begin{array}{\|rr} \hline 0 \mathrm{~B} & 8 / \\ \mathrm{RTI} \end{array}$ | 1B LEAS ${ }^{2}$ | ${ }_{\mathrm{BI}}^{2 \mathrm{~B}}$ |  | 4B 7/8/10 |  | 6B 2 ${ }^{\text {STAB }}$ |  |  | 9B ADDA ${ }^{3}$ | AB 3/4 | ADDA | CB ${ }^{\text {ADDB }}$ | DB ADDB | A 3/4 | B |
| IH | ID 2-4 | RL | IH | ID 2-5 | D | ID | EX 3 | IM | DI 2 | ID 2- | E | IM | DI | D 2 | EX 3 |
| $\begin{gathered} 0 \mathrm{OC} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | ${ }^{1 \mathrm{C}} \mathrm{BSET}^{4}$ | BGE | 3C |  |  | 6C ${ }^{2}$ |  | 8C | $9 \mathrm{CPD}{ }^{3}$ | D | $\mathrm{BC} \mathrm{CPD}^{3}$ | CC | DC LDD | $\begin{gathered} \text { EC } 3 / 4 \\ \text { LDD } \end{gathered}$ | LD |
| ID 3-5 | EX | RL | SP | DI | DI | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI | D 2- |  |
| OD 4/6 | 1D ${ }_{\text {BCLR }}{ }^{4}$ | 2D $\begin{gathered}\text { BLT }\end{gathered}$ | 3D | 4D ${ }_{\text {BCLR }}{ }^{4}$ | 5D | 6D ${ }^{2-}$ STY | 7D 3 | 8D |  | D 3/4 | BD | CD | DD LDY | $\begin{gathered} \text { D 3/4 } \\ \text { LDY } \end{gathered}$ | FD ${ }_{\text {LDY }}{ }^{3}$ |
| ID 3-5 | EX | RL | IH | DI | DI | ID | EX 3 | IM | DI 2 | D 2-4 | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OE 4-6 | 1E 5 | 2E 3 3 | 3E | 4E ${ }_{\text {BRSET }}$ | 5E | 6E ${ }^{\text {STX }}$ | F 3 | 8E | 9E 3 | AE 3/4 | BE 3 | CE LDX | DE LDX ${ }^{3}$ | EE 3/4 | - 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI 2 | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OF ${ }_{\text {BRCLR }}$ | $\begin{array}{cc}1 F & 5 \\ \text { BRCLR }\end{array}$ | 2F 3LE | 3F | 4F ${ }_{\text {BRCLR }}$ | 5F STS | ${ }^{6 F}$ STS | F 3 |  | ${ }^{9 F} \mathrm{CPS} 3$ | CPS | $\mathrm{BF}^{\text {CPS }}$ | CF | DF LDS ${ }^{3}$ | LDS | F 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE.Address mode abbreviations: DI direct 1 H - inherent SP - specialEX— extended IM - immediate |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



| BGN | $\begin{aligned} & 10 \quad 1 \\ & \text { ANDCC } \end{aligned}$ | ${ }_{\text {BRA }}^{20}{ }^{3}$ | $\begin{aligned} & 30 \\ & \text { PUL } \end{aligned}$ | $\begin{aligned} & 40 \\ & \text { NEGA } \end{aligned}$ | $\begin{aligned} & 50 \\ & \text { NEGB } \end{aligned}$ | $\begin{aligned} & \text { NEG } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { NEG } \\ & \text { EX } \end{aligned}$ | SUBA | SUBA |  | $\begin{gathered} \text { SUBA } \\ \text { EX } \end{gathered}$ | SUBB | SUBB | $\begin{gathered} 3 / 4 / 6 \\ B B \\ 3-4 \\ \hline 2 \end{gathered}$ | $\left\lvert\, \begin{array}{cc} \mathrm{FO} & 3 \\ \text { SUBB } \\ \text { EX } & 3 \end{array}\right.$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | IM 2 | RL | IH | IH | IH 1 | ID 2-4 | EX | IM 2 | DI | ID | EX 3 | IM 2 | 2 |  |  |
| ${ }^{01} \mathrm{ME}$ | ${ }^{11}{ }^{\text {EDIV }}{ }^{11}$ | 21 | $\begin{gathered} 31 \\ \text { PU } \end{gathered}$ | $41$ | $51$ | ${ }^{61} \mathrm{CC}$ | 71 | $\begin{gathered} 81 \\ \text { CI } \end{gathered}$ | $\begin{gathered} 91 \\ \text { CN } \end{gathered}$ | A1 | ${ }^{\text {B1 }}$ | $\begin{gathered} \mathrm{C} 1 \\ \mathrm{CN} \end{gathered}$ | D1 | E1 3/4/6 | F1 |
|  | IH 1 | RL 2 |  |  |  | D 2-4 | EX 3 | IM 2 | DI 2 | ID 2- | X | IM 2 | DI 2 |  |  |
| $02_{\mathrm{INY}}{ }^{1}$ | ${ }^{12}$ | $22$ | $\begin{gathered} 32 \\ \mathrm{PL} \end{gathered}$ | $42$ | $\begin{gathered} 52 \\ \\ \hline N \end{gathered}$ | $62$ |  | $\begin{gathered} 82 \\ \text { SB } \end{gathered}$ | $92$ | $\begin{gathered} \text { A2 } \\ \text { SB } \end{gathered}$ | B2 | $\begin{gathered} \mathrm{C} 2 \\ \mathrm{SBCB} \end{gathered}$ | $\begin{aligned} & \mathrm{D} 2 \\ & \mathrm{SBCB} \end{aligned}$ | $\begin{gathered} \text { E2 } 3 / 4 / 6 \\ \text { SBCB } \end{gathered}$ | F2 |
|  | IH | RL 2 |  |  |  | D 2- | EX 3 | M 2 | DI | ID 2-4 | EX | M | DI 2 |  |  |
| ${ }^{03} \mathrm{DE}$ | ${ }_{E M U L}^{3}$ | $233^{3}$ | $\begin{gathered} 33 \\ \text { PU } \end{gathered}$ | $43$ | $53$ | $63$ | $\begin{gathered} 73 \text { DEC } \end{gathered}$ | $\begin{gathered} 83 \\ \mathrm{SL} \end{gathered}$ | $\begin{gathered} 93 \\ \text { SU } \end{gathered}$ | $\begin{gathered} \text { A3 } \\ \text { SU } \end{gathered}$ | $\begin{gathered} \text { B3 } \\ \text { SU } \end{gathered}$ | C3 | ${ }_{\text {ADDD }}{ }^{3}$ | $\begin{gathered} \text { E3 } 3 / 4 / 6 \\ \text { ADDD } \end{gathered}$ | ${ }^{\text {F3 }}{ }^{3}{ }^{3}$ |
|  | 1 | RL | IH | IH 1 | IH 1 | ID 2-4 | EX 3 | M | DI | ID | EX | IM | DI |  | EX 3 |
| $\begin{aligned} & 04 \text { loop } \\ & \end{aligned}$ | $14$ | $24$ |  | $\begin{gathered} 44 \\ \text { LS } \end{gathered}$ | $\begin{gathered} 54 \\ \text { LS } \end{gathered}$ | $64$ | LS | $\begin{gathered} 84 \\ \text { AN } \end{gathered}$ | $94$ | $\begin{array}{r} \text { A4 } 3 \\ \text { AND } \end{array}$ | $\begin{gathered} \mathrm{B} 4 \\ \mathrm{AN} \end{gathered}$ | $\begin{gathered} \mathrm{C} 4 \\ \mathrm{AN} \end{gathered}$ | $\begin{gathered} \text { D4 }{ }^{3} \\ \text { ANDB } \end{gathered}$ | $\begin{gathered} \text { E4 } 3 / 4 / 6 \\ \text { ANDB } \end{gathered}$ | $\begin{gathered} \text { F4 } \\ \text { AI } \end{gathered}$ |
| RL 3 | M | RL | IH | IH 1 | IH 1 | ID 2-4 | EX 3 | M | DI | ID | EX | IM | DI | ID | X |
|  | $15 \text { 4/5/7 }$ | $\begin{gathered} 25 \mathrm{BCS} \end{gathered}$ | $\begin{gathered} 35 \\ P S \end{gathered}$ | $45$ | $55$ | $65$ |  | $85$ | $95 \text { BITA }$ | $\begin{array}{r} \text { A5 } 3 / 4 \\ \text { BITA } \end{array}$ | $\underset{\mathrm{BITA}}{\mathrm{~B}}$ | ${ }^{\mathrm{C} 5}$ | ${ }^{\text {D5 }}$ | $\begin{gathered} \text { E5 } 3 / 4 / 6 \\ \text { BITB } \end{gathered}$ | $\begin{aligned} & \text { F5 } \\ & \text { BITB } \end{aligned}$ |
| ID | ID 2-4 | RL | IH | IH | IH | ID | EX | IM 2 | DI | ID | EX | IM | DI | ID | EX 3 |
| $06{ }^{3}{ }^{3}$ | ${ }^{16} \text { JSR }$ | $26$ | $\begin{gathered} 36 \\ \text { PS } \end{gathered}$ | $\begin{gathered} 46 \\ \mathrm{RO} \end{gathered}$ | $\begin{gathered} 56 \\ \text { RC } \end{gathered}$ | $66$ |  | $86$ | $96{ }_{\text {LDAA }}^{3}$ | A6 | ${ }^{\mathrm{B} 6}{ }_{\text {LDAA }}$ | C6 LDAB | D6 LDAB | E6 3/4/6 | $\mathrm{F}^{\mathrm{LDAB}}{ }^{3}$ |
| EX 3 | EX 3 | RL | IH | IH | IH | ID | EX | M | DI | ID 2- | EX | IM | DI |  | X |
| $07_{\text {BSR }}{ }^{4}$ | $17{ }^{\prime}$ | $\begin{gathered} 273 / 1 \\ B E Q \end{gathered}$ | $\begin{gathered} 37 \\ \text { PS } \end{gathered}$ | $\begin{gathered} 47 \\ \text { AS } \end{gathered}$ | $\stackrel{57}{ } \quad \text { ASRB }$ | $\begin{gathered} 67 \\ \text { As } \end{gathered}$ |  |  | $97$ | ${ }^{\mathrm{A} 7} \mathrm{NC}$ | $\begin{array}{\|l\|} \hline \text { B7 } \\ \text { TFR/EXG } \end{array}$ | ${ }^{\mathrm{C}} \mathrm{CLRB}^{1}$ | $\begin{aligned} & \text { D7 } \\ & \text { TSTB } \end{aligned}$ | $\begin{array}{r} \text { E7 } 3 / 4 \\ \text { TST } \end{array}$ | ${ }^{\mathrm{F7}}{ }_{\mathrm{TST}}$ |
| RL 2 | DI 2 | RL | IH | IH | IH | ID | EX 3 | IH 1 | IH | IH |  | 1 H | IH | ID |  |
| $8$ | $\begin{gathered} 18 \\ \text { pag } \end{gathered}$ | $\begin{array}{r} 28 \\ 3 \\ \text { BVC } \end{array}$ | $\begin{gathered} 38 \\ \text { PUU } \end{gathered}$ | $48$ | $58$ | $68 \text { ASL }$ |  | $88$ | ${ }_{\text {EORA }}{ }^{3}$ |  |  | C8 EORB | ${ }_{\text {EORB }}{ }^{3}$ | $\begin{gathered} \text { E8 } 3 / 4 / 6 \\ \text { EORB } \end{gathered}$ | $\text { F8 }{ }^{\text {EORB }}{ }^{3}$ |
| IH 1 |  | RL | IH 1 | IH 1 | IH | ID | EX | IM 2 | DI | ID | EX 3 | IM | DI 2 | ID | EX 3 |
| $09{ }^{0}{ }^{1}$ | $19{ }^{19}{ }^{2}$ | $\begin{array}{r} 29 \\ \text { BVS } \end{array}$ | $\begin{gathered} 39 \\ \text { PSF } \end{gathered}$ | $49$ | $\stackrel{59}{\mathrm{AS}}$ | $\begin{gathered} 69 \\ \text { CLR } \end{gathered}$ | ${ }^{79} \mathrm{CL}$ | $89$ | $99$ | $\begin{gathered} \text { A9 3/4/6 } \\ \text { ADCA } \end{gathered}$ | $\mathrm{B9}_{\mathrm{ADCA}}{ }^{3}$ | $\begin{gathered} \mathrm{C} 9 \\ \text { ADCB } \end{gathered}$ | D9 | $\begin{gathered} \mathrm{E} 93 / 4 / 6 \\ \text { ADCB } \end{gathered}$ |  |
| 1 H | ID 2-4 | RL | IH | IH | IH | ID | EX | IM | DI | ID | EX | IM | DI 2 | ID | EX 3 |
| $\begin{gathered} 0 A^{7}{ }^{7} \end{gathered}$ | $\begin{aligned} & \text { 1A } \\ & \text { LEA } \end{aligned}$ | $\begin{gathered} 2 \mathrm{~A} 3^{3} \\ \mathrm{BPL} \end{gathered}$ | 3A | $4 \mathrm{CAl}$ | $\begin{aligned} & \text { 5A } \\ & \text { STAA } \end{aligned}$ | $\begin{gathered} 6 A^{2-1} \\ \text { STAA } \end{gathered}$ |  |  |  | AA 3/4/6 |  | CA | DA | EA 3/4/ | FA ORAB ${ }^{3}$ |
| IH 1 | ID 2-4 | RL | IH | EX | DI | ID | EX | IM | DI | ID | EX | IM | DI | ID | EX |
| $\begin{array}{r} 0 \mathrm{~B} \quad 8 / \\ \text { RTI } \end{array}$ | ${ }_{\text {LEAS }}{ }^{2}$ | $\begin{array}{r} 2 \mathrm{~B} 3 \\ \mathrm{BMI} \end{array}$ | $\begin{gathered} \text { 3B } \\ \text { PSHD } \end{gathered}$ | 4B 7/8/1 | $\begin{aligned} & \text { 5B } \\ & \text { STAB } \end{aligned}$ | $\begin{aligned} & 6 B{ }^{2-} \\ & \text { STAB } \end{aligned}$ | $\begin{aligned} & 7 \mathrm{~B} \\ & \text { STAB } \end{aligned}$ | 8B ${ }^{\text {ADDA }}$ | 9B ${ }^{\text {ADDA }}$ | AB 3/4/6 ADDA | BB ${ }^{\text {ADDA }}$ | CB | DB ADDB | EB 3/4 | $\begin{array}{\|c\|} \hline \mathrm{FB} \quad 3 \\ \text { ADDB }^{3} \end{array}$ |
| IH | ID 2-4 | RL | IH | ID 2-5 | DI | ID | EX | I | DI | ID | EX | M | DI | ID | E |
| $\begin{gathered} 0 \mathrm{C} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | $\begin{gathered} \text { 1C } \\ \text { BSET } \end{gathered}$ | $\begin{gathered} 2 \mathrm{C} \quad 3 / 1 \\ \mathrm{BGE} \end{gathered}$ | $\begin{aligned} & \text { 3C } \\ & \text { wav } \end{aligned}$ | $\begin{gathered} 4 \mathrm{C} \\ \text { BSET } \end{gathered}$ | $5 \mathrm{C}_{5}$ | $\begin{aligned} & 6 C^{2-} \\ & \text { STD } \end{aligned}$ |  | ${ }^{8 \mathrm{CPD}}$ | $9 \mathrm{CPD}^{9}$ | $\begin{gathered} \mathrm{AC} 3 / 4 \\ \text { CPD } \end{gathered}$ |  | CC | DC | $\begin{array}{r} \text { EC 3/4 } \\ \text { LDD } \end{array}$ | FC |
| ID 3-5 | EX | RL | SP | DI | DI | ID 2- | EX | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX |
| $\begin{gathered} \text { OD } 4 / 6 \\ \text { BCLR } \end{gathered}$ | $1 \mathrm{BCL}$ | $\begin{gathered} \text { 2D } \\ \text { BLT } \end{gathered}$ | 3D | $\begin{aligned} & \text { 4D } \\ & \text { BCLR } \end{aligned}$ |  | $\begin{aligned} & 6 D^{2} \\ & \text { STY } \end{aligned}$ |  |  |  | $\begin{gathered} \text { AD 3/4 } \\ \text { CPY } \end{gathered}$ | ${ }_{\mathrm{CPY}}^{\mathrm{BD}}$ | ${ }^{C D}$ | DD | $\begin{gathered} \text { ED 3/4 } \\ \text { LDY } \end{gathered}$ | FD |
| ID | EX | RL | IH | DI | DI | ID 2- | EX | IM | DI | ID | EX 3 | IM | DI 2 | ID | EX |
| $\begin{gathered} 0 \mathrm{E} 4 \\ \text { BRSE } \end{gathered}$ | $\begin{array}{cr} 1 \mathrm{E} & 5 \\ \mathrm{BRSET} \end{array}$ | $\begin{gathered} 2 \mathrm{E} 3 / 1 \\ \mathrm{BGT} \end{gathered}$ | $\begin{array}{r} 3 \mathrm{E} \\ \\ \\ \text { WA } \end{array}$ | $\begin{array}{cc} 4 \mathrm{E} & 4 \\ \text { BRSET } \end{array}$ | $5$ | $\begin{aligned} & 6 E^{2-} \\ & \text { STX } \end{aligned}$ |  | ${ }_{\mathrm{CPX}}^{8 \mathrm{E}}$ | ${ }_{\mathrm{CPX}}$ | $\begin{gathered} \text { AE 3/4 } \\ \text { CPX } \end{gathered}$ | $\stackrel{\mathrm{BE}}{\mathrm{CPX}}$ | ${ }_{\mathrm{CE}}^{\mathrm{LDX}}$ | DE | $\begin{gathered} \text { EE 3/4/ } \\ \text { LDX } \end{gathered}$ | FE |
| ID 4-6 | EX | RL | IH | DI | DI | ID 2- | EX | IM | DI | ID | EX 3 | IM | DI 2 | ID | EX |
| $\begin{aligned} & 0 \mathrm{~F} \quad 4-6 \\ & \text { BRCLR } \end{aligned}$ | 1F BRCLR | $2 \mathrm{~F}_{\mathrm{BLE}}^{3 / 1}$ | $3_{\mathrm{SWI}}$ | $\begin{gathered} 4 \mathrm{~F} \quad 4 \\ \text { BRCLR } \end{gathered}$ | $5 F_{S T S}$ | $6 \mathrm{~F}{ }^{2}{ }^{2-2}$ | ${ }^{7 F^{S T S}}$ | ${ }^{8 \mathrm{~F}}$ | ${ }^{9 F^{C P S}}$ | CPS | $\mathrm{BF}_{\mathrm{CPS}}$ | CF | LDS | $\text { EF } 3 / 4$ | FF |
| 4-6 | EX | RL 2 | IH 1 | DI 4 | DI | ID 2-4 | EX 3 | IM 3 | DI 2 | ID | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE. <br> Address mode abbreviations: DI- direct IH —inherent SP - special EX - extended IM -immediate <br> ID — indexed RL - relative |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $00{ }^{00}{ }^{5 G N D}$ | ANDCC | 20 BRA | ${ }_{\text {PULX }}^{30}{ }^{3}$ |  |  | NEG | $\begin{gathered} 70 \\ \text { NEG } \end{gathered}$ | SUBA | SUBA |  | $\underset{\text { SUBA }}{3}$ | SUBB | SU | $\begin{gathered} \text { EO } 3 / 4 / 6 \\ \text { SUBB } \end{gathered}$ | B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 31 | 4 |  |  | 4 |  | 3 |  | B1 3 |  | D1 3 |  |  |
|  |  |  |  |  |  | COM |  |  |  |  |  |  |  | CMPB |  |
| IH 1 | IH 1 | RL 2 | IH 1 | H | IH 1 | ID 2- | EX 3 | IM 2 | D | 2 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX 3 |
| $02$ |  | $22$ |  |  | 52 | $62$ | 4 | 8 | $92{ }_{\text {SBCA }}{ }^{3}$ | A2 | $\mathrm{B}_{\text {SBCA }}{ }^{3}$ | C2 | D2 | E2 3/4 | $\mathrm{F}_{\text {SBCB }}{ }^{3}$ |
|  | IH 1 | RL 2 | IH | IH 1 |  | ID | EX 3 | IM 2 | DI 2 | ID | EX | IM 2 | DI 2 | ID | EX 3 |
| $03{ }^{0}{ }^{1}$ | $3$ | $23$ |  | 43 | 53 | 63 DEC | 4 | 83 | $93{ }^{93}{ }^{3}$ | A3 | 3 | C3 | D3 | E3 | F3 ADDD ${ }^{3}$ |
| IH 1 | IH 1 | RL 2 | IH 1 | IH 1 | IH 1 | ID 2- | EX 3 | IM 3 | D | 2 | - | IM 3 | D | ID 2-4 | EX 3 |
| $04{ }^{0} 3$ | JR | $B C$ |  | LS | 54 | LSR | 4 | 84 | 94 ANDA ${ }^{3}$ | A4 | AN | C4 ${ }_{\text {ANDB }}$ | D4 ${ }^{\text {ANDB }}$ | E4 | ANDB |
| RL 3 | 2 | RL 2 | IH | IH 1 | IH | ID | EX 3 | IM 2 | DI 2 | ID 2- | X | , | I | ID | - |
| $05 \text { 3/4/6 }$ | 15 4/5/7 | $25 \quad 3 / 1$ |  | 45 | 55 | $\begin{gathered} 65 \text { 3- } \\ \text { ROL } \end{gathered}$ | 4 | $85$ | $95 \quad 3$ | A5 3/4 | BI | C5 BITB | D5 BITB | $\begin{array}{r} \text { E5 3/4 } \\ \text { BITB } \end{array}$ | F5 BITB |
| ID 2-4 | 2-4 | RL 2 | $\mathrm{IH} \quad 1$ | IH 1 | IH 1 | ID 2-4 | - 3 |  | D | ID 2- | EX | IM | D1 | ID | EX 3 |
| $3$ |  | $26 \quad 3 / 1$ |  |  |  | $66$ |  |  |  | A6 3/4/ | 6 | C6 | D6 | $\begin{array}{r} \text { E6 3/4 } \\ \text { LDAB } \end{array}$ | B |
| EX | EX 3 | RL | H | , | , | ID 2-4 | EX 3 | , | D1 2 | ID 2-4 | EX |  | DI 2 | ID | EX |
|  | $17 \underset{\text { JSR }}{ }{ }^{4}$ | $\begin{array}{cr} 27 & 3 / 1 \\ \text { BEQ } \end{array}$ |  |  |  |  |  |  |  |  | 7 ${ }^{\text {FR/EXG }}$ |  |  |  | F7 TST ${ }^{3}$ |
| RL 2 | D | RL | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | 1 H | IH | IH | ID 2 | EX |
|  | $18$ | $\begin{gathered} 28 \\ B V C \end{gathered}$ | 38 | 48 |  | $\begin{array}{ll} 68 & 3- \\ & \text { ASL } \end{array}$ |  | 88 | ${ }_{\text {EORA }}{ }^{3}$ |  | ${ }_{\text {EORA }}^{\text {EX }}$ | C8 | D8 EORB | E8 | $\mathrm{EORB}^{3}$ |
| IH |  | RL | IH | IH 1 | IH | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI 2 | ID 2- | EX 3 |
| DEX | $19$ <br> LE | $\begin{gathered} 29 \\ \text { BVS } \end{gathered}$ | 39 | 49 | 59 | 69 | 3 | 89 | 99 ADCA | A9 3/4 | B9 ADCA | C9 ${ }^{\text {ADCB }}$ | D9 ADCB | $\begin{array}{r} \mathrm{E} 93 / 4 \\ \mathrm{ADC} \end{array}$ | ADCB |
| IH 1 | ID 2-4 | R | IH 1 | IH | IH | ID 2- | EX | IM | DI 2 | ID 2- | EX | IM | DI 2 | D 2-4 | EX 3 |
| 0A RTC | 1A | $2 \mathrm{~A}$ | 3A | $4 \mathrm{~A}$ $\mathrm{CA}$ | $5 A$ ST | $\begin{array}{r} 6 A \\ \text { STA } \end{array}$ | ${ }_{\text {7A STAA }}{ }^{3}$ | 8A ORAA | 9A ORAA | AA 3/4 | ORAA | CA | DA ORAB | $\begin{gathered} \text { EA 3/ } \\ \text { ORA } \end{gathered}$ | ARAB |
| IH | ID 2-4 | RL | IH | EX | DI | ID 2- | EX 3 | IM | DI | ID 2- | 3 | M | DI | ID 2- | EX 3 |
| $\begin{array}{\|rr} \hline 0 \mathrm{~B} & 8 / \\ \mathrm{RTI} \end{array}$ | 1B LEAS ${ }^{2}$ | ${ }_{\mathrm{BI}}^{2 \mathrm{~B}}$ |  | 4B 7/8/10 |  | 6B 2 ${ }^{\text {STAB }}$ |  |  | 9B ADDA ${ }^{3}$ | AB 3/4 | ADDA | CB ${ }^{\text {ADDB }}$ | DB ADDB | A 3/4 | B |
| IH | ID 2-4 | RL | IH | ID 2-5 | D | ID | EX 3 | IM | DI 2 | ID 2- | E | IM | DI | D 2 | EX 3 |
| $\begin{gathered} 0 \mathrm{OC} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | ${ }^{1 \mathrm{C}} \mathrm{BSET}^{4}$ | BGE | 3C |  |  | 6C ${ }^{2}$ |  | 8C | $9 \mathrm{CPD}{ }^{3}$ | D | $\mathrm{BC} \mathrm{CPD}^{3}$ | CC | DC LDD | $\begin{gathered} \text { EC } 3 / 4 \\ \text { LDD } \end{gathered}$ | LD |
| ID 3-5 | EX | RL | SP | DI | DI | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI | D 2- |  |
| OD 4/6 | 1D ${ }_{\text {BCLR }}{ }^{4}$ | 2D $\begin{gathered}\text { BLT }\end{gathered}$ | 3D | 4D ${ }_{\text {BCLR }}{ }^{4}$ | 5D | 6D ${ }^{2-}$ STY | 7D 3 | 8D |  | D 3/4 | BD | CD | DD LDY | $\begin{gathered} \text { D 3/4 } \\ \text { LDY } \end{gathered}$ | FD ${ }_{\text {LDY }}{ }^{3}$ |
| ID 3-5 | EX | RL | IH | DI | DI | ID | EX 3 | IM | DI 2 | D 2-4 | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OE 4-6 | 1E 5 | 2E 3 3 | 3E | 4E ${ }_{\text {BRSET }}$ | 5E | 6E ${ }^{\text {STX }}$ | F 3 | 8E | 9E 3 | AE 3/4 | BE 3 | CE LDX | DE LDX ${ }^{3}$ | EE 3/4 | - 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI 2 | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OF ${ }_{\text {BRCLR }}$ | $\begin{array}{cc}1 F & 5 \\ \text { BRCLR }\end{array}$ | 2F 3LE | 3F | 4F ${ }_{\text {BRCLR }}$ | 5F STS | ${ }^{6 F}$ STS | F 3 |  | ${ }^{9 F} \mathrm{CPS} 3$ | CPS | $\mathrm{BF}^{\text {CPS }}$ | CF | DF LDS ${ }^{3}$ | LDS | F 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE.Address mode abbreviations: DI direct 1 H - inherent SP - specialEX— extended IM - immediate |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $00{ }^{00}{ }^{5 G N D}$ | ANDCC | 20 BRA | ${ }_{\text {PULX }}^{30}{ }^{3}$ |  |  | NEG | $\begin{gathered} 70 \\ \text { NEG } \end{gathered}$ | SUBA | SUBA |  | $\underset{\text { SUBA }}{3}$ | SUBB | SU | $\begin{gathered} \text { EO } 3 / 4 / 6 \\ \text { SUBB } \end{gathered}$ | B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 31 | 4 |  |  | 4 |  | 3 |  | B1 3 |  | D1 3 |  |  |
|  |  |  |  |  |  | COM |  |  |  |  |  |  |  | CMPB |  |
| IH 1 | IH 1 | RL 2 | IH 1 | H | IH 1 | ID 2- | EX 3 | IM 2 | D | 2 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX 3 |
| $02$ |  | $22$ |  |  | 52 | $62$ | 4 | 8 | $92{ }_{\text {SBCA }}{ }^{3}$ | A2 | $\mathrm{B}_{\text {SBCA }}{ }^{3}$ | C2 | D2 | E2 3/4 | $\mathrm{F}_{\text {SBCB }}{ }^{3}$ |
|  | IH 1 | RL 2 | IH | IH 1 |  | ID | EX 3 | IM 2 | DI 2 | ID | EX | IM 2 | DI 2 | ID | EX 3 |
| $03{ }^{0}{ }^{1}$ | $3$ | $23$ |  | 43 | 53 | 63 DEC | 4 | 83 | $93{ }^{93}{ }^{3}$ | A3 | 3 | C3 | D3 | E3 | F3 ADDD ${ }^{3}$ |
| IH 1 | IH 1 | RL 2 | IH 1 | IH 1 | IH 1 | ID 2- | EX 3 | IM 3 | D | 2 | - | IM 3 | D | ID 2-4 | EX 3 |
| $04{ }^{0} 3$ | JR | $B C$ |  | LS | 54 | LSR | 4 | 84 | 94 ANDA ${ }^{3}$ | A4 | AN | C4 ${ }_{\text {ANDB }}$ | D4 ${ }^{\text {ANDB }}$ | E4 | ANDB |
| RL 3 | 2 | RL 2 | IH | IH 1 | IH | ID | EX 3 | IM 2 | DI 2 | ID 2- | X | , | I | ID | - |
| $05 \text { 3/4/6 }$ | 15 4/5/7 | $25 \quad 3 / 1$ |  | 45 | 55 | $\begin{gathered} 65 \text { 3- } \\ \text { ROL } \end{gathered}$ | 4 | $85$ | $95 \quad 3$ | A5 3/4 | BI | C5 BITB | D5 BITB | $\begin{array}{r} \text { E5 3/4 } \\ \text { BITB } \end{array}$ | F5 BITB |
| ID 2-4 | 2-4 | RL 2 | $\mathrm{IH} \quad 1$ | IH 1 | IH 1 | ID 2-4 | - 3 |  | D | ID 2- | EX | IM | D1 | ID | EX 3 |
| $3$ |  | $26 \quad 3 / 1$ |  |  |  | $66$ |  |  |  | A6 3/4/ | 6 | C6 | D6 | $\begin{array}{r} \text { E6 3/4 } \\ \text { LDAB } \end{array}$ | B |
| EX | EX 3 | RL | H | , | , | ID 2-4 | EX 3 | , | D1 2 | ID 2-4 | EX |  | DI 2 | ID | EX |
|  | $17 \underset{\text { JSR }}{ }{ }^{4}$ | $\begin{array}{cr} 27 & 3 / 1 \\ \text { BEQ } \end{array}$ |  |  |  |  |  |  |  |  | 7 ${ }^{\text {FR/EXG }}$ |  |  |  | F7 TST ${ }^{3}$ |
| RL 2 | D | RL | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | 1 H | IH | IH | ID 2 | EX |
|  | $18$ | $\begin{gathered} 28 \\ B V C \end{gathered}$ | 38 | 48 |  | $\begin{array}{ll} 68 & 3- \\ & \text { ASL } \end{array}$ |  | 88 | ${ }_{\text {EORA }}{ }^{3}$ |  | ${ }_{\text {EORA }}^{\text {EX }}$ | C8 | D8 EORB | E8 | $\mathrm{EORB}^{3}$ |
| IH |  | RL | IH | IH 1 | IH | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI 2 | ID 2- | EX 3 |
| DEX | $19$ <br> LE | $\begin{gathered} 29 \\ \text { BVS } \end{gathered}$ | 39 | 49 | 59 | 69 | 3 | 89 | 99 ADCA | A9 3/4 | B9 ADCA | C9 ${ }^{\text {ADCB }}$ | D9 ADCB | $\begin{array}{r} \mathrm{E} 93 / 4 \\ \mathrm{ADC} \end{array}$ | ADCB |
| IH 1 | ID 2-4 | R | IH 1 | IH | IH | ID 2- | EX | IM | DI 2 | ID 2- | EX | IM | DI 2 | D 2-4 | EX 3 |
| 0A RTC | 1A | $2 \mathrm{~A}$ | 3A | $4 \mathrm{~A}$ $\mathrm{CA}$ | $5 A$ ST | $\begin{array}{r} 6 A \\ \text { STA } \end{array}$ | ${ }_{\text {7A STAA }}{ }^{3}$ | 8A ORAA | 9A ORAA | AA 3/4 | ORAA | CA | DA ORAB | $\begin{gathered} \text { EA 3/ } \\ \text { ORA } \end{gathered}$ | ARAB |
| IH | ID 2-4 | RL | IH | EX | DI | ID 2- | EX 3 | IM | DI | ID 2- | 3 | M | DI | ID 2- | EX 3 |
| $\begin{array}{\|rr} \hline 0 \mathrm{~B} & 8 / \\ \mathrm{RTI} \end{array}$ | 1B LEAS ${ }^{2}$ | ${ }_{\mathrm{BI}}^{2 \mathrm{~B}}$ |  | 4B 7/8/10 |  | 6B 2 ${ }^{\text {STAB }}$ |  |  | 9B ADDA ${ }^{3}$ | AB 3/4 | ADDA | CB ${ }^{\text {ADDB }}$ | DB ADDB | A 3/4 | B |
| IH | ID 2-4 | RL | IH | ID 2-5 | D | ID | EX 3 | IM | DI 2 | ID 2- | E | IM | DI | D 2 | EX 3 |
| $\begin{gathered} 0 \mathrm{OC} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | ${ }^{1 \mathrm{C}} \mathrm{BSET}^{4}$ | BGE | 3C |  |  | 6C ${ }^{2}$ |  | 8C | $9 \mathrm{CPD}{ }^{3}$ | D | $\mathrm{BC} \mathrm{CPD}^{3}$ | CC | DC LDD | $\begin{gathered} \text { EC } 3 / 4 \\ \text { LDD } \end{gathered}$ | LD |
| ID 3-5 | EX | RL | SP | DI | DI | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI | D 2- |  |
| OD 4/6 | 1D ${ }_{\text {BCLR }}{ }^{4}$ | 2D $\begin{gathered}\text { BLT }\end{gathered}$ | 3D | 4D ${ }_{\text {BCLR }}{ }^{4}$ | 5D | 6D ${ }^{2-}$ STY | 7D 3 | 8D |  | D 3/4 | BD | CD | DD LDY | $\begin{gathered} \text { D 3/4 } \\ \text { LDY } \end{gathered}$ | FD ${ }_{\text {LDY }}{ }^{3}$ |
| ID 3-5 | EX | RL | IH | DI | DI | ID | EX 3 | IM | DI 2 | D 2-4 | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OE 4-6 | 1E 5 | 2E 3 3 | 3E | 4E ${ }_{\text {BRSET }}$ | 5E | 6E ${ }^{\text {STX }}$ | F 3 | 8E | 9E 3 | AE 3/4 | BE 3 | CE LDX | DE LDX ${ }^{3}$ | EE 3/4 | - 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI 2 | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OF ${ }_{\text {BRCLR }}$ | $\begin{array}{cc}1 F & 5 \\ \text { BRCLR }\end{array}$ | 2F 3LE | 3F | 4F ${ }_{\text {BRCLR }}$ | 5F STS | ${ }^{6 F}$ STS | F 3 |  | ${ }^{9 F} \mathrm{CPS} 3$ | CPS | $\mathrm{BF}^{\text {CPS }}$ | CF | DF LDS ${ }^{3}$ | LDS | F 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE.Address mode abbreviations: DI direct 1 H - inherent SP - specialEX— extended IM - immediate |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $00{ }^{00}{ }^{5 G N D}$ | ANDCC | 20 BRA | ${ }_{\text {PULX }}^{30}{ }^{3}$ |  |  | NEG | $\begin{gathered} 70 \\ \text { NEG } \end{gathered}$ | SUBA | SUBA |  | $\underset{\text { SUBA }}{3}$ | SUBB | SU | $\begin{gathered} \text { EO } 3 / 4 / 6 \\ \text { SUBB } \end{gathered}$ | B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 31 | 4 |  |  | 4 |  | 3 |  | B1 3 |  | D1 3 |  |  |
|  |  |  |  |  |  | COM |  |  |  |  |  |  |  | CMPB |  |
| IH 1 | IH 1 | RL 2 | IH 1 | H | IH 1 | ID 2- | EX 3 | IM 2 | D | 2 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX 3 |
| $02$ |  | $22$ |  |  | 52 | $62$ | 4 | 8 | $92{ }_{\text {SBCA }}{ }^{3}$ | A2 | $\mathrm{B}_{\text {SBCA }}{ }^{3}$ | C2 | D2 | E2 3/4 | $\mathrm{F}_{\text {SBCB }}{ }^{3}$ |
|  | IH 1 | RL 2 | IH | IH 1 |  | ID | EX 3 | IM 2 | DI 2 | ID | EX | IM 2 | DI 2 | ID | EX 3 |
| $03{ }^{0}{ }^{1}$ | $3$ | $23$ |  | 43 | 53 | 63 DEC | 4 | 83 | $93{ }^{93}{ }^{3}$ | A3 | 3 | C3 | D3 | E3 | F3 ADDD ${ }^{3}$ |
| IH 1 | IH 1 | RL 2 | IH 1 | IH 1 | IH 1 | ID 2- | EX 3 | IM 3 | D | 2 | - | IM 3 | D | ID 2-4 | EX 3 |
| $04{ }^{0} 3$ | JR | $B C$ |  | LS | 54 | LSR | 4 | 84 | 94 ANDA ${ }^{3}$ | A4 | AN | C4 ${ }_{\text {ANDB }}$ | D4 ${ }^{\text {ANDB }}$ | E4 | ANDB |
| RL 3 | 2 | RL 2 | IH | IH 1 | IH | ID | EX 3 | IM 2 | DI 2 | ID 2- | X | , | I | ID | - |
| $05 \text { 3/4/6 }$ | 15 4/5/7 | $25 \quad 3 / 1$ |  | 45 | 55 | $\begin{gathered} 65 \text { 3- } \\ \text { ROL } \end{gathered}$ | 4 | $85$ | $95 \quad 3$ | A5 3/4 | BI | C5 BITB | D5 BITB | $\begin{array}{r} \text { E5 3/4 } \\ \text { BITB } \end{array}$ | F5 BITB |
| ID 2-4 | 2-4 | RL 2 | $\mathrm{IH} \quad 1$ | IH 1 | IH 1 | ID 2-4 | - 3 |  | D | ID 2- | EX | IM | D1 | ID | EX 3 |
| $3$ |  | $26 \quad 3 / 1$ |  |  |  | $66$ |  |  |  | A6 3/4/ | 6 | C6 | D6 | $\begin{array}{r} \text { E6 3/4 } \\ \text { LDAB } \end{array}$ | B |
| EX | EX 3 | RL | H | , | , | ID 2-4 | EX 3 | , | D1 2 | ID 2-4 | EX |  | DI 2 | ID | EX |
|  | $17 \underset{\text { JSR }}{ }{ }^{4}$ | $\begin{array}{cr} 27 & 3 / 1 \\ \text { BEQ } \end{array}$ |  |  |  |  |  |  |  |  | 7 ${ }^{\text {FR/EXG }}$ |  |  |  | F7 TST ${ }^{3}$ |
| RL 2 | D | RL | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | 1 H | IH | IH | ID 2 | EX |
|  | $18$ | $\begin{gathered} 28 \\ B V C \end{gathered}$ | 38 | 48 |  | $\begin{array}{ll} 68 & 3- \\ & \text { ASL } \end{array}$ |  | 88 | ${ }_{\text {EORA }}{ }^{3}$ |  | ${ }_{\text {EORA }}^{\text {EX }}$ | C8 | D8 EORB | E8 | $\mathrm{EORB}^{3}$ |
| IH |  | RL | IH | IH 1 | IH | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI 2 | ID 2- | EX 3 |
| DEX | $19$ <br> LE | $\begin{gathered} 29 \\ \text { BVS } \end{gathered}$ | 39 | 49 | 59 | 69 | 3 | 89 | 99 ADCA | A9 3/4 | B9 ADCA | C9 ${ }^{\text {ADCB }}$ | D9 ADCB | $\begin{array}{r} \mathrm{E} 93 / 4 \\ \mathrm{ADC} \end{array}$ | ADCB |
| IH 1 | ID 2-4 | R | IH 1 | IH | IH | ID 2- | EX | IM | DI 2 | ID 2- | EX | IM | DI 2 | D 2-4 | EX 3 |
| 0A RTC | 1A | $2 \mathrm{~A}$ | 3A | $4 \mathrm{~A}$ $\mathrm{CA}$ | $5 A$ ST | $\begin{array}{r} 6 A \\ \text { STA } \end{array}$ | ${ }_{\text {7A STAA }}{ }^{3}$ | 8A ORAA | 9A ORAA | AA 3/4 | ORAA | CA | DA ORAB | $\begin{gathered} \text { EA 3/ } \\ \text { ORA } \end{gathered}$ | ARAB |
| IH | ID 2-4 | RL | IH | EX | DI | ID 2- | EX 3 | IM | DI | ID 2- | 3 | M | DI | ID 2- | EX 3 |
| $\begin{array}{\|rr} \hline 0 \mathrm{~B} & 8 / \\ \mathrm{RTI} \end{array}$ | 1B LEAS ${ }^{2}$ | ${ }_{\mathrm{BI}}^{2 \mathrm{~B}}$ |  | 4B 7/8/10 |  | 6B 2 ${ }^{\text {STAB }}$ |  |  | 9B ADDA ${ }^{3}$ | AB 3/4 | ADDA | CB ${ }^{\text {ADDB }}$ | DB ADDB | A 3/4 | B |
| IH | ID 2-4 | RL | IH | ID 2-5 | D | ID | EX 3 | IM | DI 2 | ID 2- | E | IM | DI | D 2 | EX 3 |
| $\begin{gathered} 0 \mathrm{OC} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | ${ }^{1 \mathrm{C}} \mathrm{BSET}^{4}$ | BGE | 3C |  |  | 6C ${ }^{2}$ |  | 8C | $9 \mathrm{CPD}{ }^{3}$ | D | $\mathrm{BC} \mathrm{CPD}^{3}$ | CC | DC LDD | $\begin{gathered} \text { EC } 3 / 4 \\ \text { LDD } \end{gathered}$ | LD |
| ID 3-5 | EX | RL | SP | DI | DI | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI | D 2- |  |
| OD 4/6 | 1D ${ }_{\text {BCLR }}{ }^{4}$ | 2D $\begin{gathered}\text { BLT }\end{gathered}$ | 3D | 4D ${ }_{\text {BCLR }}{ }^{4}$ | 5D | 6D ${ }^{2-}$ STY | 7D 3 | 8D |  | D 3/4 | BD | CD | DD LDY | $\begin{gathered} \text { D 3/4 } \\ \text { LDY } \end{gathered}$ | FD ${ }_{\text {LDY }}{ }^{3}$ |
| ID 3-5 | EX | RL | IH | DI | DI | ID | EX 3 | IM | DI 2 | D 2-4 | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OE 4-6 | 1E 5 | 2E 3 3 | 3E | 4E ${ }_{\text {BRSET }}$ | 5E | 6E ${ }^{\text {STX }}$ | F 3 | 8E | 9E 3 | AE 3/4 | BE 3 | CE LDX | DE LDX ${ }^{3}$ | EE 3/4 | - 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI 2 | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OF ${ }_{\text {BRCLR }}$ | $\begin{array}{cc}1 F & 5 \\ \text { BRCLR }\end{array}$ | 2F 3LE | 3F | 4F ${ }_{\text {BRCLR }}$ | 5F STS | ${ }^{6 F}$ STS | F 3 |  | ${ }^{9 F} \mathrm{CPS} 3$ | CPS | $\mathrm{BF}^{\text {CPS }}$ | CF | DF LDS ${ }^{3}$ | LDS | F 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE.Address mode abbreviations: DI direct 1 H - inherent SP - specialEX— extended IM - immediate |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $00{ }^{00}{ }^{5 G N D}$ | ANDCC | 20 BRA | ${ }_{\text {PULX }}^{30}{ }^{3}$ |  |  | NEG | $\begin{gathered} 70 \\ \text { NEG } \end{gathered}$ | SUBA | SUBA |  | $\underset{\text { SUBA }}{3}$ | SUBB | SU | $\begin{gathered} \text { EO } 3 / 4 / 6 \\ \text { SUBB } \end{gathered}$ | B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 31 | 4 |  |  | 4 |  | 3 |  | B1 3 |  | D1 3 |  |  |
|  |  |  |  |  |  | COM |  |  |  |  |  |  |  | CMPB |  |
| IH 1 | IH 1 | RL 2 | IH 1 | H | IH 1 | ID 2- | EX 3 | IM 2 | D | 2 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX 3 |
| $02$ |  | $22$ |  |  | 52 | $62$ | 4 | 8 | $92{ }_{\text {SBCA }}{ }^{3}$ | A2 | $\mathrm{B}_{\text {SBCA }}{ }^{3}$ | C2 | D2 | E2 3/4 | $\mathrm{F}_{\text {SBCB }}{ }^{3}$ |
|  | IH 1 | RL 2 | IH | IH 1 |  | ID | EX 3 | IM 2 | DI 2 | ID | EX | IM 2 | DI 2 | ID | EX 3 |
| $03{ }^{0}{ }^{1}$ | $3$ | $23$ |  | 43 | 53 | 63 DEC | 4 | 83 | $93{ }^{93}{ }^{3}$ | A3 | 3 | C3 | D3 | E3 | F3 ADDD ${ }^{3}$ |
| IH 1 | IH 1 | RL 2 | IH 1 | IH 1 | IH 1 | ID 2- | EX 3 | IM 3 | D | 2 | - | IM 3 | D | ID 2-4 | EX 3 |
| $04{ }^{0} 3$ | JR | $B C$ |  | LS | 54 | LSR | 4 | 84 | 94 ANDA ${ }^{3}$ | A4 | AN | C4 ${ }_{\text {ANDB }}$ | D4 ${ }^{\text {ANDB }}$ | E4 | ANDB |
| RL 3 | 2 | RL 2 | IH | IH 1 | IH | ID | EX 3 | IM 2 | DI 2 | ID 2- | X | , | I | ID | - |
| $05 \text { 3/4/6 }$ | 15 4/5/7 | $25 \quad 3 / 1$ |  | 45 | 55 | $\begin{gathered} 65 \text { 3- } \\ \text { ROL } \end{gathered}$ | 4 | $85$ | $95 \quad 3$ | A5 3/4 | BI | C5 BITB | D5 BITB | $\begin{array}{r} \text { E5 3/4 } \\ \text { BITB } \end{array}$ | F5 BITB |
| ID 2-4 | 2-4 | RL 2 | $\mathrm{IH} \quad 1$ | IH 1 | IH 1 | ID 2-4 | - 3 |  | D | ID 2- | EX | IM | D1 | ID | EX 3 |
| $3$ |  | $26 \quad 3 / 1$ |  |  |  | $66$ |  |  |  | A6 3/4/ | 6 | C6 | D6 | $\begin{array}{r} \text { E6 3/4 } \\ \text { LDAB } \end{array}$ | B |
| EX | EX 3 | RL | H | , | , | ID 2-4 | EX 3 | , | D1 2 | ID 2-4 | EX |  | DI 2 | ID | EX |
|  | $17 \underset{\text { JSR }}{ }{ }^{4}$ | $\begin{array}{cr} 27 & 3 / 1 \\ \text { BEQ } \end{array}$ |  |  |  |  |  |  |  |  | 7 ${ }^{\text {FR/EXG }}$ |  |  |  | F7 TST ${ }^{3}$ |
| RL 2 | D | RL | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | 1 H | IH | IH | ID 2 | EX |
|  | $18$ | $\begin{gathered} 28 \\ B V C \end{gathered}$ | 38 | 48 |  | $\begin{array}{ll} 68 & 3- \\ & \text { ASL } \end{array}$ |  | 88 | ${ }_{\text {EORA }}{ }^{3}$ |  | ${ }_{\text {EORA }}^{\text {EX }}$ | C8 | D8 EORB | E8 | $\mathrm{EORB}^{3}$ |
| IH |  | RL | IH | IH 1 | IH | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI 2 | ID 2- | EX 3 |
| DEX | $19$ <br> LE | $\begin{gathered} 29 \\ \text { BVS } \end{gathered}$ | 39 | 49 | 59 | 69 | 3 | 89 | 99 ADCA | A9 3/4 | B9 ADCA | C9 ${ }^{\text {ADCB }}$ | D9 ADCB | $\begin{array}{r} \mathrm{E} 93 / 4 \\ \mathrm{ADC} \end{array}$ | ADCB |
| IH 1 | ID 2-4 | R | IH 1 | IH | IH | ID 2- | EX | IM | DI 2 | ID 2- | EX | IM | DI 2 | D 2-4 | EX 3 |
| 0A RTC | 1A | $2 \mathrm{~A}$ | 3A | $4 \mathrm{~A}$ $\mathrm{CA}$ | $5 A$ ST | $\begin{array}{r} 6 A \\ \text { STA } \end{array}$ | ${ }_{\text {7A STAA }}{ }^{3}$ | 8A ORAA | 9A ORAA | AA 3/4 | ORAA | CA | DA ORAB | $\begin{gathered} \text { EA 3/ } \\ \text { ORA } \end{gathered}$ | ARAB |
| IH | ID 2-4 | RL | IH | EX | DI | ID 2- | EX 3 | IM | DI | ID 2- | 3 | M | DI | ID 2- | EX 3 |
| $\begin{array}{\|rr} \hline 0 \mathrm{~B} & 8 / \\ \mathrm{RTI} \end{array}$ | 1B LEAS ${ }^{2}$ | ${ }_{\mathrm{BI}}^{2 \mathrm{~B}}$ |  | 4B 7/8/10 |  | 6B 2 ${ }^{\text {STAB }}$ |  |  | 9B ADDA ${ }^{3}$ | AB 3/4 | ADDA | CB ${ }^{\text {ADDB }}$ | DB ADDB | A 3/4 | B |
| IH | ID 2-4 | RL | IH | ID 2-5 | D | ID | EX 3 | IM | DI 2 | ID 2- | E | IM | DI | D 2 | EX 3 |
| $\begin{gathered} 0 \mathrm{OC} \quad 4 / 6 \\ \text { BSET } \end{gathered}$ | ${ }^{1 \mathrm{C}} \mathrm{BSET}^{4}$ | BGE | 3C |  |  | 6C ${ }^{2}$ |  | 8C | $9 \mathrm{CPD}{ }^{3}$ | D | $\mathrm{BC} \mathrm{CPD}^{3}$ | CC | DC LDD | $\begin{gathered} \text { EC } 3 / 4 \\ \text { LDD } \end{gathered}$ | LD |
| ID 3-5 | EX | RL | SP | DI | DI | ID | EX 3 | IM | DI 2 | ID 2- | EX | IM | DI | D 2- |  |
| OD 4/6 | 1D ${ }_{\text {BCLR }}{ }^{4}$ | 2D $\begin{gathered}\text { BLT }\end{gathered}$ | 3D | 4D ${ }_{\text {BCLR }}{ }^{4}$ | 5D | 6D ${ }^{2-}$ STY | 7D 3 | 8D |  | D 3/4 | BD | CD | DD LDY | $\begin{gathered} \text { D 3/4 } \\ \text { LDY } \end{gathered}$ | FD ${ }_{\text {LDY }}{ }^{3}$ |
| ID 3-5 | EX | RL | IH | DI | DI | ID | EX 3 | IM | DI 2 | D 2-4 | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OE 4-6 | 1E 5 | 2E 3 3 | 3E | 4E ${ }_{\text {BRSET }}$ | 5E | 6E ${ }^{\text {STX }}$ | F 3 | 8E | 9E 3 | AE 3/4 | BE 3 | CE LDX | DE LDX ${ }^{3}$ | EE 3/4 | - 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI 2 | ID 2- | EX 3 | IM | DI 2 | ID 2 | EX 3 |
| OF ${ }_{\text {BRCLR }}$ | $\begin{array}{cc}1 F & 5 \\ \text { BRCLR }\end{array}$ | 2F 3LE | 3F | 4F ${ }_{\text {BRCLR }}$ | 5F STS | ${ }^{6 F}$ STS | F 3 |  | ${ }^{9 F} \mathrm{CPS} 3$ | CPS | $\mathrm{BF}^{\text {CPS }}$ | CF | DF LDS ${ }^{3}$ | LDS | F 3 |
| ID 4-6 | EX | RL | IH | DI 4 | DI | ID 2-4 | EX 3 | IM | DI | ID 2- | EX 3 | IM | DI 2 | ID | EX 3 |
| Opcode $\$ 04$ is for one of the loop primitive instructions DBEQ, DBNE, IBNE, TBEQ, or TBNE.Address mode abbreviations: DI direct 1 H - inherent SP - specialEX— extended IM - immediate |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| $\begin{array}{cr} 00 \\ \text { MOVW } \end{array}$ | $10 \text { IDIV }^{12}$ | $20$ | $\begin{aligned} & 3010 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 40 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $50{ }^{10}$ | $\begin{gathered} 60 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 70{ }^{70}{ }^{\text {TRAP }} \end{gathered}$ | $\begin{aligned} & 80 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} 90{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & \text { A0 } 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & B 0 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { CO }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { D0 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \mathrm{EO}{ }^{10} \\ & \operatorname{TRAP} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { F0 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IM-ID 5 |  | RL |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | 1112 | 21 | 3110 | 4110 | 5110 | 6110 | $71 \quad 10$ | 8110 | 9110 | A1 10 | B1 10 | C1 10 | D1 10 | E1 10 | F1 |
| MO | FD | LB | TRAP |  | TRAP |  |  | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP |
| EX-ID 5 | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
|  | 12 | 22 4/3 | 3210 | 42 | 52 | 6210 | $72 \quad 10$ | 8210 | 9210 | A2 10 | B2 10 | C2 10 | D2 10 | E2 10 | F2 10 |
| MOV | EMACS | LBHI | TR |  |  |  |  |  |  |  |  | TRAP | AP | TRAP |  |
| ID-ID | SP | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH 2 | IH | IH |
|  | 13 | 23 4/3 | 3310 | 4310 | 53 | 6310 | 7310 | 8310 | 9310 | A3 10 | B3 10 | C3 10 | D3 10 | E3 10 | F3 10 |
| MO | EMULS | LBLS | TR | TR | TR | TR |  |  | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP |  |
| IM-EX 6 | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH 2 | IH 2 | IH |
|  | $14 \quad 12$ | 24 4/3 | 3410 | 4410 | 5410 | 6410 | $74 \quad 10$ | $84 \quad 10$ | $94 \quad 10$ | A4 10 | B4 10 | C4 10 | D4 10 | E4 10 | F4 10 |
| MOVW | EDIVS | LB | TRAP | TR | TR | TR | TR | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP |  |
| EX-EX 6 | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
|  | 1512 | 25 4/3 | 3510 | 4510 | 5510 | 6510 | $75 \quad 10$ | 8510 | 9510 | A5 10 | B5 10 | C5 10 | D5 10 | E5 10 | F5 10 |
| MOVW | IDIVS | LBCS | TRAP | TR | TR | TRAP | Trap | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP |  |
| ID-EX 5 | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
|  | 16 | 26 4/3 | 3610 | 4610 | 5610 | 6610 | 7610 | 8610 | 9610 | A6 10 | B6 10 | C6 10 | D6 10 | E6 10 | F6 10 |
| ABA | SBA | LB | TR | TR | TR | Trap | Trap | TRAP | Trap | TRAP | Trap | Trap | TRAP | TRAP |  |
| IH | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
|  | 17 | 27 4/3 | 3710 | 4710 | 5710 | 6710 | 7710 | 8710 | 9710 | A7 10 | B7 10 | C7 10 | D7 10 | E7 10 | F7 10 |
| DA | CBA | LB | TR | TR | TR | TR | TR | TR | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | AP |
| IH | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
|  | 18 4/5/7 | 28 4/3 | 3810 | 4810 | 5810 | 6810 | 7810 | 8810 | 9810 | A8 10 | B8 10 | C8 10 | D8 10 | E8 10 | F8 10 |
| MO | MA | LBVC | TR | TR | TR | TR | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | AP |
| M-ID | ID 3-5 | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
|  | 19 4/5/7 | 29 4/3 | 3910 | 4910 | 5910 | 6910 | $79 \quad 10$ | 8910 | 9910 | A9 10 | B9 10 | C9 10 | D9 10 | E9 | F9 10 |
| MO | MIN | LBVS | TRAP | TR | TR | TR | TR | TRAP | TR | TR | TRAP | TRAP | TRAP | TRAP | A |
| EX-ID 5 | ID 3-5 | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
|  | 1A 4/5/7 | 2A 4/3 | 3A 3n | 4A 10 | 5A 10 | 6A 10 | 7A 10 | 8A 10 | 9A 10 | AA 10 | BA 10 | CA 10 | DA 10 | EA | FA 10 |
| MOVB | EMAXD | L | REV | TR | TR | TRAP | TR | TR | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | RAP |
| ID-ID | ID 3-5 | RL | SP | 1 H | IH | IH 2 | IH | IH | IH | IH | IH | IH 2 | IH 2 | IH 2 | IH |
|  | 1B 4/5/7 | 2B 4/3 | 3B 5n/3n | 4B 10 | 5B 10 | 6B 10 | 7B 10 | 8B 10 | 9 B 10 | AB 10 | BB 10 | CB 10 | DB 10 | EB 10 | FB 10 |
| MOVB | EMIND | LBMI | REVW | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | A |
| IM-EX 5 | ID 3-5 | RL | SP | 1 H | IH | IH | IH | IH | IH | IH | IH | IH 2 | IH 2 | IH 2 | IH |
|  | 1C 4-7 | 2C 4/3 | 3C 7n | 4C 10 | 5C 10 | 6C 10 | 7 C 10 | $8 \mathrm{C} \quad 10$ | 9 C 10 | AC 10 | BC 10 | CC 10 | DC 10 | EC 10 | FC 10 |
| MOVB | MAXM | LBGE | WAV | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRA |
| EX-EX 6 | ID 3-5 | RL | SP | IH | IH | IH | IH | IH | IH | IH | IH | IH 2 | IH 2 | IH 2 | IH |
|  | 1D 4-7 | 2D 4/3 | 3D | 4D 10 | 5D 10 | 6D 10 | 7D 10 | 8D 10 | 9D 10 | AD 10 | BD 10 | CD 10 | DD 10 | ED 10 | FD 10 |
| MOVB | MINM | LBLT | TBL | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP |
| ID-EX 5 | ID 3-5 | RL | ID 3 | IH | IH | IH | IH | IH | IH | IH | IH | IH 2 | IH 2 | IH | IH |
|  | 1E 4-7 | 2E 4/3 | 3E 8+6 | 4E 10 |  |  | 7E 10 | 8E 10 | 9 E 10 | AE 10 | BE 10 | CE 10 | DE 10 | EE 10 | FE 10 |
| TAB | EMAXM | LBGT | STOP | TRAP | Trap | trap | trap | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP | TRAP |
| 1 H | ID 3-5 | RL | IH | IH | IH 2 | IH 2 | IH 2 | IH | IH | IH 2 | IH 2 | IH 2 | IH 2 | IH 2 | IH |
| OF 2 | 1F 4-7 | 2F 4/3 | 3 F 10 | $4 \mathrm{~F} \quad 10$ | 5F 10 | $6 \mathrm{~F} \quad 10$ | $7 \mathrm{~F} \quad 10$ | $8 \mathrm{~F} \quad 10$ | 9F 10 | AF 10 | BF 10 | CF 10 | DF 10 | EF 10 | FF 10 |
| TBA | EMINM | LBLE | ETBL | TRAP | RAP | RAP | RAP | TRAP | TRAP | RAP | RAP | RAP | TRA | TRA | TRAP |
| H 2 | EX 3-5 | RL | ID | IH | IH 2 | H 2 | H 2 | IH 2 | IH | IH | IH | IH | IH | IH | IH |

### 4.6 Transfer and Exchange Postbyte Encoding

| Transfers |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\downarrow$ LS ${ }^{\text {MS }} \rightarrow$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0 | $A \Rightarrow A$ | $B \Rightarrow A$ | CCR $\Rightarrow$ A | TMP3 ${ }_{\text {L }} \Rightarrow$ A | $B \Rightarrow A$ | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{A}$ | $Y_{L} \Rightarrow A$ | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{A}$ |
| 1 | $A \Rightarrow B$ | $B \Rightarrow B$ | $C C R \Rightarrow B$ | $\mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{B}$ | $B \Rightarrow B$ | $X_{L} \Rightarrow B$ | $Y_{L} \Rightarrow B$ | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{B}$ |
| 2 | $A \Rightarrow C C R$ | $B \Rightarrow C C R$ | CCR $\Rightarrow$ CCR | TMP3 ${ }_{L}=$ CCR | $B \Rightarrow C C R$ | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{CCR}$ | $\mathrm{Y}_{\mathrm{L}} \Rightarrow C C R$ | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{CCR}$ |
| 3 | sex:A $\Rightarrow$ TMP2 | sex: $B \Rightarrow$ TMP2 | sex:CCR $\Rightarrow$ TMP2 | TMP3 $\Rightarrow$ TMP2 | $\mathrm{D} \Rightarrow$ TMP2 | $\mathrm{X} \Rightarrow$ TMP2 | $\mathrm{Y} \Rightarrow$ TMP2 | $\mathrm{SP} \Rightarrow \mathrm{TMP} 2$ |
| 4 | $\begin{aligned} & \text { sex:A } \Rightarrow D \\ & \text { SEX A,D } \end{aligned}$ | $\begin{aligned} & \text { sex:B } \Rightarrow D \\ & \text { SEX B,D } \end{aligned}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow D \\ & \text { SEX CCR,D } \end{aligned}$ | TMP3 $\Rightarrow$ D | $D \Rightarrow D$ | $\mathrm{X} \Rightarrow \mathrm{D}$ | $Y \Rightarrow D$ | $S P \Rightarrow D$ |
| 5 | $\begin{aligned} & \text { sex:A } \Rightarrow X \\ & \text { SEX } A, X \end{aligned}$ | $\begin{aligned} & \text { sex: } B \Rightarrow X \\ & \text { SEX } B, X \end{aligned}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow X \\ & \text { SEX CCR, } X \end{aligned}$ | TMP3 $\Rightarrow$ X | $D \Rightarrow X$ | $X \Rightarrow X$ | $Y \Rightarrow X$ | $S P \Rightarrow X$ |
| 6 | $\begin{aligned} & \text { sex:A } \Rightarrow Y \\ & \text { SEX A,Y } \end{aligned}$ | $\text { sex: } B \Rightarrow Y$ SEX B,Y | $\begin{aligned} & \hline \text { sex:CCR } \Rightarrow Y \\ & \text { SEX CCR, } \end{aligned}$ | TMP3 $\Rightarrow$ Y | $D \Rightarrow Y$ | $X \Rightarrow Y$ | $Y \Rightarrow Y$ | $\mathrm{SP} \Rightarrow \mathrm{Y}$ |
| 7 | $\begin{aligned} & \text { sex:A } \Rightarrow \text { SP } \\ & \text { SEX A,SP } \end{aligned}$ | $\begin{aligned} & \text { sex: } B \Rightarrow S P \\ & \text { SEX } B, S P \end{aligned}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow \text { SP } \\ & \text { SEX CCR,SP } \end{aligned}$ | TMP3 $\Rightarrow$ SP | $D \Rightarrow S P$ | $\mathrm{X} \Rightarrow \mathrm{SP}$ | $\mathrm{Y} \Rightarrow \mathrm{SP}$ | $\mathrm{SP} \Rightarrow \mathrm{SP}$ |
| Exchanges |  |  |  |  |  |  |  |  |
| $\downarrow$ LS MS $\rightarrow$ | 8 | 9 | A | B | C | D | E | F |
| 0 | $A \Leftrightarrow A$ | $B \Leftrightarrow A$ | CCR $\Leftrightarrow \mathrm{A}$ | $\begin{gathered} \mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{~A} \\ \$ 00: \mathrm{A} \Rightarrow \mathrm{TMP3} 3 \end{gathered}$ | $\begin{aligned} & B \Rightarrow A \\ & A \Rightarrow B \end{aligned}$ | $\begin{gathered} X_{L} \Rightarrow A \\ \$ 00: A \Rightarrow X \end{gathered}$ | $\begin{gathered} Y_{L} \Rightarrow A \\ \$ 00: A \Rightarrow Y \end{gathered}$ | $\begin{gathered} \mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{~A} \\ \$ 00: \mathrm{A} \Rightarrow \mathrm{SP} \end{gathered}$ |
| 1 | $A \Leftrightarrow B$ | $B \Leftrightarrow B$ | $\mathrm{CCR} \Leftrightarrow \mathrm{B}$ | $\begin{gathered} \mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{~B} \\ \$ F F: B \Rightarrow \mathrm{TMP} 3 \end{gathered}$ | $\begin{gathered} \mathrm{B} \Rightarrow \mathrm{~B} \\ \$ \mathrm{FF} \Rightarrow \mathrm{~A} \end{gathered}$ | $\begin{gathered} \mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{~B} \\ \$ \mathrm{FF}: \mathrm{B} \Rightarrow \mathrm{X} \end{gathered}$ | $\begin{gathered} Y_{L} \Rightarrow B \\ \$ F F: B \Rightarrow Y \end{gathered}$ | $\begin{gathered} \mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{~B} \\ \$ \mathrm{FF}: \mathrm{B} \Rightarrow \mathrm{SP} \end{gathered}$ |
| 2 | A $\Leftrightarrow \mathrm{CCR}$ | $\mathrm{B} \Leftrightarrow \mathrm{CCR}$ | CCR $\Leftrightarrow$ CCR | $\begin{gathered} \mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ \mathrm{FF}: \mathrm{CCR} \Rightarrow \mathrm{TMP3} \end{gathered}$ | $\begin{gathered} \mathrm{B} \Rightarrow \mathrm{CCR} \\ \$ \mathrm{FF}: C C R \Rightarrow D \end{gathered}$ | $\begin{gathered} \mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ \mathrm{FF}: \mathrm{CCR} \Rightarrow \mathrm{X} \end{gathered}$ | $\begin{gathered} \mathrm{Y}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ \mathrm{FF}: C \mathrm{CR} \Rightarrow \mathrm{Y} \end{gathered}$ | $\begin{gathered} \mathrm{SP} \mathrm{~L}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ \mathrm{FF}: C \mathrm{CR} \Rightarrow \mathrm{SP} \end{gathered}$ |
| 3 | $\begin{gathered} \text { \$00:A } \Rightarrow \text { TMP2 } \\ \text { TMP2 } \Rightarrow A A \end{gathered}$ | $\begin{gathered} \$ 00: \mathrm{B} \Rightarrow \mathrm{TMP2} \\ \mathrm{TMP2}_{\mathrm{L}} \Rightarrow \mathrm{~B} \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow \text { TMP2 } \\ \text { TMP2 }_{L} \Rightarrow \text { CCR } \end{gathered}$ | TMP3 $\Leftrightarrow$ TMP2 | $\mathrm{D} \Leftrightarrow \mathrm{TMP2}$ | X $\Leftrightarrow$ TMP2 | Y $\Leftrightarrow$ TMP2 | SP $\Leftrightarrow$ TMP2 |
| 4 | \$00:A $\Rightarrow \mathrm{D}$ | \$00: $\mathrm{B} \Rightarrow \mathrm{D}$ | $\begin{gathered} \$ 00: C C R \Rightarrow D \\ B \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ D | $D \Leftrightarrow D$ | $\mathrm{X} \Leftrightarrow \mathrm{D}$ | $Y \Leftrightarrow D$ | $\mathrm{SP} \Leftrightarrow \mathrm{D}$ |
| 5 | $\begin{gathered} \$ 00: A \Rightarrow X \\ X_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow X \\ X_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow X \\ X_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow X$ | $D \Leftrightarrow X$ | $X \Leftrightarrow X$ | $Y \Leftrightarrow X$ | $\mathrm{SP} \Leftrightarrow \mathrm{X}$ |
| 6 | $\begin{gathered} \$ 00: A \Rightarrow Y \\ Y_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow Y \\ Y_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow Y \\ Y_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ Y | $D \Leftrightarrow Y$ | $X \Leftrightarrow Y$ | $Y \Leftrightarrow Y$ | $\mathrm{SP} \Leftrightarrow \mathrm{Y}$ |
| 7 | $\begin{gathered} \$ 00: A \Rightarrow S P \\ S P_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow S P \\ S P_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow S P \\ S P_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ SP | $D \Leftrightarrow S P$ | $X \Leftrightarrow S P$ | $Y \Leftrightarrow S P$ | $\mathrm{SP} \Leftrightarrow \mathrm{SP}$ |

TMP2 and TMP3 registers are for factory use only.

### 4.7 Loop Primitive Postbyte (lb) Encoding

|  | ${ }^{10}{ }_{\text {DBEQ }}{ }^{\mathrm{A}}$ <br> (-) | ${ }^{20} \text { DBNE }^{\text {A }}$ <br> (+) | ${ }^{30} \text { DBNE }^{\text {A }}$ <br> (-) | ${ }^{40}{ }_{\text {TBEQ }}{ }^{\mathrm{A}}$ <br> (+) | $\begin{array}{\|c\|} \hline 50 \\ \hline \\ \hline \end{array}$ | ${ }^{60}{ }_{\text {TBNE }}{ }^{\mathrm{A}}$ <br> (+) | ${ }^{70}$ TBNE $^{\mathrm{A}}$ <br> (-) | ${ }^{80}{ }_{\text {IBEQ }} \mathrm{A}$ <br> (+) | ${ }^{90}{ }_{\text {IBEQ }} \mathrm{A}$ $(-)$ | ${ }^{\mathrm{A} 0}{ }_{\mathrm{IBNE}}{ }^{\mathrm{A}}$ <br> (+) | ${ }^{\mathrm{B} 0}{ }_{\text {IBNE }}{ }^{\mathrm{A}}$ <br> (-) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{\|c\|} \hline 01 \\ \underset{y}{\text { DBEQ }} \\ (+) \end{array}$ | $\underset{\substack{\text { DBEQ } \\(-)}}{ }$ |  | $\begin{array}{\|c\|} \hline 31 \\ \operatorname{DBNE}^{(-)} \\ \hline \end{array}$ | ${\underset{c}{41}}_{\substack{\text { TBEQ } \\(+)}}{ }^{\text {B }}$ | $\begin{array}{\|c\|} \hline 51 \\ \operatorname{TBEQ}^{\text {( })} \\ \hline \end{array}$ | ${ }^{61}{ }^{\text {TBNE }}$ <br> (+) | $\begin{array}{\|c\|} \hline 71 \\ \substack{7 B N E \\ (-)} \\ \hline \end{array}$ | $\underset{\substack{\text { IBEQ } \\(+)}}{81}$ | $\begin{array}{\|c\|c\|} \hline 91 \\ \hline \\ \hline \end{array}$ | ${ }_{\text {IBNE }}{ }^{\mathrm{B}}$ <br> (+) | $\underset{\substack{\mathrm{BN} 1 \\(-)}}{\mathrm{B}}$ |
| 02 | 12 | 22 | 32 | 42 | 52 | 62 | 72 | 82 | 92 | A2 | B2 |
| 03 | 13 | 23 | 33 | 43 | 53 | 63 | 73 | 83 | 93 | A3 | B3 |
| $\begin{array}{\|c} \hline 04 \\ \hline \\ \hline \end{array}$ | $\begin{gathered} \hline 14 \\ \substack{\text { DBEQ } \\ (-)} \\ \hline \end{gathered}$ | $\begin{array}{\|c\|} \hline 24 \\ \text { DBNE } \left.^{\text {( }} \text { ( }\right) \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 34 \\ \text { DBNE }^{\text {( }} \text { 碞 } \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 44 \\ \hline \\ \hline \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 54 \\ \hline \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 64 \\ \substack{\text { TBNE } \\ (+)} \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline 74 \\ \hline \\ \hline \end{array}$ | $\begin{array}{\|c} \hline 84 \underset{\substack{\text { IBEQ } \\ (+)}}{ } \mathrm{D} \\ \hline \end{array}$ | $$ | $\begin{array}{\|c} \hline \text { A4 } \underset{\substack{\text { IBNE } \\ (+)}}{ } \mathrm{D} \\ \hline \end{array}$ | $\underset{\substack{\text { B4 } \\(-)}}{ }$ |
| $\underset{\substack{\text { DBEQ } \\(+)}}{ } \mathrm{X}$ | $\underset{\substack{\text { DBEQ } \\(-)}}{ }$ | $25{ }_{\text {DBNE }} \mathrm{X}$ <br> (+) | $\left.\right\|_{\substack{\text { DBNE } \\(-)}} \mathrm{X}$ | $\left.\right\|_{\substack{\text { TBEQ } \\(+)}} \mathrm{X}$ | ${\underset{c}{\text { TBEQ }}}_{\substack{55 \\(-)}} \mathrm{X}$ | ${ }_{\text {TBNE }} \mathrm{X}$ <br> (+) | $\begin{array}{\|c\|} \hline 75 \\ \substack{\text { TBNE } \\ (-)} \\ \hline \end{array}$ | ${ }^{85} \text { IBEQ }$ <br> (+) | ${\underset{c}{\text { IBEQ }}}_{\substack{\text { I- }}} \mathrm{X}$ | ${ }_{\text {IBNE }}^{\text {A5 }}$ <br> (+) | ${ }_{\text {IBNE }}^{\text {B5 }}$ $(-)$ |
| $\begin{array}{\|c} 06 \\ \underset{y}{\text { DBEQ }} \\ (+) \end{array}$ | $\begin{gathered} \hline 16 \underset{\substack{\text { DBEQ } \\ (-)}}{ } \mathrm{Y} \\ \hline \end{gathered}$ | $26{ }_{\text {DBNE }}$ <br> (+) | $\underset{\substack{36 \\ \text { DBNE } \\(-)}}{ }$ | $\underset{\substack{\text { TBEQ } \\(+)}}{ }{ }^{46}$ | $\underset{\substack{\text { TBEQ } \\(-)}}{ } \mathrm{Y}$ | ${ }^{66}{ }_{\text {TBNE }}$ <br> (+) | $\underset{\substack{76 \\ \text { TBNE } \\(-)}}{ } Y$ | $86{ }_{\text {IBEQ }}$ <br> (+) | ${\underset{c}{96}}_{\substack{\text { IBEQ } \\(-)}} Y$ | ${ }_{\text {IBNE }} \mathrm{Y}$ <br> (+) | $\begin{gathered} \hline \text { B6 } \underset{\substack{\text { IBNE } \\ (-)}}{ } Y \\ \hline \end{gathered}$ |
| $\begin{gathered} 07 \\ \text { DBEQ } \\ (+) \end{gathered}$ | $\begin{gathered} 17 \\ \text { DBEQ } \\ (-) \\ \hline \end{gathered}$ | $\begin{array}{\|cc\|} \hline 27 & \text { SP } \\ \text { DBNE } \end{array}$ <br> (+) | $\begin{array}{\|c} \hline 37 \\ \text { DBNE } \\ (-) \end{array}$ | $\begin{gathered} \hline 47 \\ \begin{array}{c} \text { TBEQ } \\ (+) \end{array} \\ \hline \end{gathered}$ | $\begin{array}{\|c\|} \hline 57 \\ \substack{\text { TBEQ } \\ (-)} \\ \hline \end{array}$ | $\begin{array}{\|cr\|} \hline 67 & \text { SP } \\ \text { TBNE } \end{array}$ <br> (+) | $\begin{array}{\|c\|} \hline 77 \\ \text { TBNE } \\ (-) \end{array}$ | $87 \text { IBEQ }$ <br> (+) | $\begin{array}{\|c} \hline 97 \\ \begin{array}{c} \text { IBEQ } \\ (-) \end{array} \\ \hline \end{array}$ |  <br> (+) | $\begin{gathered} \mathrm{B7}{ }_{\text {IBNE }} \mathrm{SP} \end{gathered}$ $(-)$ |

Hex postbyte (bit 3 is don't care) $\longrightarrow \underset{\substack{\text { DBEQ } \\(+)}}{\text { Anemonic }} \longleftrightarrow$ Counter
(lower eight bits are an extension byte following postbyte)


[^1]: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 5 Instruction Execution

The CPU uses a three-stage instruction queue to facilitate instruction fetching and increase execution speed. This section provides a general description of the instruction queue during normal program execution and during changes in execution flow. Operation of the queue is automatic and generally transparent to the user.

### 5.1 Normal Instruction Execution

Queue logic prefetches program information and positions it for sequential execution, one instruction at a time. The relationship between bus cycles and execution cycles is straightforward and facilitates tracking and debugging.

There are three 16-bit stages in the instruction queue. Instructions enter the queue at stage 1 and roll out after stage 3. Each byte in the queue is selectable. An opcode-prediction algorithm determines the location of the next opcode in the instruction queue.

Each instruction refills the queue by fetching the same number of bytes that the instruction uses. Program information is fetched in aligned 16-bit words. Each program fetch indicates that two bytes need to be replaced in the instruction queue. Each optional fetch indicates that only one byte needs to be replaced. For example, an instruction composed of five bytes does two program fetches and one optional fetch. If the first byte of the five-byte instruction was even-aligned, the optional fetch is converted into a free cycle. If the first byte was odd-aligned, the optional fetch is executed as a program fetch.

Two external pins, IPIPE[1:0], provide time-multiplexed information about instruction execution and data movement in the queue. Decoding and using the IPIPE signals is discussed in.

### 5.2 Execution Sequence

All queue operations are defined by two basic queue movement cycles. Queue movement cycles are only one factor in instruction execution time and should not be confused with bus cycles.

### 5.2.1 No Movement

There is no data movement in the instruction queue during the cycle. This occurs during execution of instructions that must perform a number of internal operations, such as division instructions.

### 5.2.2 Advance and Load from Data Bus

The content of queue stage 1 advances to stage 2 , stage 2 advances to stage 3 , and stage 1 is loaded with a word of program information from the data bus.

### 5.3 Changes of Flow

Most of the time, the instruction queue operates in a continuous sequence of queue movement cycles. When program flow changes because of an exception, subroutine call, branch, or jump, the queue automatically adjusts its movement sequence to accommodate the change in program flow.

### 5.3.1 Exceptions

Exceptions include three types of reset, an unimplemented opcode trap, a software interrupt instruction, X bit maskable interrupts, and I bit maskable interrupts.

To minimize the effect of queue operation on exception handling:

- The exception vector fetch is the first part of exception processing.
- Fetches to refill the queue from the new address are interleaved with the context-stacking operations, so that program access time does not delay the switch.

Please see Section 6 of this guide for more detailed information on exception processing.

### 5.3.2 Subroutines

The CPU can branch to (BSR), jump to (JSR), or CALL subroutines. The BSR and JSR instructions are for accessing subroutines in the normal 64 K byte address space. The CALL instruction is for accessing subroutines in expanded memory.

BSR uses relative addressing mode to generate the effective address of the subroutine, while JSR can use other addressing modes. Both instructions calculate a return address, stack the address, then do three program word fetches to refill the queue.

A subroutine in the normal 64 K byte address space ends with a return from subroutine instruction (RTS). RTS unstacks the return address and does three program word fetches from that address to refill the queue.

CALL is similar to JSR. MCUs with expanded memory treat the 16 K bytes of addresses from $\$ 8000$ to $\$ B F F F$ as an expanded memory window. An 8-bit PPAGE register switches the memory pages in the window. CALL calculates and stacks a return address along with the current PPAGE value and writes a new instruction-supplied value to PPAGE. Then it calculates the subroutine address and fetches three program words from that address to refill the queue.

A subroutine in expanded memory ends with a return from call instruction (RTC). RTC unstacks the PPAGE value and the return address and does three program word fetches from that address to refill the queue.

### 5.3.3 Branches

A branch instruction changes the execution flow when a specific condition exists. There are short conditional branches, long conditional branches, and bit-condition branches. All branch instructions affect the queue similarly, but there are differences in cycle counts between the various types. Loop primitive instructions are a special type of branch instruction for implementing counter-based loops.

A branch instruction has two execution cases. Either the branch condition is satisfied, and a change of flow takes place, or the condition is not satisfied, and no change of flow occurs.

### 5.3.3.1 Short Branches

The branch-not-taken case for a short branch is simple. Since the instruction consists of a single word containing both an opcode and an 8-bit offset, the queue advances, the CPU fetches another program word, and execution continues with the next instruction.

The branch-taken case for a short branch requires that the queue be refilled so that execution can begin at a new address. First, the CPU calculates the effective address of the destination using the relative offset in the instruction. Then it loads the address into the program counter, and performs three program word fetches at the new address to refill the queue.

### 5.3.3.2 Long Branches

The branch-not-taken case for a long branch requires three cycles, while the branch-taken case requires four cycles. This is due to differences in the amount of program information needed to fill the queue.

A long branch instruction begins with a $\$ 18$ prebyte which indicates that the opcode is on page 2 of the opcode map. The CPU treats the prebyte as a special one-byte instruction. To maintain alignment in the two-byte queue, the first cycle of a long branch instruction is an optional cycle. If the prebyte is not aligned, the CPU does a program word access; if the prebyte is aligned, the first cycle is a free cycle.

Optional cycles align byte-sized and misaligned instructions with aligned word-length instructions. Program information is always fetched as aligned 16 -bit words. When an instruction has an odd number of bytes, and the first byte is not aligned with an even byte boundary, the optional cycle makes an additional program word access that maintains queue order. In all other cases, the optional cycle is a free cycle. In the branch-not-taken case, the queue advances so that execution can continue with the next instruction. The CPU does one program fetch and one optional fetch to refill the queue.
In the branch-taken case, the CPU calculates the effective address of the branch using the 16-bit relative offset contained in the second word of the instruction. It loads the address into the program counter and then does three program word fetches at the new address to refill the queue.

### 5.3.3.3 Bit Condition Branches

A bit-condition branch instruction reads a location in memory and branches if the bits in that location are in a certain state. It can use direct, extended, or indexed addressing mode. Indexed operations require varying amounts of information to determine the effective address, so instruction length varies with the addressing mode. The amount of program information fetched also varies with instruction length. To shorten execution time, the CPU does one program word fetch in anticipation of the branch-taken case. The data from this fetch is ignored if the branch is not taken, and the CPU refills the queue according to the instruction length. If the branch is taken, the CPU refills the queue from the new address according to the instruction length.

### 5.3.3.4 Loop Primitive Instructions

A loop primitive instruction tests a counter value in a register or accumulator. If the test condition is met, the CPU branches to an address specified by a 9-bit relative offset contained in the instruction. There are autoincrement and autodecrement versions of the instructions. The test and increment/decrement operations are performed on internal CPU registers, and require no additional program information. To shorten execution time, the CPU does one program word fetch in anticipation of the branch-taken case. The data from this fetch is ignored if the branch is not taken, and the CPU does one program fetch and one optional fetch to refill the queue. If the branch is taken, the CPU refills the queue with two additional program word fetches at the new address.

### 5.3.4 Jumps

JMP is the simplest change-of-flow instruction. JMP can use extended or indexed addressing. Indexed operations require varying amounts of information to determine the effective address, so instruction length varies with the addressing mode. The amount of program information fetched also varies with instruction length. In all forms of JMP, the CPU refills the queue with three program word fetches at the new address.

### 5.4 Instruction Timing

The Access Detail column of the summary in Table 5-1 shows how many bytes of information the CPU accesses while executing an instruction. With this information and knowledge of the type and speed of memory in the system, you can determine the execution time for any instruction in any system. Simply count the code letters to determine the execution time of an instruction in a best-case system. An example of a best-case system is a single-chip 16-bit system with no 16-bit off-boundary data accesses to any locations other than on-chip RAM.

A description of the notation used in each column of the table is given in the subsections that follow including that of the Access Detail column. This information as well as the summary in Table 5-1 is repeated from Section 1 of this guide for completeness.

Table 5-1 Instruction Set Summary

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H I N V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ABA | Add B to $\mathrm{A} ;(\mathrm{A})+(\mathrm{B}) \Rightarrow \mathrm{A}$ | INH | 1806 | 00 | --- - $\Delta\|-\|\Delta\| \Delta\| \Delta\|\Delta\|$ |
| ABXSame as LEAX B, X | Add $B$ to $\mathrm{X} ;(\mathrm{X})+(\mathrm{B}) \Rightarrow \mathrm{X}$ | IDX | 1A E5 | Pf |  |
| ABYSame as LEAY B,Y | Add B to $\mathrm{Y} ;(\mathrm{Y})+(\mathrm{B}) \Rightarrow \mathrm{Y}$ | IDX | 19 ED | Pf |  |
| ADCA \#opr8i ADCA opr8a ADCA opr16a ADCA oprx0_xysppc ADCA oprx9,xysppc ADCA oprx16,xysppc ADCA [D, xysppc] ADCA [oprx16,xysppc] | Add with carry to $A ;(A)+(M)+C \Rightarrow A$ or $(A)+i m m+C \Rightarrow A$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | 89 ii 99 dd B9 hh ll A9 xb A9 xb ff A9 xb ee ff A9 xb A9 xb ee ff | ```P rPf rPO rPf rPO frPP fIfrPf fIPrPf``` |  |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H INZVC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADCB \#opr8i ADCB opr8a ADCB opr16a ADCB oprx0_xysppc ADCB oprx9,xysppc ADCB oprx16,xysppc ADCB [D, xysppc] ADCB [oprx16,xysppc] | Add with carry to $B ;(B)+(M)+C \Rightarrow B$ or $(B)+i m m+C \Rightarrow B$ | $\begin{aligned} & \hline \text { IMM } \\ & \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | C9 ii <br> D9 dd <br> F9 hh 11 <br> E9 xb <br> E9 xb ff <br> E9 xbeeff <br> E9 xb <br> E9 xbeeff | P rPf rPo rPf rPo frPP fIfrPf fIPrPf | ---\| $\Delta-\|\Delta\| \Delta \Delta \Delta \Delta$ |
| ADDA \#opr8i ADDA opr8a ADDA opr16a ADDA oprx0_xysppc ADDA oprx9,xysppc ADDA oprx16,xysppc ADDA [D, xysppc] ADDA [oprx16,xysppc] | Add to $\mathrm{A} ;(\mathrm{A})+(\mathrm{M}) \Rightarrow \mathrm{A}$ or $(A)+i m m \Rightarrow A$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8B ii <br> 9B dd <br> BB hh 11 <br> AB xb <br> AB xb ff <br> AB xbeeff <br> AB xb <br> AB xbeeff | P rPf rPo rPf rPo frPP fIfrPf fIPrPf | ---\| $\Delta\|-\|\Delta\| \Delta\| \Delta \mid \Delta$ |
| ADDB \#opr8i <br> ADDB opr8a <br> ADDB opr16a <br> ADDB oprx0_xysppc <br> ADDB oprx9,xysppc <br> ADDB oprx16,xysppc <br> ADDB [D, xysppc] <br> ADDB [oprx16,xysppc] | Add to $\mathrm{B} ;(\mathrm{B})+(\mathrm{M}) \Rightarrow \mathrm{B}$ or $(B)+i m m \Rightarrow B$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{array}$ | CB ii <br> DB dd <br> FB hh 11 <br> EB xb <br> EB xbff <br> EB xb eeff <br> EB xb <br> EB xb ee ff | P rPf rPO rPf rPO frPP fIfrPf fIPrPf | ---\| $\Delta-\|\Delta\| \Delta \Delta \Delta \Delta$ |
| ADDD \#opr16i ADDD opr8a ADDD opr16a ADDD oprx0_xysppc ADDD oprx9,xysppc ADDD oprx16,xysppc ADDD [D,xysppc] ADDD [oprx16,xysppc] | $\begin{aligned} & \text { Add to } D ;(A: B)+(M: M+1) \Rightarrow A: B \\ & \text { or }(A: B)+i m m \Rightarrow A: B \end{aligned}$ | $\begin{aligned} & \hline \text { IMM } \\ & \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & {[\text { IDX2] }} \end{aligned}$ | C3 jjkk <br> D3 dd <br> F3 hh 11 <br> E3 xb <br> E3 xb ff <br> E3 xbeeff <br> E3 xb <br> E3 xb eeff | PO RPf RPO RPf RPO fRPP fIfRPf fIPRPf | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| ANDA \#opr8i ANDA opr8a ANDA opr16a ANDA oprx0_xysppc ANDA oprx9,xysppc ANDA oprx16,xysppc ANDA [D, xysppc] ANDA [oprx16,xysppc] | AND with $A ;(A) \bullet(M) \Rightarrow A$ or $(A) \cdot i m m \Rightarrow A$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 84 ii <br> 94 dd <br> B4 hh 11 <br> A 4 xb <br> A4 xb ff <br> A4 xbeeff <br> A 4 xb <br> A4 xbeeff | P rPf rPO rPf rPO frPP fIfrPf fIPrPf | - ------ d $^{\text {a }} 0$ |
| ANDB \#opr8i <br> ANDB opr8a <br> ANDB opr16a <br> ANDB oprx0_xysppc <br> ANDB oprx9,xysppc <br> ANDB oprx16,xysppc <br> ANDB [D, xysppc] <br> ANDB [oprx16,xysppc] | AND with $B ;(B) \bullet(M) \Rightarrow B$ or $(B) \cdot i m m \Rightarrow B$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | C4 ii D 4 dd F4 hh ll E4 xb E4 xb ff E4 xb ee ff E4 xb E4 xb ee ff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ------- $\Delta \Delta \Delta^{\text {a }} 0$ |
| ANDCC \#opr8i | AND with CCR; (CCR)•imm $\Rightarrow$ CCR | IMM | 10 ii | P |  |
| ASL opr16aSame as LSL <br> ASL oprx0_xysp <br> ASL oprx9, xysppc <br> ASL oprx16,xysppc <br> ASL[D,xysppc] <br> ASL [oprx16,xysppc] <br> ASLASame as LSLA <br> ASLBSame as LSLB | Arithmetic shift left A Arithmetic shift left B | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 78 hh ll 68 xb 68 xb ff 68 xb ee ff 68 xb 68 xb ee ff 48 58 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 |  |
| ASLDSame as LSLD |  | INH | 59 | $\bigcirc$ | ------\| $\Delta \Delta \Delta \Delta \Delta$ |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X HINZVC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ASR opr16a ASR oprx0_xysppc ASR oprx9, xysppc ASR oprx16,xysppc ASR [D,xysppc] ASR [oprx16,xysppc] ASRA ASRB | Arithmetic shift right A Arithmetic shift right B | EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> INH <br> INH | 77 hh ll 67 xb 67 xb ff 67 xb ee ff 67 xb 67 xb ee ff 47 57 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 |  |
| BCC rel8Same as BHS | $\begin{aligned} & \text { Branch if } \mathrm{C} \text { clear; if } \mathrm{C}=0 \text {, then } \\ & (\mathrm{PC})+2+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 24 rr | PPP (branch) <br> P (no branch) | -----\|-|-|--|- |
| BCLR opr8a, msk8 BCLR opr16a, msk8 BCLR oprx0_xysppc, msk8 BCLR oprx9, xysppc, msk8 BCLR oprx16,xysppc, msk8 | Clear bit(s) in M; (M)•mask byte $\Rightarrow \mathrm{M}$ | $\begin{array}{\|l} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | 4D dd mm <br> 1D hh 11 mm <br> OD xb mm <br> OD xb ff mm <br> 0D xb ee ff mm | rPwo rPwP rPwo rPwP frPwPo | ------\| $\Delta\|\Delta\| 0 \mid-$ |
| BCS rel8Same as BLO | $\begin{aligned} & \text { Branch if } \mathrm{C} \text { set; if } \mathrm{C}=1 \text {, then } \\ & (\mathrm{PC})+2+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 25 rr | PPP (branch) P (no branch) | ------------\| |
| BEQ rel8 | Branch if equal; if $Z=1$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 27 rr | PPP (branch) <br> P (no branch) | ---------\|--|- |
| BGE rel8 | Branch if $\geq 0$, signed; if $\mathrm{N} \oplus \mathrm{V}=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 2Crr | PPP (branch) P (no branch) | ------------\| |
| BGND | Enter background debug mode | INH | 00 | VfPPP | $\square$ |
| BGT rel8 | $\begin{aligned} & \begin{array}{l} \text { Branch if }>0, \text { signed; if } \mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{~V})=0, \\ \text { then }(\mathrm{PC})+2+r e l \Rightarrow \mathrm{PC} \end{array} \end{aligned}$ | REL | 2Err | PPP (branch) P (no branch) | - - - - - - - - - - - - |
| BHI rel8 | Branch if higher, unsigned; if $C \mid Z=0$, then ( PC ) $+2+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 22 rr | PPP (branch) P (no branch) | ---------\|---| |
| BHS rel8Same as BCC | Branchifhigherorsame,unsigned;if $\mathrm{C}=0$, then $(\mathrm{PC})+2+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 24 rr | PPP (branch) P (no branch) | - ----\|-|-|---| |
| BITA \#opr8i <br> BITA opr8a <br> BITA opr16a <br> BITA oprx0_xysppc <br> BITA oprx9, xysppc <br> BITA oprx16,xysppc <br> BITA [D, xysppc] <br> BITA [oprx16,xysppc] | $\begin{aligned} & \text { Bit test A; (A)•(M) } \\ & \text { or (A)•imm } \end{aligned}$ |  <br> IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 85 ii <br> 95 dd <br> B5 hh 11 <br> A5 xb <br> A5 xb ff <br> A5 xbeeff <br> A5 xb <br> A5 xbeeff | P rPf rPo rPf rPo frPP fIfrPf fIPrPf |  |
| BITB \#opr8i BITB opr8a BITB opr16a BITB oprx0_xysppc BITB oprx9, xysppc BITB oprx16,xysppc BITB [D,xysppc] BITB [oprx16,xysppc] | $\begin{aligned} & \text { Bit test B; (B)•(M) } \\ & \text { or (B)•imm } \end{aligned}$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | C5 ii <br> D5 dd <br> F5 hhll <br> E5 xb <br> E5 xb ff <br> E5 xb eeff <br> E5 xb <br> E5 xbeeff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ------\| $\Delta\|\Delta\| 0 \mid-$ |
| BLE rel8 | $\begin{aligned} & \text { Branch if } \leq 0, \text { signed; if } Z \mid(N \oplus V)=1, \\ & \text { then }(P C)+2+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 2 Frr | PPP (branch) P (no branch) | -----\|-|-|---| |
| BLO rel8Same as BCS | $\begin{aligned} & \text { Branch if lower, unsigned; if } \mathrm{C}=1, \\ & \text { then (PC)+2+rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 25 rr | PPP (branch) P (no branch) | - - - - - - - - - - - - - |
| BLS rel8 | Branch if lower or same, unsigned; if $\mathrm{C} \mid \mathrm{Z}=1$, then $(\mathrm{PC})+2+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 23 rr | PPP (branch) P (no branch) | - ----\|------|- |
| BLT rel8 | Branch if < 0 , signed; if $\mathrm{N} \oplus \mathrm{V}=1$, then (PC)+2+rel $\Rightarrow$ PC | REL | 2Drr | PPP (branch) P (no branch) | --------\|---| |
| BMI rel8 | $\begin{aligned} & \text { Branch if minus; if } \mathrm{N}=1 \text {, then } \\ & \text { (PC) }+2+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 2Brr | PPP (branch) P (no branch) | - ----\|-|-|---| |
| BNE rel8 | Branch if not equal to 0 ; if $Z=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | REL | 26 rr | PPP (branch) P (no branch) | - ---\|-|-|-|---| |
| BPL rel8 | Branch if plus; if $\mathrm{N}=0$, then (PC) $+2+$ rel $\Rightarrow$ PC | REL | 2Arr | PPP (branch) P (no branch) | -----\|-|-|--|- |
| BRA rel8 | Branch always | REL | 20 rr | PPP | -----\|-|-|---| |


| Source Form | Operation | $\begin{aligned} & \text { Address } \\ & \text { Mode } \end{aligned}$ | Machine Coding (Hex) | Access Detail | SXHINZVC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| BRCLR opr8a, msk8, rel8 BRCLR opr16a, msk8, rel8 BRCLR oprx0_xysppc, msk8, rel8 BRCLR oprx9, xysppc, msk8, rel8 BRCLR oprx16,xysppc, msk8, rel8 | Branch if bit(s) clear; if (M)•(mask byte) $=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | $\begin{array}{\|l\|} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | $4 \mathrm{~F} \mathrm{ddmm} r$ r <br> 1 Fhh 11 mmrr <br> 0F xb mm rr <br> 0 Fxb ff mmrr <br> 0F xbee ff mmrr |  | --\|----|-|- |
| BRN rel8 | Branch never | REL | 21 rr | P | ---------- |
| BRSET opr8, msk8, rel8 BRSET opr16a, msk8, rel8 BRSET oprx0_xysppc, msk8, rel8 BRSET oprx9, xysppc, msk8, rel8 BRSET oprx16,xysppc, msk8, rel8 | $\begin{aligned} & \text { Branch if bit(s) set; if } \\ & (\bar{M}) \cdot(\text { mask byte })=0 \text {, then } \\ & (\mathrm{PC})+2+\text { rel } \Rightarrow P C \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { DR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | 4E dd mm rr <br> 1E hh ll mmrr <br> $0 \mathrm{Exb} \mathrm{mm} r \mathrm{r}$ <br> $0 \mathrm{Exb} \mathrm{ff} \mathrm{mm} r \mathrm{r}$ <br> 0 Exb ee ffmmrr |  | - ---\|-|-|-|-| |
| BSET opr8, msk8 <br> BSET opr16a, msk8 <br> BSET oprx0_xysppc, msk8 <br> BSET oprx9, xysppp, msk8 <br> BSET oprx16,xysppc, msk8 | Set bit(s) in M (M) $\mid$ mask byte $\Rightarrow M$ | $\begin{array}{\|l\|} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \hline \end{array}$ | 4 Cdd mm <br> 1 C hh 11 mm <br> 0 C xb mm <br> 0 Cxb ffmm <br> 0C xb ee ff mm | $\begin{aligned} & \hline \text { rPwo } \\ & \text { rPwP } \\ & \text { rPwo } \\ & \text { rPwP } \\ & \text { frPwPO } \end{aligned}$ | $\square-----\Delta \Delta \Delta^{-1}$ |
| BSR rel8 | $\begin{aligned} & \text { Branch to subroutine; (SP)-2 } \Rightarrow \text { SP } \\ & \text { RTN }_{\mathrm{H}}: \text { RTN } \mathrm{L} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1} \\ & \text { (PC) }+2+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 07 rr | SPPP | -1-\|-|--|-|-| |
| BVC rel8 | $\begin{aligned} & \text { Branch if } \mathrm{V} \text { clear; if } \mathrm{V}=0 \text {, then } \\ & (\mathrm{PC})+2+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 28 rr | PPP (branch) <br> P (no branch) | - ---\|----|-|- |
| BVS rel8 | $\begin{aligned} & \text { Branch if } V \text { set; if } V=1 \text {, then } \\ & \text { (PC) }+2+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 29 rr | PPP (branch) <br> P (no branch) | - ---------\|- |
| CALL opr16a, page CALL oprx0_xysppc, page CALL oprx9, xysppc, page CALL oprx16,xysppc, page CALL [D, xysppc] CALL [oprx16, xysppc] | $\begin{aligned} & \text { Call subroutine in expanded memory } \\ & (S P)-2 \Rightarrow S P \\ & R T N_{H}: R T N_{L} \Rightarrow M_{S P}: M_{S P+1} \\ & (S P)-1 \Rightarrow S P ;(P P G) \Rightarrow M_{S P} \\ & \text { pg } \Rightarrow P P A G E \text { register } \\ & \text { subroutine address } \Rightarrow P C \end{aligned}$ | $\begin{aligned} & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & {[D, 1 D X]} \\ & {[I D X 2]} \end{aligned}$ | 4A hh ll pg 4B xb pg 4B xb ff pg 4B xb ee $f f \mathrm{pg}$ 4B xb eeff | gnSsPPP <br> gnSsPPP <br> gnSsPPP <br> fgnSsPPP <br> fIignSsPPP fignSsPPP <br> fIignSsPPP | - ---\|---|-|- |
| CBA | Compare A to B; (A)-(B) | INH | 17 | $\bigcirc$ |  |
| CLCSame as ANDCC \#\$FE | Clear C bit | IMM | 10 FE | P | -----------0 |
| CLISame as ANDCC \#\$EF | Clear I bit | IMM | 10 EF | P | -----0---\|-| |
| CLR opr16a CLR oprx0_xysppc CLR oprx9,xysppc CLR oprx16,xysppc CLR [D, xysppc] CLR [oprx16,xysppc] CLRA CLRB | Clear $M ; \$ 00 \Rightarrow M$Clear A; $\$ 00 \Rightarrow A$ <br> Clear $B ; \$ 00 \Rightarrow B$ | EXT <br> IDX <br> IDX1 <br> IDX2 <br> [DIDX] <br> IDX2] <br> INH <br> INH <br> 1 | 79 hh ll 69 xb 69 xb ff 69 xb ee ff 69 xb 69 xb ee ff 87 $\mathrm{C7}$ | $\begin{aligned} & \hline \text { Pwo } \\ & \text { Pw } \\ & \text { Pwo } \\ & \text { PwP } \\ & \text { PIfw } \\ & \text { PIPw } \\ & 0 \\ & 0 \end{aligned}$ | - ---\|-01100 |
| CLVSame as ANDCC \#\$FD | Clear V | IMM | 10 FD | P | - ---------\|0|- |
| CMPA \#opr8i MPA opr8a CMPA oprx0_xysppc CMPA oprx9, xysppc CMPA oprx16,xysppc CMPA [D, xysppc] CMPA [oprx16,xysppc] | $\begin{aligned} & \text { Compare A } \\ & \text { (A)-(M) or }(\mathrm{A}) \text {-imm } \end{aligned}$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> IM | $\begin{aligned} & \hline 81 \mathrm{ii} \\ & 91 \mathrm{dd} \\ & \text { B1 hh ll } \\ & \text { A1 xb } \\ & \text { A1 xb ff } \\ & \text { A1 xb ee ff } \\ & \text { A1 xb } \\ & \text { A1 xb ee ff } \end{aligned}$ | P rPf rPO rPf rPD frPP fIfrff fIPrPf | - ------\| $\Delta \Delta \Delta \Delta$ |
| CMPB \#opr8i MPB opr8a MPB MMB oprxo_xyspp CMPB oprx16,xysppo CMPB [D, xysppc] CMPB[oprx16,xysppc] | $\begin{aligned} & \text { Compare B } \\ & \text { (B)-(M) or (B)-imm } \end{aligned}$ | IDM IMR DRT EXX IDX IDX1 IDX2 ID,IDX] $[$ IDX2] | C1 ii <br> D1 dd <br> F1 hh 11 <br> E1 xb <br> E1 xb ff <br> E1 xbeeff <br> E1 xb <br> E1 xbeeff | P rPf rPO rPf Pro frPP fIfrff fIPrPf | -------\|t| |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H IN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| COM opr16a COM oprx0_xysppc COM oprx9, xysppc COM oprx16,xysppc COM [D, xysppc] COM [oprx16,xysppc] COMA COMB | Complement M ; $(\overline{\mathrm{M}})=\$ \mathrm{FF}-(\mathrm{M}) \Rightarrow \mathrm{M}$ <br> Complement $\mathrm{A} ;(\overline{\mathrm{A}})=\$ \mathrm{FF}-(\mathrm{A}) \Rightarrow \mathrm{A}$ <br> Complement $\mathrm{B} ;(\overline{\mathrm{B}})=\mathrm{FFF}-(\mathrm{B}) \Rightarrow \mathrm{B}$ | EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> INH <br> INH | 71 hh ll 61 xb 61 xb ff 61 xb ee ff 61 xb 61 xb ee ff 41 51 | $\begin{aligned} & \hline \text { rPwo } \\ & \text { rPw } \\ & \text { rPwo } \\ & \text { frPwP } \\ & \text { fIfrPw } \\ & \text { fIPrPw } \\ & 0 \\ & 0 \end{aligned}$ |  |
| CPD \#opr16i CPD opr8a CPD opr16a CPD oprx0_xysppc CPD oprx9,xysppc CPD oprx16,xysppc CPD [D,xysppc] CPD [oprx16,xysppc] | $\begin{aligned} & \text { Compare D } \\ & (A: B)-(M: M+1) \\ & \text { or }(A: B)-i m m \end{aligned}$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \end{array}$ | 8C jjkk 9 C dd BC hh 11 AC xb AC xb ff AC xbeeff $\mathrm{AC} x \mathrm{~b}$ <br> AC xbeeff |  | - ------ $\Delta \Delta \Delta \Delta \Delta$ |
| CPS \#opr16i CPS opr8a CPS opr16a CPS oprx0_ xysppc CPS oprx9,xysppc CPS oprx16,xysppc CPS[D,xysppc] CPS [oprx16,xysppc] | Compare SP (SP)-(M:M+1) or (SP)-imm | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8F jjkk $9 F \mathrm{dd}$ BF hh ll AF xb AF xb ff AF xbee ff AF xb AF xb ee ff |  | ------- $\Delta \Delta \Delta \Delta \Delta$ |
| CPX\#opr16i CPX opr8a CPX opr16a CPX oprx0_xysppc CPX oprx9,xysppc CPX oprx16,xysppc CPX [D,xysppc] CPX[oprx16,xysppc] | $\begin{aligned} & \text { Compare X } \\ & \text { (X)-(M:M+1) } \\ & \text { or (X)-imm } \end{aligned}$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \end{array}$ |  |  | - ----\|-| $\Delta \Delta \Delta \Delta \Delta$ |
| CPY \#opr16i CPY opr8a CPY opr16a CPY oprx0_xysppo CPY oprx9,xysppc CPY oprx16,xysppc CPY [D,xysppc] CPY [oprx16,xysppc] | $\begin{aligned} & \text { Compare } \mathrm{Y} \\ & \text { (Y)-(M:M+1) } \\ & \text { or }(\mathrm{Y})-\mathrm{imm} \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8D jjkk <br> 9D dd <br> BD hh 11 <br> AD xb <br> AD xb ff <br> AD xb eeff <br> AD xb <br> $A D x b$ ee ff | PO RPf RPO RPf RPO fRPP fIfRPf fIPRP $f$ | - ----\|-| $\Delta \Delta \Delta \Delta \Delta$ |
| DAA | Decimal adjust A for BCD | INH | 1807 | Ofo |  |
| DBEQ abdxysp, rel9 | Decrement and branch if equal to 0 (counter) $-1 \Rightarrow$ counter if (counter) $=0$, then branch | $\begin{array}{\|l\|l\|} \hline \text { REL } \\ \text { (9-bit) } \end{array}$ | 04 lb rr | PPP (branch) PPO (no branch) | ------------ |
| DBNE abdxysp, rel9 | Decrementand branch ifnotequal to 0; (counter) $-1 \Rightarrow$ counter; if (counter) $\neq 0$, then branch | $\begin{aligned} & \hline \begin{array}{l} \text { REL } \\ \text { (9-bit) } \end{array} \end{aligned}$ | 04 lbrr | $\begin{array}{ll} \hline \text { PPP } & \text { (branch) } \\ \text { PPO } & \text { (no branch) } \end{array}$ | - ---------\|-- |
| DEC opr16a DEC oprx0- xysppc DEC opr9,xysppc DEC oprx16,xysppc DEC [D, xysppc] DEC [oprx16,xysppc] DECA DECB | Decrement M ; (M)-1 $\Rightarrow \mathrm{M}$ <br> Decrement $A$; $(A)-1 \Rightarrow A$ Decrement $B$; $(B)-1 \Rightarrow B$ | EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> INH <br> INH | 73 hh ll 63 xb 63 xb ff 63 xb ee ff 63 xb 63 xb ee ff 43 53 | $\begin{aligned} & \hline \text { rPwo } \\ & \text { rPw } \\ & \text { rPwo } \\ & \text { frPwP } \\ & \text { fIfrPw } \\ & \text { fIPrPw } \\ & 0 \\ & 0 \end{aligned}$ | ------\| $\Delta \Delta \Delta \Delta \mid$ |
| DESSame as LEAS -1,SP | Decrement SP; (SP)-1 $=$ SP | IDX | 1B 9F | Pf | - - ---\|-|-|-|-| |
| DEX | Decrement $X$; $(X)-1 \Rightarrow X$ | INH | 09 | 0 | -----\|-|-| ${ }^{-1-\square}$ |
| DEY | Decrement $\mathrm{Y} ;(\mathrm{Y})-1 \Rightarrow \mathrm{Y}$ | INH | 03 | $\bigcirc$ | ---\|-|-|-| $\Delta\|-\|-\|$ |
| EDIV | Extended divide, unsigned; 32 by 16 to 16-bit; $(Y: D) \div(X) \Rightarrow Y ;$ remainder $\Rightarrow D$ | INH | 11 | ffffffffffo |  |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H I N V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EDIVS | Extended divide,signed; 32 by 16 to 16-bit; (Y:D) $\div(\mathrm{X}) \Rightarrow \mathrm{Y}$ remainder $\Rightarrow \mathrm{D}$ | INH | 1814 | Offffffffffo |  |
| EMACS opr16a | Extended multiply and accumulate, signed; $\left(\mathrm{M}_{\mathrm{X}}: \mathrm{M}_{\mathrm{X}+1}\right) \times\left(\mathrm{M}_{\mathrm{Y}}: \mathrm{M}_{\mathrm{Y}+1}\right)+$ $(\mathrm{M} \sim \mathrm{M}+3) \Rightarrow \mathrm{M} \sim \mathrm{M}+3$; 16 by 16 to 32 -bit | Special | 1812 hh 11 | ORROfffRRfWWP | --\|-|-|-| $\Delta\|\Delta\| \Delta \mid \Delta$ |
| EMAXD oprx0_xysppc EMAXD oprx9,xysppc EMAXD oprx16,xysppc EMAXD [D, xysppc] EMAXD [oprx16,xysppc] | Extended maximum in D; put larger of 2 unsigned 16 -bit values in D $\operatorname{MAX[}[\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)] \Rightarrow \mathrm{D}$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(D)-(M:M+1)] | $\begin{aligned} & \hline \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | 181 Axb 181 Axb ff 181 Axb ee ff 181 Axb 181 Axb ee ff | ORPf <br> ORPO <br> OfRPP <br> OfIfRPf <br> OfIPRPf |  |
| EMAXM oprx0_xysppc EMAXM oprx9,xysppc EMAXM oprx16,xysppc EMAXM [D,xysppc] EMAXM [oprx16,xysppc] | Extended maximum in M; put larger of 2 unsigned 16-bit values in $M$ $\operatorname{MAX}[(D),(M: M+1)] \Rightarrow M: M+1$ $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(D)-(M:M+1)] | $\begin{aligned} & \mathrm{IDX} \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | 181 Exb 181 Exb ff 181 Exb ee ff 181 Exb 181 Exb ee ff | ORPW ORPWO OfRPWP OfIfRPW OfIPRPW | ----\|-|-| $\Delta\|\Delta\| \Delta \mid \Delta$ |
| EMIND oprx0_xysppc EMIND oprx9,xysppc EMIND oprx16,xysppc EMIND [D,xysppc] EMIND [oprx16,xysppc] | Extended minimum in D; put smaller of 2 unsigned 16-bit values in D $\operatorname{MIN}[(\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)] \Rightarrow \mathrm{D}$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(D)-(M:M+1)] | $\begin{array}{\|l\|} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{array}$ | 181 Bxb 18 Bxb Bf 18 Bxb ee ff 18 Bx Bb 181 Bxb ee ff | ORPf <br> ORPO <br> OfRPP <br> OfIfRPf <br> OfIPRPf | ----\|-|-| $\Delta\|\Delta\| \Delta\|\Delta\|$ |
| EMINM oprx0_xysppc EMINM oprx9, xysppc EMINM oprx16,xysppc EMINM [D,xysppc] EMINM [oprx16,xysppc] | Extended minimum in M; put smaller of <br> 2 unsigned 16 -bit values in M $\operatorname{MIN}[(D),(M: M+1)] \Rightarrow M: M+1$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(D)-(M:M+1)] | IDX IDX1 IDX2 [D,IDX] [IDX2] | 181 Fxb 181 Fxb ff 181 Fx ee ff 181 Fxb 181 Fxb ee ff | ORPW ORPWO OfRPWP OfIfRPW OfIPRPW | --\|-|-|-| $\Delta\|\Delta\| \Delta \mid \Delta$ |
| EMUL | Extended multiply, unsigned $(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D} ; 16$ by 16 to 32 -bit | INH | 13 | ffo | --\|-|-|-| $\Delta\|\Delta\|-\|\Delta\|$ |
| EMULS | Extended multiply, signed $(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D} ; 16$ by 16 to 32 -bit | INH | 1813 | OfO <br> Offo (if followed by page 2 instruction) | --\|-|-|-| $\Delta\|\Delta\|-\mid s$ |
| EORA \#opr8i EORA opr8a EORA opr16a EORA oprx0_xysppc EORA oprx9,xysppc EORA oprx16,xysppc EORA [D, xysppc] EORA [oprx 16, xysppc] | Exclusive OR A <br> $(A) \oplus(M) \Rightarrow A$ <br> or $(A) \oplus i m m \Rightarrow A$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | 88 ii 98 dd B8 hh ll A8 xb A8 xb ff A8 xb ee ff A8 xb A8 xb ee ff | ```P rPf rPO rPf rPO frPP fIfrPf fIPrPf``` |  |
| EORB \#opr8i EORB opr8a EORB opr16a EORB oprx0_xysppc EORB oprx9, xysppc EORB oprx16,xysppc EORB [D, xysppc] EORB [oprx16,xysppc] | Exclusive ORB <br> (B) $\oplus(\mathrm{M}) \Rightarrow \mathrm{B}$ <br> or (B) $\oplus \mathrm{imm} \Rightarrow \mathrm{B}$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | C8 ii D8 dd F8 hh ll E8 xb E8 xb ff E8 xb ee ff E8 xb E8 xbee ff | P <br> rPf <br> rPO <br> rPf <br> rPO <br> frPP <br> fIfrPf <br> fIPrPf | --\|-|-|-| $\Delta\|\Delta\| 0 \mid-$ |
| ETBL oprx0_xysppc | Extended table lookup and interpolate, 16-bit; (M:M+1)+ $[(B) \times((M+2: M+3)-(M: M+1))] \Rightarrow D$ | IDX | 183 Fxb | ORRffffffP | --\|-|-|-| $\Delta\|\Delta\|-\|\Delta\|$ |
| Before executing ETBL, initialize B with fractional part of lookup value; initialize index register to point to first table entry (M:M+1). No extensions or indirect addressing allowed. |  |  |  |  |  |
| EXG abcdxysp,abcdxysp | Exchange register contents $(r 1) \Leftrightarrow(r 2) r 1$ and $r 2$ same size $\$ 00:(r 1) \Rightarrow r 2 r 1=8-b i t ; r 2=16$-bit $\left(r 1_{\mathrm{L}}\right) \Leftrightarrow(\mathrm{r} 2) \mathrm{r} 1=16$-bit; $\mathrm{r} 2=8$-bit | INH | B7 eb | P | --\|-|-|-|-|-|-| |
| FDIV | Fractional divide; ( D$) \div(\mathrm{X}) \Rightarrow \mathrm{X}$ remainder $\Rightarrow \mathrm{D}$; 16 by 16-bit | INH | 1811 | Offffffffffo |  |

User Guide - S12CPU15Ftersscale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H IN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IBEQ abdxysp, re/9 | Increment and branch if equal to 0 (counter) $+1 \Rightarrow$ counter <br> If (counter) $=0$, then branch | $\begin{array}{\|l\|l} \text { REL } \\ \text { (9-bit) } \end{array}$ | 04 lb rr | PPP (branch) <br> PPO (no branch) |  |
| IBNE abdxysp, rel9 | Increment and branch if not equal to 0 (counter) $+1 \Rightarrow$ counter <br> If (counter) $\neq 0$, then branch | $\begin{aligned} & \hline \text { REL } \\ & \text { (9-bit) } \end{aligned}$ | 04 lb rr | PPP (branch) <br> PPO (no branch) | ---\|-|-|-|-|-| |
| IDIV | Integer divide, unsigned; (D) $\div(\mathrm{X}) \Rightarrow \mathrm{X}$ Remainder $\Rightarrow \mathrm{D}$; 16 by 16-bit | INH | 1810 | Offffffffffo |  |
| IDIVS | Integer divide, signed; ( D$) \div(\mathrm{X}) \Rightarrow \mathrm{X}$ Remainder $\Rightarrow \mathrm{D}$; 16 by 16 -bit | INH | 1815 | Offffffffffo |  |
| INC opr16a INC oprx0_xysppc INC oprx9, xysppc INC oprx16,xysppc INC [D, xysppc] INC [oprx 16, xysppc] INCA INCB | Increment M ; $(\mathrm{M})+1 \Rightarrow \mathrm{M}$ <br> Increment $A ;(A)+1 \Rightarrow A$ Increment $B ;(B)+1 \Rightarrow B$ |  <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> INH <br> INH | 72 hh ll 62 xb 62 xb ff 62 xb ee ff 62 xb 62 xb ee ff 42 52 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 |  |
| INSSame as LEAS 1,SP | Increment SP; (SP)+1 $\Rightarrow$ SP | IDX | 1B 81 | Pf | ---\|---|-|-|- |
| INX | Increment $X ;(X)+1 \Rightarrow X$ | INH | 08 | $\bigcirc$ |  |
| INY | Increment $\mathrm{Y} ;(\mathrm{Y})+1 \Rightarrow \mathrm{Y}$ | INH | 02 | $\bigcirc$ |  |
| JMP opr16a JMP oprx0_xysppc JMP oprx9, xysppc JMP oprx16,xysppc JMP [D,xysppc] JMP [oprx16,xysppc] | Jump <br> Subroutine address $\Rightarrow P C$ | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | 06 hh ll 05 xb 05 xb ff 05 xb ee ff 05 xb 05 xb ee ff | PPP PPP PPP fPPP fIfPPP fIfPPP | - - -\|-|-|-|-|-| |
| JSR opr8a JSR opr16a JSR oprx0_xysppc JSR oprx9,xysppc JSR oprx16,xysppc JSR [D,xysppc] JSR [oprx16,xysppc] | Jump to subroutine $\begin{aligned} & \text { (SP)-2 } \Rightarrow \mathrm{SP} \\ & \text { RTN }_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1} \\ & \text { Subroutine address }^{2} \mathrm{PC} \end{aligned}$ | IDIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | $\begin{aligned} & \hline 17 \mathrm{dd} \\ & 16 \mathrm{hh} \mathrm{ll} \\ & 15 \mathrm{xb} \\ & 15 \mathrm{xb} \mathrm{ff} \\ & 15 \mathrm{xb} \mathrm{ee} \mathrm{ff} \\ & 15 \mathrm{xb} \\ & 15 \mathrm{xb} \text { ee ff } \end{aligned}$ | SPPP SPPP PPPS PPPS fPPPS fIfPPPS fIfPPPS | ---1--\|-1--|-| |
| LBCC rel16Same as LBHS | Long branch if C clear; if $\mathrm{C}=0$, then (PC) $+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 1824 qqrr | OPPP (branch) OPO (no branch) |  |
| LBCS rel16Same as LBLO | Long branch if C set; if $\mathrm{C}=1$, then (PC) $+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 1825 qqrr | OPPP (branch) opo (no branch) |  |
| LBEQ rel16 | Long branch if equal; if $Z=1$, then (PC) $+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 1827 qqrr | OPPP (branch) OPO (no branch) | --- -- - - - -- |
| LBGE rel16 | Long branch if $\geq 0$, signed If $N \oplus V=0$, then $(P C)+4+r e l \Rightarrow P C$ | REL | 182 Cqqrr | OPPP (branch) OPO (no branch) | - - -\|-|-|-|-|-| |
| LBGT rel16 | Long branch if $>0$, signed If $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$, then $(\mathrm{PC})+4+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 182 Eqqrr | OPPP (branch) OPO (no branch) |  |
| LBHI rel16 | Long branch if higher, unsigned If $C$ \| $Z=0$, then ( $P C$ ) $+4+r e l \Rightarrow P C$ | REL | 1822 qqrr | OPPP (branch) OPO (no branch) |  |
| LBHS rel16Same as LBCC | Long branch if higher or same, unsigned; If $\mathrm{C}=0$, (PC) $+4+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 1824 qqrr | OPPP (branch) OPO (no branch) | ---\|--|-|-|-| |
| LBLE rel16 | Long branch if $\leq 0$, signed; if $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$, then $(\mathrm{PC})+4+r e l \Rightarrow \mathrm{PC}$ | REL | 182 Fqqrr | OPPP (branch) OPO (no branch) | - - - - - - - - - - |
| LBLO rel16Same as LBCS | Long branch if lower, unsigned; if $\mathrm{C}=1$, then ( PC ) $+4+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 1825 qqrr | OPPP (branch) OPO (no branch) |  |
| LBLS rel16 | Long branch if lower or same, unsigned; If $C \mid Z=1$, then (PC) $+4+$ rel $\Rightarrow P C$ | REL | 1823 qqrr | OPPP (branch) OPO (no branch) | - - - - - - - - - - - - |
| LBLT rel16 | Long branch if $<0$, signed If $N \oplus V=1$, then $(P C)+4+r e l \Rightarrow P C$ | REL | 18 2D qq rr | OPPP (branch) OPO (no branch) |  |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X HIN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LBMI rel16 | Long branch if minus If $\mathrm{N}=1$, then $(\mathrm{PC})+4+$ rel $\Rightarrow \mathrm{PC}$ | REL | 18 2B qq rr | OPPP (branch) OPO (no branch) | ------------\| |
| LBNE rel16 | Long branch if not equal to 0 If $Z=0$, then ( PC ) $+4+$ rel $\Rightarrow P C$ | REL | 1826 qq rr | OPPP (branch) opo (no branch) | - ----1---\|-|-| |
| LBPL rel16 | Long branch if plus If $\mathrm{N}=0$, then $(\mathrm{PC})+4+\mathrm{rel} \Rightarrow \mathrm{PC}$ | REL | 18 2A qq rr | OPPP (branch) OPO (no branch) | - ------------ |
| LBRA rel16 | Long branch always | REL | 1820 qq rr | OPPP | ---\|-|-|--|-|- |
| LBRN rel16 | Long branch never | REL | 1821 qq rr | OPO | - -----\|------ |
| LBVC rel16 | $\begin{aligned} & \text { Long branch if } \mathrm{V} \text { clear } \\ & \text { If } \mathrm{V}=0 \text {, then }(\mathrm{PC})+4+\text { rel } \Rightarrow \mathrm{PC} \end{aligned}$ | REL | 1828 qq rr | OPPP (branch) OPO (no branch) | - ------------ |
| LBVS rel16 | $\begin{aligned} & \text { Long branch if } V \text { set } \\ & \text { If } V=1 \text {, then }(P C)+4+\text { rel } \Rightarrow P C \end{aligned}$ | REL | 1829 qqrr | OPPP (branch) OPO (no branch) | - ------------ |
| LDAA \#opr8i <br> LDAA opr8a <br> LDAA opr16a <br> LDAA oprx0_xysppc <br> LDAA oprx9,xysppc <br> LDAA oprx16,xysppc <br> LDAA [D, xysppc] <br> LDAA [oprx16,xysppc] | Load A $(\mathrm{M}) \Rightarrow A$ or imm $\Rightarrow A$ | IMM IMR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 86 ii 96 dd B 6 hh ll A 6 xb A 6 xb ff A 6 xb ee ff A 6 xb A 6 xb ee ff | P rPff rPO rPf rPo frPP fIfrPf fIPrPf |  |
| LDAB \#opr8i <br> LDAB opr8a <br> LDAB opr16a <br> LDAB oprx0_xysppc <br> LDAB oprx9,xysppc <br> LDAB oprx16,xysppc <br> LDAB [D, xysppc] <br> LDAB [oprx16,xysppc] | Load B $(\mathrm{M}) \Rightarrow \mathrm{B}$ or imm $\Rightarrow B$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | C6 ii <br> D6 dd <br> F6 hh 11 <br> E6 xb <br> E6 xb ff <br> E6 xb eeff <br> E6 xb <br> E6 xb eeff | $\begin{aligned} & \hline \mathrm{P} \\ & \text { rPf } \\ & \text { rPO } \\ & \text { rPf } \\ & \text { rPo } \\ & \text { frPP } \\ & \text { fIfrPf } \\ & \text { fIPrPf } \end{aligned}$ |  |
| LDD \#opr16i <br> LDD opr8a <br> LDD opr16a <br> LDD oprx0_xysppc <br> LDD oprx9,xysppc <br> LDD oprx16,xysppc <br> LDD [D,xysppc] <br> LDD [oprx16,xysppc] | $\begin{aligned} & \text { Load D } \\ & (M: M+1) \Rightarrow A: B \\ & \text { or imm } \Rightarrow A: B \end{aligned}$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | CC jjkk <br> DC dd <br> FC hh 11 <br> EC xb <br> EC xb ff <br> EC xbeeff <br> EC xb <br> EC xb eeff | PO RPf RPO RPf RPO fRPP fIfRPf fIPRPf | -----\|-| $\Delta \Delta \Delta 0 \mid-2$ |
| LDS \#opr16i <br> LDS opr8a <br> LDS opr16a <br> LDS oprx0_xysppc <br> LDS oprx9,xysppc <br> LDS oprx16,xysppc <br> LDS [D,xysppc] <br> LDS [oprx16,xysppc] | Load SP $(\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{SP}$ or $\mathrm{imm} \Rightarrow \mathrm{SP}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | CF jjkk <br> DF dd <br> FF hh 11 <br> EF xb <br> EF xbff <br> EF xb eeff <br> EF xb <br> EF xbeeff | PO RPf RPO RPf RPO fRPP fIfRPf fIPRPf | ------\| $\Delta \Delta \Delta 0 \mid-$ |
| LDX \#opr16i <br> LDX opr8a <br> LDX opr16a <br> LDX oprx0_xysppc <br> LDX oprx9, xysppc <br> LDX oprx16,xysppc <br> LDX [D,xysppc] <br> LDX [oprx16,xysppc] | $\begin{aligned} & \text { Load X } \\ & (M: M+1) \Rightarrow X \\ & \text { or } \mathrm{imm} \Rightarrow X \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | CE jjkk DE dd FE hh ll EE xb EE xb ff EExbee ff EExb EE xb ee ff | Po RPf RPO RPf RPO fRPP fIfRPf fIPRPf | ----\|-| $\Delta\|\Delta\| 0 \mid-$ |
| LDY \#opr16i <br> LDY opr8a <br> LDY opr16a <br> LDY oprx0_xysppc <br> LDY oprx9,xysppc <br> LDY oprx16,xysppc <br> LDY [D,xysppc] <br> LDY [oprx16,xysppc] | $\begin{aligned} & \text { Load Y } \\ & (\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{Y} \\ & \text { or imm } \Rightarrow \mathrm{Y} \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | CD jjkk <br> DD dd <br> FD hh 11 <br> ED xb <br> ED xbff <br> ED xb ee ff <br> ED xb <br> ED xb ee ff | $\begin{array}{\|l\|} \hline \text { PO } \\ \text { RPf } \\ \text { RPO } \\ \text { RPf } \\ \text { RPO } \\ \text { fRPP } \\ \text { fIfRPf } \\ \text { fIPRPf } \end{array}$ | - -----\| $\Delta\|\Delta\| 0 \mid-$ |

User Guide - S12CPU15F̛̣̂riscale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H N Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LEAS oprx0_xysppc LEAS oprx9, xysppc LEAS oprx16,xysppc | Load effective address into SP $E A \Rightarrow S P$ | $\begin{array}{\|l\|} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | $\begin{aligned} & 1 \mathrm{Bxb} \\ & 1 \mathrm{~B} \times \mathrm{ff} \\ & 1 \mathrm{Bxb} \text { ee ff } \end{aligned}$ | $\begin{aligned} & \mathrm{Pf} \\ & \mathrm{PO} \\ & \mathrm{PP} \end{aligned}$ | - $--\|-\|-\|-\|-\| ~$ |
| LEAX oprx0_xysppc LEAX oprx9, xysppc LEAX oprx16,xysppc | Load effective address into $X$ $E A \Rightarrow X$ | $\begin{array}{\|l\|} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | 1A xb <br> 1 A xb ff <br> $1 A x b$ eeff | $\begin{aligned} & \mathrm{Pf} \\ & \mathrm{PO} \\ & \mathrm{PP} \end{aligned}$ | -----\|---|---| |
| LEAY oprx0_xysppc LEAY oprx9, xysppc LEAY oprx16,xysppc | Load effective address into Y $E A \Rightarrow Y$ | $\begin{array}{\|l\|} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | $\begin{aligned} & 19 \mathrm{xb} \\ & 19 \mathrm{xb} \mathrm{ff} \\ & 19 \mathrm{xb} \text { ee ff } \end{aligned}$ | $\begin{aligned} & \hline \mathrm{Pf} \\ & \mathrm{PO} \\ & \mathrm{PP} \end{aligned}$ | --\|-|-|-|-|-|-| |
| LSL opr16aSame as ASL <br> LSL oprxO_xysppc <br> LSL oprx9,xysppc <br> LSL oprx16,xysppc <br> LSL [D,xysppc] <br> LSL[oprx16,xysppc] <br> LSLASame as ASLA <br> LSLBSame as ASLB | Logical shift left A Logical shift left B | EXT <br> IDX <br> IDX1 <br> IDX2 <br> $[D, I D X]$ <br> [IDX2] <br> INH <br> INH | 78 hh ll 68 xb 68 xb ff 68 xb ee ff 68 xb 68 xb ee ff 48 58 | rOPw <br> rPw <br> rPOw <br> frPPw <br> fIfrPw <br> fIPrPw <br> 0 <br> 0 |  |
| LSLDSame as ASLD |  | INH | 59 | $\bigcirc$ |  |
| LSR opr16a LSR oprx0_xysppc LSR opry9, xysppc LSR oprx16,xysppc LSR [D, xysppp] LSR [oprx16, xysppc] LSRA LSRB |  |  <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> INH <br> INH | 74 hh ll 64 xb 64 xb ff 64 xb ee ff 64 xb 64 xb ee ff 44 54 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 |  |
| LSRD |  | INH | 49 | $\bigcirc$ |  |
| MAXA oprx0_xysppc MAXA oprx9, xysppc MAXA oprx16,xysppc MAXA [D, xysppc] MAXA [oprx16,xysppc] | Maximum in A; put larger of 2 unsigned 8-bit values in A $\operatorname{MAX[}(\mathrm{A}),(\mathrm{M})] \Rightarrow \mathrm{A}$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | IDX IDX1 IDX2 [D,IDX] $[$ IDX2] | 1818 xb 1818 xb ff 1818 xb ee ff 1818 xb 1818 xb ee ff | OrPf OrPo OfrPP OfIfrpf OfIPrPf | ------\| $\Delta \mid \Delta \Delta \Delta$, |
| MAXM oprxO_xysppc MAXM oprx9,xysppc MAXM oprx16,xysppc MAXM [D, xysppc] MAXM [oprx16,xysppc] | Maximum in M; put larger of 2 unsigned 8-bit values in M $\operatorname{MAX}[(A),(M)] \Rightarrow M$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | IDX IDX1 IDX2 [D,IDX] [IDX2] | $\begin{aligned} & 18 \mathrm{Clxb} \\ & 18 \mathrm{Cxb} \mathrm{Cf} \\ & 18 \mathrm{Cxb} \text { ee ff } \\ & 18 \mathrm{Cl} \times \mathrm{b} \\ & 18 \mathrm{Cl} \text { x ee } \mathrm{ff} \end{aligned}$ | OrPw OrPwo OfrPwP OfIfrPw OfIPrPw |  |
| MEM | Determine grade of membership; $\mu$ (grade) $\Rightarrow \mathrm{M}_{\mathrm{Y}} ;(\mathrm{X})+4 \Rightarrow \mathrm{X} ;(\mathrm{Y})+1 \Rightarrow \mathrm{Y}$ If $(A)<P 1$ or $(A)>P 2$, then $\mu=0$; else $\mu=$ $\operatorname{MIN}[((\mathrm{A})-\mathrm{P} 1) \times \mathrm{S} 1,(\mathrm{P} 2-(\mathrm{A})) \times \mathrm{S} 2$, \$FF] (A)=current crisp input value; X points at 4 data bytes (P1, P2, S1, S2) of a trapezoidal membership function; Y points at fuzzy input (RAM location) | Special | 01 | RRfOw | ---\|?-|? ? ? ? ? |
| MINA oprx0_xysppc MINA oprx9,xysppc MINA oprx16,xysppc MINA [D, xysppc] MINA [oprx16,xysppc] | Minimum in A; put smaller of 2 unsigned 8-bit values in A $\operatorname{MIN}[(A),(\mathrm{M})] \Rightarrow A$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | IDX IDX1 IDX2 $\left[\begin{array}{l}\text { [D,IDX] } \\ \text { [DX2] }\end{array}\right]$ | 1819 xb 1819 xb ff 1819 xb ee ff 1819 xb 1819 xb ee ff | OrPf OrPO OfrPP OfIfrPf OfIPrPf | -----\|-| $\Delta \mid \Delta \Delta \Delta$, |
| MINM oprx0_xysppc MINM oprx9,xysppc MINM oprx16,xysppc MINM [D, xysppc] MINM [oprx16,xysppc] | Minimum in N ; put smaller of two unsigned 8 -bit values in M $\operatorname{MIN}[(A),(M)] \Rightarrow M$ <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}, \mathrm{C}$ bits reflect result of internal compare [(A)-(M)] | IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | $\begin{aligned} & \text { 18 1D xb } \\ & 18 \text { 1D xb ff } \\ & 18 \text { 1D xb ee ff } \\ & 18 \text { 1D xb } \\ & 18 \text { 1D xb ee ff } \end{aligned}$ | OrPw <br> OrPwo <br> OfrPwP <br> OfIfrPw <br> OfIPrPw | ------- $\Delta\|\Delta\| \Delta \mid \Delta$ |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X HINZVC |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MOVB \#opr8, opr16a <br> MOVB \#opr8i, oprx0_xysppc <br> MOVB opr16a, opr16a <br> MOVB opr16a, oprx0_xysppc <br> MOVB oprx0_xysppc, opr16a <br> MOVB oprx0_xysppc, oprx0_xysppc | Move byte <br> Memory-to-memory 8-bit byte-move $\left(M_{1}\right) \Rightarrow M_{2}$ <br> First operand specifies byte to move | $\begin{aligned} & \text { IMM-EXT } \\ & \text { IMMT-IDX } \\ & \text { EXT-EXT } \\ & \text { EXT-IDX } \\ & \text { IDX-EXT } \\ & \text { IDX-IDX } \end{aligned}$ |  | $\begin{aligned} & \hline \text { OPwP } \\ & \text { OPwo } \\ & \text { OrPwPo } \\ & \text { OPrPw } \\ & \text { OrPwP } \\ & \text { OrPwo } \end{aligned}$ | -1-------\|-|- |
| MOVW \#oprx16, opr16a <br> MOVW \#opr16i, oprx0_xysppc <br> MOVW opr16a, opr16a <br> MOVW opr16a, oprx0_xysppc <br> MOVW oprx0_xysppc, opr16a <br> MOVW oprx0_xysppc, oprx0_xysppc | Move word <br> Memory-to-memory 16-bitword-move $\left(M_{1}: M_{1}+1\right) \Rightarrow M_{2}: M_{2}+1$ <br> First operand specifies word to move | $\begin{array}{\|l\|} \hline \text { IMM-EXT } \\ \text { IMMM-IDX } \\ \text { EXT-EXT } \\ \text { EXT-IDX } \\ \text { IDX-EXT } \\ \text { IDX-IDX } \end{array}$ | $\left\|\begin{array}{l\|}1803 \mathrm{jjkhhhll} \\ 1800 \mathrm{xbjjkk} \\ 1804 \mathrm{hh} \mathrm{ll} \mathrm{hhll} \\ 1801 \mathrm{xb} \mathrm{hh} \mathrm{ll} \\ 1805 \mathrm{xb} \mathrm{hhll} \\ 1802 \mathrm{xb} \mathrm{xb}\end{array}\right\|$ | $\begin{aligned} & \hline \text { OPWPO } \\ & \text { OPPW } \\ & \text { ORPWPO } \\ & \text { OPRPW } \\ & \text { ORPWP } \\ & \text { ORPWO } \end{aligned}$ | -----\|-|-|---| |
| MUL | Multiply, unsigned $(A) \times(B) \Rightarrow A: B ; 8$ by 8 -bit | INH | 12 | $\bigcirc$ | ------------ ${ }^{\text {a }}$ |
| NEG opr16a <br> NEG oprx0_xysppc <br> NEG oprx9, xysppc <br> NEG oprx16,xysppc <br> NEG [D,xysppc] <br> NEG [oprx16,xysppc] <br> NEGA <br> NEGB | Negate $\mathrm{M} ; 0-(\mathrm{M}) \Rightarrow \mathrm{M}$ or $(\overline{\mathrm{M}})+1 \Rightarrow \mathrm{M}$ <br> Negate $A ; 0-(A) \Rightarrow A$ or $(\overline{\mathrm{A}})+1 \Rightarrow A$ <br> Negate $\mathrm{B} ; 0-(\mathrm{B}) \Rightarrow \mathrm{B}$ or $(\overline{\mathrm{B}})+1 \Rightarrow \mathrm{~B}$ | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \\ & \text { INH } \\ & \text { INH } \end{aligned}$ | 70 hh ll 60 xb 60 xb ff 60 xb ee ff 60 xb 60 xb ee ff 40 50 | rPwo rPw rPwo frPwP fIfrPw fIPrPw 0 0 | ------\| $\Delta \mid \Delta \Delta \Delta$ |
| NOP | No operation | INH | A7 | $\bigcirc$ | ---1- |
| ORAA \#opr8i ORAA opr8a ORAA opr16a ORAA oprx0_xysppc ORAA oprx9,xysppc ORAA oprx16,xysppc ORAA [D, xysppc] ORAA [oprx16,xysppc] | OR accumulator A <br> (A) \| (M) $\Rightarrow A$ <br> or (A) $\mid \mathrm{imm} \Rightarrow A$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8A ii 9A dd BA hh ll AA xb AA xb ff AA xb ee ff AA xb AA xb ee $f f$ | P rPf rPO rPf rPo frPP fIfrPf fIPrPf |  |
| ORAB \#opr8i ORAB opr8a ORAB opr16a ORAB oprxO_xysppc ORAB oprx9,xysppc ORAB oprx16,xysppc ORAB [D,xysppc] ORAB [oprx16,xysppc] | OR accumulator $B$ <br> (B) \| (M) $\Rightarrow B$ <br> or (B) \| imm $\Rightarrow B$ | $\begin{aligned} & \hline \text { IMM } \\ & \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [DIDX] } \\ & \text { [IDX2] } \end{aligned}$ | CAii <br> DA dd <br> FA hh 11 <br> EA xb <br> EA $x b f f$ <br> EA xb eeff <br> EA xb <br> EA xb ee ff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | -----\|-| $\Delta\|\Delta\| 0 \mid$ |
| ORCC \#opr8i | OR CCR; (CCR) \| imm $\Rightarrow$ CCR | IMM | 14 ii | P |  |
| PSHA | Push A ; (SP) $-1 \Rightarrow$ SP; $(A) \Rightarrow M_{\text {SP }}$ | INH | 36 | Os | ----\|------- |
| PSHB | Push B; (SP)-1 $\Rightarrow$ SP; $(\mathrm{B}) \Rightarrow \mathrm{M}_{\text {SP }}$ | INH | 37 | Os | ------------ |
| PSHC | $\begin{aligned} & \text { Push CCR; (SP) }-1 \Rightarrow \text { SP; } \\ & (\mathrm{CCR}) \Rightarrow \mathrm{M}_{\mathrm{SP}} \end{aligned}$ | INH | 39 | Os | - ----\|------- |
| PSHD | $\begin{aligned} & \text { Push D } \\ & (S P)-2 \Rightarrow S P ;(A: B) \Rightarrow M_{S P}: M_{S P+1} \end{aligned}$ | INH | 3B | os | ---------\|--| |
| PSHX | $\begin{aligned} & \text { Push } X \\ & (S P)-2 \Rightarrow S P ;\left(X_{H}: X_{L}\right) \Rightarrow M_{S P}: M_{S P+1} \end{aligned}$ | INH | 34 | os | - ----1----\|-|- |
| PSHY | $\begin{aligned} & \text { Push } Y \\ & (S P)-2 \Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{S P}: M_{S P+1} \end{aligned}$ | INH | 35 | os | -----\|---|---| |
| PULA | $\begin{aligned} & \text { Pull A } \\ & \left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{A} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 32 | ufo | ----\|-|-|-|-| |
| PULB | $\begin{aligned} & \text { Pull B } \\ & \left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{B} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 33 | ufo | - ----\|-|-|---|- |
| PULC | $\begin{aligned} & \text { Pull CCR } \\ & \left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{CCR} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 38 | ufo | $\Delta \backslash \downarrow \Delta \Delta \Delta \Delta \Delta \Delta \Delta \Delta$ |
| PULD | $\begin{aligned} & \text { Pull D } \\ & \left(M_{\mathrm{SP}}: M_{S P+1}\right) \Rightarrow A: B ;(S P)+2 \Rightarrow S P \end{aligned}$ | INH | 3A | Ufo | ------------\|- |

## : User Guide - S12CPU15UGEP:Scale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H IN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| PULX | $\begin{aligned} & \text { Pull } X \\ & \left(\mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 30 | Ufo | -1---\|---|-|-- |
| PULY | $\begin{aligned} & \text { Pull } Y \\ & \left(\mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 31 | Ufo | - - - - - - - - - - - - |
| REV | Rule evaluation, unweighted; find smallest rule input; store to rule outputs unless fuzzy output is larger | Special | 183 A |  | ---??-\?? ${ }^{\text {a }}$ ? |
| *The $t \wedge t x$ loop is executed once for each element in the rule list. The ^ denotes a check for pending interrupt requests. **These are additional cycles caused by an interrupt: ff is the exit sequence and Orft^ is the re-entry sequence. |  |  |  |  |  |
| REVW | Rule evaluation, weighted; rule weights optional; find smallest rule input; store to rule outputs unless fuzzy output is larger | Special | 18 3B | ORf ( $t^{\wedge}$ Tx) O* <br> or <br> ORf(r^ffRf) O** <br> ffffforft^*** <br> fffflorfr^**** | ---??-\|??? ${ }^{\text {a }}$ ! |

${ }^{*}$ With weighting not enabled, the $t^{\wedge}$ Tx loop is executed once for each element in the rule list. The ${ }^{\wedge}$ denotes a check for pending interrupt requests. **With weighting enabled, the $t^{\wedge} T x$ loop is replaced by $r^{\wedge} £ f R f$.
${ }^{* * *}$ Additional cycles caused by an interrupt when weighting is not enabled: $f f f f$ is the exit sequence and ORft^ is the re-entry sequence. ${ }^{* * * *}$ Additional cycles caused by an interrupt when weighting is enabled: $f f f f$ is the exit sequence and $O R f r^{\wedge}$ is the re-entry sequence.

| ROL opr16a ROL oprxO_xysppc ROL oprx9,xysppc ROL oprx16,xysppc ROL [D,xysppc] ROL [oprx16,xysppc] ROLA ROLB | Rotate left A Rotate left B | $\begin{array}{\|l} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{array}$ | 75 hh ll 65 xb 65 xb ff 65 xb ee ff 65 xb 65 xb ee ff 45 55 | $\begin{aligned} & \hline r P w O \\ & \text { rPw } \\ & \text { rPwo } \\ & \text { frPwP } \\ & \text { fIfrPw } \\ & \text { fIPrPw } \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ROR opr16a ROR oprx0_xysppc ROR oprx9, xysppc ROR oprx16,xysppc ROR [D,xysppc] ROR [oprx16,xysppc] RORA RORB | Rotate right A Rotate right $B$ | $\begin{array}{\|l} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{array}$ | 76 hh ll 66 xb 66 xb ff 66 xb ee ff 66 xb 66 xb ee ff 46 56 | $\begin{aligned} & \hline \text { rPwo } \\ & \text { rPw } \\ & \text { rPwo } \\ & \text { frPwP } \\ & \text { fIfrPw } \\ & \text { fIPrPw } \end{aligned}$ | -----\|-| $\Delta \Delta \Delta \Delta \Delta$ |
| RTC | $\begin{aligned} & \text { Return from call; }\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \text { PPAGE } \\ & (\mathrm{SP})+1 \Rightarrow \mathrm{SP} ; \\ & \left(\mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}} \\ & (\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 0A | UUnfPPP | - ---\|-|-|-|-|-|- |
| RTI | $\begin{aligned} & \text { Return from interrupt } \\ & \left(M_{S P}\right) \Rightarrow C C R ;(S P)+1 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow B: A ;(S P)+2 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow X_{H}: X_{L} ;(S P)+4 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow P C_{H}: P C_{L} ;(S P)+2 \Rightarrow S P \\ & \left(M_{S P}: M_{S P+1}\right) \Rightarrow Y_{H}: Y_{L} ;(S P)+4 \Rightarrow S P \end{aligned}$ | INH | OB | uUUUUPPP or uUUUUfVfPPP* |  |
| *RTI takes 11 cycles if an interrupt is pending. |  |  |  |  |  |
| RTS | $\begin{aligned} & \text { Return from subroutine } \\ & \left(\mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{H}: \mathrm{PC}_{\mathrm{L}} ; \\ & (\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ | INH | 3D | UfPPP | ---\|-|-|-|-|-| |
| SBA | Subtract B from A; (A)-(B) $\Rightarrow$ A | INH | 1816 | 00 |  |
| SBCA \#opr8i SBCA opr8a SBCA opr16a SBCA oprx0_xysppc SBCA oprx9, xysppc SBCA oprx16,xysppc SBCA [D, xysppc] SBCA [oprx16,xysppc] | Subtract with carry from A <br> (A)-(M)-C $\Rightarrow A$ <br> or (A)-imm-C $\Rightarrow A$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{array}$ | 82 ii <br> 92 dd <br> B2 hh 11 <br> A 2 xb <br> A2 xb ff <br> A2 xb ee ff <br> A2 xb <br> A2 xbeeff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ---\|--- $\Delta \Delta \Delta \Delta \Delta$, |


| Source Form | Operation | Address <br> Mode | Machine Coding (Hex) | Access Detail | S X H IN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SBCB\#opr8i <br> SBCB opr8a <br> SBCB opr16a <br> SBCB oprx0_xysppc <br> SBCB oprx9,xysppc <br> SBCB oprx16,xysppc <br> SBCB [D,xysppc] <br> SBCB [oprx16,xysppc] <br> SECa | Subtract with carry from B (B)-(M)-C $\Rightarrow B$ <br> or (B)-imm-C $\Rightarrow B$ | IMM IDIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C2 ii <br> D2 dd <br> F2 hh 11 <br> E2 xb <br> E2 xb ff <br> E2 xbeeff <br> E2 xb <br> E2 xbeeff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | $\stackrel{----\mid-\Delta \Delta \Delta \Delta \Delta}{ }$ |
| SECSame as ORCC \#\$01 | Set C bit | IMM | 1401 | P | -\|-|-|-|-|-1 |
| SEISame as ORCC \#\$10 | Set I bit | IMM | 1410 | P | - $--\|-11-\|-\|-\|-10$ |
| SEVSame as ORCC \#\$02 | Set V bit | IMM | 1402 | P | ---\|-|-1|- |
| SEX abc,dxyspSame as TFR r1, r2 | Sign extend; 8-bit r1 to 16 -bit r2 $\$ 00:(\mathrm{r} 1) \Rightarrow \mathrm{r} 2$ if bit 7 of r 1 is 0 $\$ F F:(r 1) \Rightarrow r 2$ if bit 7 of $r 1$ is 1 | INH | B7 eb | P | - ---------\|-| |
| STAA opr8a STAA opr16a STAA oprx0_xysppc STAA oprx9,xysppc STAA oprx16,xysppc STAA [D,xysppc] STAA [oprx16,xysppc] | Store accumulator A $(A) \Rightarrow M$ | DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | 5A dd <br> 7A hh 11 <br> 6A xb <br> 6 A xb ff <br> 6A xb ee ff <br> 6A xb <br> 6A xb eeff | Pw Pwo Pw Pw Pwo PwP PIfw PIPw PIP | ------\| $\Delta\|\Delta\| 0 \mid$ |
| STAB opr8a STAB opr16a STAB oprx0_xysppc STAB oprx9,xysppc STAB oprx16,xysppc STAB [D,xysppc] STAB [oprx16,xysppc] | Store accumulator B $(B) \Rightarrow M$ | DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | 5 B dd <br> 7B hh 11 <br> 6B xb <br> 6 Bxb ff <br> 6B xb ee ff <br> 6B xb <br> 6B xb eeff | Pw Pwo Pw Pwo PwP PIfw PIPw | ------\| $\Delta\|\Delta\| 0 \mid$ |
| STD opr8a <br> STD opr16a <br> STD oprx0_xysppc <br> STD oprx9,xysppc <br> STD oprx16,xysppc <br> STD [D,xysppc] <br> STD [oprx16,xysppc] | $\begin{aligned} & \text { Store } D \\ & (A: B) \Rightarrow M: M+1 \end{aligned}$ | DIR EXT IDX IDX1 IDX2 [DIDX] $[$ IDX2] | 5 C dd <br> 7C hh 11 <br> 6 Cxb <br> 6 C xb ff <br> 6 C xb ee ff <br> 6 Cxb <br> 6C xb ee ff | PW <br> PWO <br> PW <br> PWO <br> PWP <br> PIfW <br> PIPW |  |
| STOP | Stop processing; (SP)-2 $\Rightarrow$ SP RTN $_{\mathrm{H}}:$ RTN $_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ (SP)-2 $\Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ (SP)-2 $\Rightarrow \mathrm{SP} ;\left(\mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ (SP) $-2 \Rightarrow S P ;(B: A) \Rightarrow M_{S P}: M_{S P+1}$ $(S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{S P}$ Stop all clocks | INH | 18 3E | OOSSSSsf (enter stop mode) fVfPPP (exit stop mode) ff (continue stop mode) OO (if stop mode disabled by $S=1$ ) | - ----------- |
| STS opr8a STS opr16a STS oprx0_ xysppc STS oprx9,xysppc STS oprx16,xysppc STS [D, xysppp] STS [oprx16,xysppc] | $\left.\begin{array}{l} \text { Store } \mathrm{SP} \\ \left(\mathrm{SP}_{\mathrm{H}}: \mathrm{SP}\right. \end{array}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1$ | DIR EXX IDX IDX1 IDX2 [DIDX] [IDX2] | 5 F dd <br> 7F hh 11 <br> 6 F xb <br> 6 Fxb ff <br> 6 Fxb ee ff <br> 6 F xb <br> 6F xb ee ff | PW <br> PWO <br> PW <br> PWO <br> PWP <br> PIfW <br> PIPW |  |
| STX opr8a STX opr16a STX oprx0_xysppc STX oprx9, xysppc STX oprx16,xysppc STX [D,xysppc] STX [oprx16,xysppc] | $\begin{aligned} & \text { Store } X \\ & \left(X_{H}: X_{L}\right) \Rightarrow M: M+1 \end{aligned}$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [DIDX] } \\ & \text { [IDX2] } \end{aligned}$ | 5 E dd <br> 7E hh 11 <br> 6 Exb <br> 6 Exb ff <br> 6 Exb eeff <br> 6 Exb <br> 6E xb eeff | PW PWO PW PWO PWP PIfW PIPW | ------\| $\Delta \Delta \Delta^{\text {a }} 0$ |

: User Guide - S12CPU15जtert.2cale Semiconductor, Inc.

| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X HIN V C |
| :---: | :---: | :---: | :---: | :---: | :---: |
| STY opr8a STY opr16a STY oprx0_xysppc STY oprx9,xysppc STY oprx16,xysppc STY [D,xysppc] STY [oprx16,xysppc] | $\begin{aligned} & \text { Store } \mathrm{Y} \\ & \left(\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1 \end{aligned}$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \text { [D,IDX] } \\ & \text { [IDX2] } \end{aligned}$ | 5D dd 7D hh ll 6D xb 6D xb ff 6D xb ee ff 6D xb 6D xb ee ff | PW <br> PWO <br> PW <br> PWo <br> PWP <br> PIfW <br> PIPW |  |
| SUBA \#opr8i SUBA opr8a SUBA opr16a SUBA oprx0_xysppc SUBA oprx9, xysppc SUBA opr16,xysppc SUBA [D,xypppc] SUBA [oprx16,xysppc] | $\begin{aligned} & \text { Subtract from } A \\ & \text { (A)-(M) } \Rightarrow A \\ & \text { or }(A) \text {-imm } \Rightarrow A \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 80 ii 90 dd B0 hh ll A0 xb A0 xb ff A0 xb ee ff A0 xb A0 xb ee ff | P rPf rPO rPf rPo frPP fIfrPf fIPrPf | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| SUBB \#opr8i SUBB oprra SUBB opr16a SUBB oprx0-xysppc SUBB oprx9,xysppc SUBB oprx16,xysppc SUBB SUBB [oprspppc] Sopr16,xysppc] | Subtract from B <br> (B)-(M) $\Rightarrow B$ <br> or (B)-imm $\Rightarrow B$ | IMM DIR EXT IDX IDX1 IDX2 [DIDX] [IDX2] | C0 ii D0 dd F0 hh ll E0 xb E0 xb ff E0 xb ee ff E0 xb E0 xb ee ff | P rPf rPO rPf rPO frPP fIfrPf fIPrPf | ------\| $\Delta \Delta \Delta \Delta \Delta$ |
| SUBD \#opr16i SUBD opr8a SUBD opr16a SUBD oprx0_xysppc SUBD oprx9,xysppc SUBD oprx16,xysppc SUBD [D, xysppc] SUBD [oprx16,xysppc] | Subtract from D $(A: B)-(M: M+1) \Rightarrow A: B$ or $(A: B)-i m m \Rightarrow A: B$ | $\begin{array}{\|l} \hline \text { IMM } \\ \text { DR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{array}$ | 83 jjkk 93 dd B3 hhll A3 xb A3 xb ff A3 xbee ff A3 xb A3 xbeeff |  | ------ $\Delta \Delta \Delta \Delta \Delta$ |
| SWI | Software interrupt; (SP)-2 $\Rightarrow$ SP <br> RTN $_{\mathrm{H}}:$ RTN $_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ <br> (SP)-2 $\Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ <br> (SP) $-2 \Rightarrow S P ;\left(X_{H}: X_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ <br> (SP) $-2 \Rightarrow S P ;(B: A) \Rightarrow M_{S P}: M_{S P+1}$ <br> $(S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{S P} ; 1 \Rightarrow 1$ <br> (SWI vector) $\Rightarrow$ PC | INH | 3 F | VSPSSPSsP* | -----\|1---|-- |
| ${ }^{*}$ The CPU also uses VSPSSPSsP for hardware interrupts and unimplemented opcode traps. |  |  |  |  |  |
| TAB | Transfer A to $\mathrm{B} ;(\mathrm{A}) \Rightarrow \mathrm{B}$ | INH | 18 0E | OO | ------\| $\Delta \Delta 0 \mid \square$ |
| TAP | Transfer A to CCR; (A) $\Rightarrow$ CCR Assembled as TFR A, CCR | INH | B7 02 | P | $\Delta \backslash \Downarrow \Delta \Delta \Delta \Delta \Delta \Delta \Delta$ |
| TBA | Transfer B to A; (B) $\Rightarrow$ A | INH | 180 F | 00 | ------\| $\Delta \Delta 00^{\text {a }}$ |
| TBEQ abdxysp,rel9 | Test and branch if equal to 0 If (counter) $=0$, then ( PC ) $+2+$ rel $\Rightarrow \mathrm{PC}$ | $\begin{aligned} & \hline \begin{array}{l} \text { REL } \\ \text { (9-bit) } \end{array} \end{aligned}$ | 04 lb rr | PPP (branch) PPO (no branch) | ----------- |
| TBL oprx0_xysppc | Table lookup and interpolate, 8-bit $(\mathrm{M})+[(\mathrm{B}) \times((\mathrm{M}+1)-(\mathrm{M}))] \Rightarrow \mathrm{A}$ | IDX | 18 3D xb | ORfffP | -----\|-| $\Delta \Delta-\|\Delta\|$ |
| TBNE abdxysp,rel9 | Test and branch if not equal to 0 If (counter) $=0$, then (PC) $+2+$ rel $\Rightarrow \mathrm{PC}$ | $\begin{array}{\|l\|l\|} \hline \text { REL } \\ \text { (9-bit) } \end{array}$ | 04 lbrr | PPP (branch) PPO (no branch) | - ----\|-1--|-- |
| TFR $a b c d x y s p, a b c d x y s p$ | Transfer from register to register $(r 1) \Rightarrow r 2 r 1$ and $r 2$ same size \$00:(r1) $\Rightarrow$ r2r1=8-bit; r2=16-bit $(r 1 \mathrm{~L}) \Rightarrow \mathrm{r} 2 \mathrm{r} 1=16$-bit; $\mathrm{r} 2=8$-bit | INH | B7 eb | P |  |
| TPASame as TFR CCR , A | Transfer CCR to A; (CCR) $\Rightarrow$ A | INH | B7 20 | P | - -\|-|-|-|-|-|- |


| Source Form | Operation | Address Mode | Machine Coding (Hex) | Access Detail | S X H IN V V |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TRAP trapnum |  | INH | $\begin{aligned} & 18 \mathrm{tn} \\ & \mathrm{tn}=\$ 30-\$ 39 \\ & \mathrm{or} \\ & \mathrm{tn}=\$ 40-\$ \mathrm{FF} \end{aligned}$ | OVSPSSPSsP | - ---\|-|1-|-|-| |
| TST opr16a TST oprx0_xysppc TST oprx9, xysppc TST oprx16,xysppc TST [D,xysppc] TST [oprx16,xysppc] TSTA TSTB | Test M; (M)-0 <br> Test A ; (A) $\mathbf{- 0}$ <br> Test B; (B)-0 | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | F7 hh ll E7 xb E7 xb ff E7 xb ee ff E7 xb E7xb ee ff 97 D7 | rPO rPf rPO frPP fIfrPf fIPrPf 0 0 |  |
| TSXSame as TFR SP, X | Transfer SP to X; (SP) $\Rightarrow$ X | INH | B7 75 | P | - ----\|---|--- |
| TSYSame as TFRSP, Y | Transfer SP to Y; (SP) $\Rightarrow$ Y | INH | B7 76 | P | -----\|---|---| |
| TXSSame as TFR X, SP | Transfer X to $\mathrm{SP} ;(\mathrm{X}) \Rightarrow \mathrm{SP}$ | INH | B7 57 | P | - ----\|---|-|-| |
| TYSSame as TFRY,SP | Transfer Y to $\mathrm{SP} ;(\mathrm{Y}) \Rightarrow \mathrm{SP}$ | INH | B7 67 | P | ---------1-- |
| WAI | Wait for interrupt; (SP)-2 $\Rightarrow$ SP RTN $_{\mathrm{H}}:$ RTN $_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ (SP)-2 $\Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{S P}: M_{S P+1}$ (SP) $-2 \Rightarrow \mathrm{SP} ;\left(\mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$ (SP) $-2 \Rightarrow S P ;(B: A) \Rightarrow M_{S P}: M_{S P+1}$ $(S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{S P}$ | INH | 3E | OSSSSS£ (before interrupt) fVfPPP (after interrupt) | $-\|-\|-\|-\|-\|-\|-\|-\|$ <br> or <br> $-\|-\|-\|1\|-\|-\|-\|$ <br> or <br> $-\|1\|-1\|-\|-\|-\|$ |
| WAV | Calculate weighted average; sum of products (SOP) and sum of weights (SOW)* $\begin{aligned} & \sum_{i=1}^{B} S_{i} F_{i} \Rightarrow Y: D \\ & \sum_{i=1}^{B} F_{i} \Rightarrow X \end{aligned}$ | Special | 183 C | $\begin{aligned} & \text { Of (frr} \left.{ }^{\wedge} f f f f\right) \text { O** }^{\text {SSU }} \\ & \text { SSSUUrr^** } \end{aligned}$ |  |

${ }^{*}$ Initialize $\mathrm{B}, \mathrm{X}$, and $\mathrm{Y}: \mathrm{B}=$ number of elements; X points at first element in $\mathrm{S}_{\mathrm{i}}$ list; Y points at first element in $\mathrm{F}_{\mathrm{i}}$ list. All $\mathrm{S}_{\mathrm{i}}$ and $\mathrm{F}_{\mathrm{i}}$ elements are 8-bit values.
${ }^{* *}$ The $f r r^{\wedge} f f f f$ sequence is the loop for one iteration of SOP and SOW accumulation. The ${ }^{\wedge}$ denotes a check for pending interrupt requests.
${ }^{* * *}$ Additional cycles caused by an interrupt: SSS is the exit sequence and UUUrr^ is the re-entry sequence. Intermediate values use six stack bytes.

| wavr* | Resume executing interrupted WAV | Special | 3 C | $\begin{aligned} & \text { UUUrr^ffff(frr^^ } \\ & \text { ffff)0** } \\ & \text { SSS+UUUrı^*** } \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |

[^2]| XGDXSame as EXG D, X | Exchange D with X ; $(\mathrm{D}) \Leftrightarrow(\mathrm{X})$ | INH | B7 C5 | P | -----\|------| |
| :---: | :---: | :---: | :---: | :---: | :---: |
| XGDYSame as EXG D, Y | Exchange D with Y; $(\mathrm{D}) \Leftrightarrow(\mathrm{Y})$ | INH | B7 C6 | P | ------------ |

## : User Guide - S12CPU15UGYes.scale Semiconductor, Inc.

### 5.4.1 Register and Memory Notation

Table 5-2 Register and Memory Notation

| A or a | Accumulator A |
| :---: | :---: |
| An | Bit n of accumulator A |
| B or $b$ | Accumulator B |
| Bn | Bit n of accumulator B |
| D ord | Accumulator D |
| Dn | Bit n of accumulator D |
| X or $x$ | Index register X |
| $\mathrm{X}_{\mathrm{H}}$ | High byte of index register X |
| X ${ }_{\text {L }}$ | Low byte of index register X |
| Xn | Bit n of index register X |
| Y or $y$ | Index register Y |
| $\mathrm{Y}_{\mathrm{H}}$ | High byte of index register Y |
| $Y_{L}$ | Low byte of index register Y |
| Yn | Bit n of index register Y |
| SP or sp | Stack pointer |
| SPn | Bit n of stack pointer |
| PC or $p c$ | Program counter |
| $\mathrm{PC}_{\mathrm{H}}$ | High byte of program counter |
| $\mathrm{PC}_{\mathrm{L}}$ | Low byte of program counter |
| CCR or $c$ | Condition code register |
| M | Address of 8-bit memory location |
| Mn | Bit n of byte at memory location M |
| Rn | Bit n of the result of an arithmetic or logical operation |
| In | Bit n of the intermediate result of an arithmetic or logical operation |
| $\mathrm{RTN}_{\mathrm{H}}$ | High byte of return address |
| $\mathrm{RTN}_{\mathrm{L}}$ | Low byte of return address |
| () | Contents of |

### 5.4.2 Source Form Notation

The Source Form column of the summary in Table 5-1 gives essential information about assembler source forms. For complete information about writing source files for a particular assembler, refer to the documentation provided by the assembler vendor.

Everything in the Source Form column, except expressions in italic characters, is literal information which must appear in the assembly source file exactly as shown. The initial 3- to 5-letter mnemonic is always a literal expression. All commas, pound signs (\#), parentheses, square brackets ( [ or ] ), plus signs $(+)$, minus signs ( - ), and the register designation ( $\mathrm{A}, \mathrm{B}, \mathrm{D}$ ), are literal characters.

The groups of italic characters shown in Table 5-3 represent variable information to be supplied by the programmer. These groups can include any alphanumeric character or the underscore character, but cannot include a space or comma. For example, the groups xysppc and oprx0_xysppc are both valid, but the two groups oprx0 xysppc are not valid because there is a space between them.

Table 5-3 Source Form Notation

| $a b c$ | Register designator for A, B, or CCR |
| :---: | :---: |
| abcdxysp | Register designator for A, B, CCR, D, X, Y, or SP |
| abd | Register designator for A, B, or D |
| abdxysp | Register designator for A, B, D, X, Y, or SP |
| $d x y s p$ | Register designator for D, X, Y, or SP |
| msk8 | 8-bit mask value Some assemblers require the \# symbol before the mask value. |
| opr8i | 8-bit immediate value |
| opr16i | 16-bit immediate value |
| opr8a | 8-bit address value used with direct address mode |
| opr16a | 16-bit address value |
| oprx0_xysp | Indexed addressing postbyte code: <br> oprx3,-xysp - Predecrement X , Y, or SP by 1-8 <br> oprx3,+xysp - Preincrement X, Y, or SP by 1-8 <br> oprx3,xysp- - Postdecrement X, Y, or SP by 1-8 <br> oprx3,xysp+ - Postincrement X, Y, or SP by 1-8 <br> oprx5,xysppc - 5-bit constant offset from X, Y, SP, or PC <br> abd,xysppc - Accumulator A, B, or D offset from X, Y, SP, or PC |
| oprx3 | Any positive integer from 1 to 8 for pre/post increment/decrement |
| oprx5 | Any integer from -16 to +15 |
| oprx9 | Any integer from -256 to +255 |
| oprx16 | Any integer from $-32,768$ to $+65,535$ |
| page | 8-bit value for PPAGE register <br> Some assemblers require the \# symbol before this value. |
| rel8 | Label of branch destination within -256 to +255 locations |
| rel9 | Label of branch destination within -512 to +511 locations |
| rel16 | Any label within the 64K byte memory space |
| trapnum | Any 8-bit integer from \$30 to \$39 or from \$ 40 to \$FF |
| xysp | Register designator for X or Y or SP |
| xysppc | Register designator for X or Y or SP or PC |

### 5.4.3 Operation Notation

Table 5-4 Operation Notation

| + | Add |
| :---: | :--- |
| - | Subtract |
| $\bullet$ | AND |
| $\dot{1}$ | OR |
| $\oplus$ | Exclusive OR |
| $\times$ | Multiply |
| $\div$ | Divide |
| $:$ | Concatenate |
| $\Rightarrow$ | Transfer |
| $\Leftrightarrow$ | Exchange |

### 5.4.4 Address Mode Notation

Table 5-5 Address Mode Notation

| INH | Inherent; no operands in instruction stream |
| ---: | :--- |
| IMM | Immediate; operand immediate value in instruction stream |
| DIR | Direct; operand is lower byte of address from \$0000 to \$00FF |
| EXT | Operand is a 16-bit address |
| REL | Two's complement relative offset; for branch instructions |
| IDX | Indexed (no extension bytes); includes: <br> 5-bit constant offset from X, Y, SP or PC <br> Pre/post increment/decrement by 1-8 <br> Accumulator A, B, or D offset |
| IDX1 | 9-bit signed offset from X, Y, SP, or PC; 1 extension byte |
| IDX2 | 16-bit signed offset from X, Y, SP, or PC; 2 extension bytes |
| [IDX2] | Indexed-indirect; 16-bit offset from X, Y, SP, or PC |
| [D, IDX] | Indexed-indirect; accumulator D offset from X, Y, SP, or PC |

### 5.4.5 Machine Code Notation

In the Machine Code (Hex) column of the summary in Table 5-1, digits 0-9 and upper case letters A-F represent hexadecimal values. Pairs of lower-case letters represent 8-bit values as shown in Table 5-6.

Table 5-6 Machine Code Notation

| dd | 8-bit direct address from \$0000 to \$00FF; high byte is \$00 |
| :---: | :---: |
| ee | High byte of a 16-bit constant offset for indexed addressing |
| eb | Exchange/transfer postbyte |
| ff | Low eight bits of a 9-bit signed constant offset in indexed addressing, or low byte of a 16-bit constant offset in indexed addressing |
| hh | High byte of a 16-bit extended address |
| ii | 8-bit immediate data value |
| jj | High byte of a 16-bit immediate data value |
| kk | Low byte of a 16-bit immediate data value |
| 1b | Loop primitive (DBNE) postbyte |
| 11 | Low byte of a 16-bit extended address |
| mm | 8-bit immediate mask value for bit manipulation instructions; bits that are set indicate bits to be affected |
| pg | Program page or bank number used in CALL instruction |
| qq | High byte of a 16-bit relative offset for long branches |
| tn | Trap number from \$30 to \$39 or from \$40 to \$FF |
| rr | Signed relative offset $\$ 80(-128)$ to $\$ 7 \mathrm{~F}(+127)$ relative to the byte following the relative offset byte, or low byte of a 16-bit relative offset for long branches |
| xb | Indexed addressing postbyte |

### 5.4.6 Access Detail Notation

A single-letter code in the Access Detail column of Table 5-1 represents a single CPU access cycle. An upper-case letter indicates a 16-bit access.

Table 5-7 Access Detail Notation

| f | Free cycle. During an f cycle, the CPU does not use the bus. An f cycle is always one cycle of the <br> system bus clock. An f cycle can be used by a queue controller or the background debug system to <br> perform a single-cycle access without disturbing the CPU. |
| ---: | :--- |
| g | Read PPAGE register. A g cycle is used only in CALL instructions and is not visible on the external <br> bus. Since PPAGE is an internal 8-bit register, a $g$ cycle is never stretched. |
| I | Read indirect pointer. Indexed-indirect instructions use the 16-bit indirect pointer from memory to <br> address the instruction operand. An I cycle is a 16-bit read that can be aligned or misaligned. An I <br> cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the <br> corresponding data is stored in external memory. There can be additional stretching when the <br> address space is assigned to a chip-select circuit programmed for slow memory. An I cycle is also <br> stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle <br> misaligned access. | :User Guide - S12CPU15Utêfiscale Semiconductor, Inc.

Table 5-7 Access Detail Notation (Continued)

| i | Read indirect PPAGE value. An i cycle is used only in indexed-indirect CALL instructions. The 8 -bit PPAGE value for the CALL destination is fetched from an indirect memory location. An i cycle is stretched only when controlled by a chip-select circuit that is programmed for slow memory. |
| :---: | :---: |
| n | Write PPAGE register. An n cycle is used only in CALL and RTC instructions to write the destination value of the PPAGE register and is not visible on the external bus. Since the PPAGE register is an internal 8 -bit register, an $n$ cycle is never stretched. |
| $\bigcirc$ | Optional cycle. An o cycle adjusts instruction alignment in the instruction queue. An o cycle can be a free cycle ( $£$ ) or a program word access cycle (P). When the first byte of an instruction with an odd number of bytes is misaligned, the o cycle becomes a P cycle to maintain queue order. If the first byte is aligned, the o cycle is an f cycle. <br> The $\$ 18$ prebyte for a page-two opcode is treated as a special one-byte instruction. If the prebyte is misaligned, the o cycle at the beginning of the instruction becomes a P cycle to maintain queue order. If the prebyte is aligned, the o cycle is an f cycle. If the instruction has an odd number of bytes, it has a second o cycle at the end. If the first o cycle is a P cycle (prebyte misaligned), the second $o$ cycle is an $f$ cycle. If the first $o$ cycle is an $f$ cycle (prebyte aligned), the second o cycle is a P cycle. <br> An o cycle that becomes a P cycle can be extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An o cycle that becomes an $f$ cycle is never stretched. |
| P | Program word access. Program information is fetched as aligned 16 -bit words. A P cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the program is stored externally. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. |
|  | 8 -bit data read. An $r$ cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| R | 16 -bit data read. An R cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An $R$ cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
| s | Stack 8-bit data. An s cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| S | Stack 16-bit data. An s cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the SP is pointing to external memory. There can be additional stretching if the address space is assigned to a chip-select circuit programmed for slow memory. An s cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. The internal RAM is designed to allow single cycle misaligned word access. |
| w | 8 -bit data write. A w cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| W | 16 -bit data write. A w cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A w cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
| u | Unstack 8-bit data. A w cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |

Table 5-7 Access Detail Notation (Continued)

| U | Unstack 16-bit data. A U cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the SP is pointing to external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A u cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. The internal RAM is designed to allow single-cycle misaligned word access. |
| :---: | :---: |
| V | 16 -bit vector fetch. Vectors are always aligned 16-bit words. A v cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. |
| t | 8-bit conditional read. A t cycle is either a data read cycle or a free cycle, depending on the data and flow of the REVW instruction. A t cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| T | 16-bit conditional read. A T cycle is either a data read cycle or a free cycle, depending on the data and flow of the REV or REVW instruction. A t cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A t cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
| x | 8-bit conditional write. An x cycle is either a data write cycle or a free cycle, depending on the data and flow of the REV or REVW instruction. An x cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| Special Notation for Branch Taken/Not Taken |  |
| PPP/P | A short branch requires three cycles if taken, one cycle if not taken. Since the instruction consists of a single word containing both an opcode and an 8-bit offset, the not-taken case is simple - the queue advances, another program word fetch is made, and execution continues with the next instruction. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address. |
| OPPP / OPO | A long branch requires four cycles if taken, three cycles if not taken. An o cycle is required because all long branches are page two opcodes and thus include the $\$ 18$ prebyte. The prebyte is treated as a one-byte instruction. If the prebyte is misaligned, the o cycle is a P cycle; if the prebyte is aligned, the o cycle is an $f$ cycle. As a result, both the taken and not-taken cases use one o cycle for the prebyte. In the not-taken case, the queue must advance so that execution can continue with the next instruction, and another o cycle is required to maintain the queue. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address. |

### 5.4.7 Condition Code State Notation

Table 5-8 Condition Code State Notation

| - | Not changed by operation |
| :---: | :--- |
| 0 | Cleared by operation |
| 1 | Set by operation |
| $\Delta$ | Set or cleared by operation |
| $\Downarrow$ | May be cleared or remain set, but not set by operation |
| $\Uparrow$ | May be set or remain cleared, but not cleared by operation |
| $?$ | May be changed by operation but final state not defined |
| $!$ | Used for a special purpose |

### 5.5 External Visibility Of Instruction Queue

The instruction queue buffers program information and increases instruction throughput. The queue consists of three 16-bit stages. Program information is always fetched in aligned 16-bit words. Normally, at least three bytes of program information are available to the CPU when instruction execution begins.

Program information is fetched and queued a few cycles before it is used by the CPU. In order to monitor cycle-by-cycle CPU activity, it is necessary to externally reconstruct what is happening in the instruction queue.

Two external pins, IPIPE[1:0], provide time-multiplexed information about data movement in the queue and instruction execution. To complete the picture for system debugging, it is also necessary to include program information and associated addresses in the reconstructed queue.

The instruction queue and cycle-by-cycle activity can be reconstructed in real time or from trace history captured by a logic analyzer. However, neither scheme can be used to stop the CPU at a specific instruction. By the time an operation is visible outside the system, the instruction has already begun execution. A separate instruction tagging mechanism is provided for this purpose. A tag follows the information in the queue as the queue is advanced. During debugging, the CPU enters active background debug mode when a tagged instruction reaches the head of the queue, rather than executing the tagged instruction. For more information about tagging, refer to 14.4.8 Instruction Tagging.

### 5.5.1 Instruction Queue Status Signals

The IPIPE[1:0] signals carry time-multiplexed information about data movement and instruction execution during normal operation. The signals are available on two multifunctional device pins. During reset, the pins are mode-select inputs MODA and MODB. After reset, information on the pins does not become valid until an instruction reaches stage two of the queue.

To reconstruct the queue, the information carried by the status signals must be captured externally. In general, data-movement and execution-start information are considered to be distinct two-bit values, with the low bit on IPIPE0 and the high bit on IPIPE1. Data-movement information is available when E clock is high or on falling edges of the E clock; execution-start information is available when E clock is low or on rising edges of the E clock, as shown in Figure 5-1. Data-movement information refers to data on the
bus. Execution-start information is delayed one bus cycle to guarantee the indicated opcode is in stage three. Table 5-9 summarizes the information encoded on the IPIPE[1:0] pins.


Figure 5-1 Queue Status Signal Timing

Data movement status is valid when the E clock is high and is represented by two states:

- No movement - There is no data shifting in the queue.
- Advance and load from data bus - The queue shifts up one stage with stage one being filled with the data on the read data bus.

Execution start status is valid when the E clock is low and is represented by four states:

- No start - Execution of the current instruction continues.
- Start interrupt - An interrupt sequence has begun.

NOTE: The start-interrupt state is indicated when an interrupt request or tagged instruction alters program flow. SWI and TRAP instructions are part of normal program flow and are indicated as start even or start odd depending on their alignment. Since they are present in the queue, they can be tracked in an external queue rebuild. An external event that interrupts program flow is indeterministic. Program data is not present in the queue until after the vector jump.

- Start even instruction - The current opcode is in the high byte of stage three of the queue.
- Start odd instruction - The current opcode is in the low byte of stage three of the queue.

Table 5-9 IPIPE[1:0] Decoding when E Clock is High

| Data Movement <br> (capture at E fall) | Mnemonic | Meaning |
| :---: | :---: | :--- |
| $0: 0$ | - | No movement |

Table 5-9 IPIPE[1:0] Decoding when E Clock is High

| Data Movement <br> (capture at E fall) | Mnemonic | Meaning |
| :---: | :---: | :--- |
| $0: 1$ | - | Reserved |
| $1: 0$ | ALD | Advance queue and load from bus |
| $1: 1$ | - | Reserved |

Table 5-10 IPIPE[1:0] Decoding when E Clock is Low

| Execution Start <br> (capture at E rise) | Mnemonic | Meaning |
| :---: | :---: | :--- |
| $0: 0$ | - | No start |
| $0: 1$ | INT | Start interrupt sequence |
| $1: 0$ | SEV | Start even instruction |
| $1: 1$ | SOD | Start odd instruction |

The execution-start status signals are delayed by one E clock cycle to allow a lagging program fetch and queue advance. Therefore the execution-start status always refers to the data in stage three of the queue.

The advance and load from bus signal can be used as a load-enable to capture the instruction word on the data bus. This signal is effectively the queue advance signal inside the CPU. Program data is registered into stage one on the rising edge of $t 4$ when queue advance is asserted.

### 5.5.2 No Movement (0:0)

The $0: 0$ state at the falling edge of $E$ indicates that there is no data movement in the instruction queue during the current cycle. The 0:0 state at the rising edge of $E$ indicates continuation of an instruction or interrupt sequence during the previous cycle.

### 5.5.3 ALD - Advance and Load from Data Bus (1:0)

The three-stage instruction queue is advanced by one word and stage one is refilled with a word of program information from the data bus. The CPU requested the information two bus cycles earlier but, due to access delays, the information was not available until the E cycle immediately prior to the ALD.

### 5.5.4 INT — Start Interrupt (0:1)

This state indicates program flow has changed to an interrupt sequence. Normally this cycle is a read of the interrupt vector. However, in systems that have interrupt vectors in external memory and an 8-bit data bus, this cycle reads only the lower byte of the 16-bit interrupt vector.

### 5.5.5 SEV — Start Even Instruction (1:0)

This state indicates that the instruction is in the even (high) half of the word in stage three of the instruction queue. The queue treats the $\$ 18$ prebyte of an instruction on page two of the opcode map as a special
one-byte, one-cycle instruction. However, interrupts are not recognized at the boundary between the prebyte and the rest of the instruction.

### 5.5.6 SOD — Start Odd Instruction (1:1)

This state indicates that the instruction in the odd (low) half of the word in stage three of the instruction queue. The queue treats the $\$ 18$ prebyte of an instruction on page two of the opcode map as a special one-byte, one-cycle instruction. However, interrupts are not recognized at the boundary between the prebyte and the rest of the instruction.
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 6 Exception Processing

Exceptions are events that require a change in the sequence of instruction execution. This section describes the exceptions supported by the Core and their functionality.

### 6.1 Exception Processing Overview

The Core supports two basic types of exceptions; those from resets and those from interrupt requests. Regardless of the source, the first cycle in exception processing is a vector fetch cycle. The exception processing flow is shown in Figure 6-1 below. Relevant points within the flow are detailed in the paragraphs that follow.

## $1.0-\mathrm{V}$

During the vector fetch cycle, the CPU indicates to the system that it is requesting that the vector address of the pending exception having the highest priority be driven onto the address bus. The CPU does not provide this address.

The vector points to the address where the exception service routine begins. Exception vectors are stored in a table at the top of the memory map (\$FFB6-\$FFFF). The CPU begins using the vector to fetch instructions in the third cycle of the exception processing sequence.

After the vector fetch, the CPU selects one of the three processing paths based on the source of the exception:

- Reset
- X bit maskable and I bit maskable interrupt request
- SWI and TRAP


Figure 6-1 Exception Processing Flow

### 6.1.1 Reset Processing

$$
2.0-f
$$

This cycle sets the $\mathrm{S}, \mathrm{X}$ and I bits.

$$
3.0-\mathrm{P} \text { through } 5.0-\mathrm{P}
$$

These cycles are program word fetches that refill the instruction queue. Fetches start at the address pointed to by the reset vector. When the fetches are completed, reset processing ends, and the CPU starts executing the instruction at the head of the instruction queue.

### 6.1.2 Interrupt Processing

The SWI and TRAP interrupts have no mask or interrupt request and are always recognized. An $\overline{\text { XIRQ }}$ interrupt request is recognized any time after the X bit is cleared. An enabled I bit maskable interrupt request is recognized any time after the I bit is cleared. The CPU responds to an interrupt after it completes the execution of its current instruction. Interrupt latency depends on the number of cycles required to complete the instruction.

After the vector fetch, the CPU calculates a return address. The return address depends on the type of exception:

- When an X bit maskable or I bit maskable interrupt causes the exception, the return address points to the next instruction that would have been executed had processing not been interrupted.
- When an SWI opcode or TRAP causes the exception, the return address points to the next address after the SWI opcode or to the next address after the unimplemented opcode.

```
2.1-S and 2.2-S
```

These are both $S$ cycles (16-bit writes) that push the return address onto the stack.

## 3.1-P

This cycle is the first of three program word fetches to refill the instruction queue. Instructions are fetched from the address pointed to by the vector.
4.1-S

This cycle pushes Y onto the stack.

## 5.1-S

This cycle pushes X onto the stack.

## 6.1-P

This cycle is the second of three program word fetches to refill the instruction queue. During this cycle, the contents of the A and B accumulators are concatenated in the order $\mathrm{B}: \mathrm{A}$, making register order in the stack frame the same as that of the M68HC11, M6801, and the M6800.

## 7.1-S

This cycle pushes the 16 -bit word containing B:A onto the stack.
$8.1-\mathrm{s}$ and $8.2-\mathrm{s}$

These are both s cycles (8-bit writes) that push the 8-bit CCR onto the stack and then update the X and I mask bits:

- When an XIRQ interrupt causes the exception, both X and I are set to inhibit further interrupts during exception processing.
- When any other interrupt causes the exception, the I bit is set to inhibit further I bit maskable interrupts during exception processing, but the X bit is not changed.


## 9.1-P

This cycle is the third of three program word fetches to refill the instruction queue. It is the last cycle of exception processing. After this cycle the CPU begins the interrupt service routine by executing the instruction at the head of the instruction queue.

At the end of the interrupt service routine, an RTI instruction restores the stacked registers, and the CPU returns to the return address. RTI is an 8 -cycle instruction when no other interrupt is pending, and an 11 -cycle instruction when another interrupt is pending. In either case, the first five cycles are used to pull the CCR, B:A, X, Y, and the return address from the stack.

If no other interrupt is pending at this point, three program words are fetched to refill the instruction queue from the area of the return address and processing proceeds from there.

If another interrupt is pending after registers are restored, a new vector is fetched, and the stack pointer is adjusted to point at the CCR value that was just recovered ( $\mathrm{SP}=\mathrm{SP}-9$ ). This makes it appear that the registers have been stacked again. After the SP is adjusted, three program words are fetched to refill the instruction queue, starting at the address the vector points to. Processing then continues with execution of the instruction at the head of the queue.

### 6.2 Exception Vectors

Each exception has a 16-bit vector that points to the memory location where the routine that handles the exception is located. Vectors are stored in the upper 128 bytes of the standard 64 K byte address map and are prioritized as shown in Table 6-1 below from highest (system reset) to lowest (lowest priority I maskable interrupt).

Table 6-1 Exception Vector Map and Priority

| Vector Address | Source |
| :---: | :--- |
| \$FFFE-\$FFFF | System reset |
| \$FFFC-\$FFFD | Crystal Monitor reset |
| \$FFFA-\$FFFB | COP reset |
| \$FFF8-\$FFF9 | Unimplemented opcode trap |
| \$FFF6-\$FFF7 | Software interrupt instruction (SWI) or BDM vector request |
| \$FFF4-\$FFF5 | XIRQ signal |
| \$FFF2-\$FFF3 | $\overline{\text { IRQ signal }}$ |
| \$FFF0-\$FF00 | Device-specific I bit maskable interrupt sources (priority in <br> descending order) |

The six highest vector addresses are used for resets and nonmaskable interrupt sources. The remaining vectors are used for maskable interrupts. All vectors must be programmed to point to the address of the appropriate service routine.

### 6.3 Exception Types

As stated previously, the Core supports exceptions from resets within the system as well as interrupt requests. Each of these exception types are discussed in the subsections that follow.

### 6.3.1 Resets

A block (or blocks) within the SoC design must evaluate any/all reset sources and request the proper reset vector from the Core. The CPU then fetches a vector determined by the source of the reset, configures the CPU registers to their reset states and fills the instruction queue from the address pointed to by the vector.

There are three reset sources supported by the Core:

- System reset
- Crystal Monitor reset
- COP Watchdog reset

The priority and vector addresses assigned to these reset sources are shown in Table 6-2 below. Please note that the inclusion of Crystal Monitor and COP reset requests is based upon the two most common and predominately used requests historically implemented in $\mathrm{HC12}$ based systems. (It is assumed that all systems will have a system reset). Each SoC integration of the Core will determine whether the system contains both requests, one or the other or neither request. Each source is described in the subsections that follow.

Table 6-2 Reset Sources

| Reset <br> Source | Exception <br> Priority | Vector <br> Address |
| :--- | :---: | :---: |
| System reset | 1 | \$FFFE-\$FFFF |
| Crystal Monitor block | 2 | \$FFFC-\$FFFD |
| Computer Operating Properly (COP) block | 3 | \$FFFA-\$FFFB |

### 6.3.1.1 System reset

All systems generally have a block or sub-block within the system that determines the validity and priority of all possible sources of a system reset request. When a valid system reset request becomes active, the block or sub-block will request the appropriate reset vector from the Core. The Core will then acknowledge the request and provide the vector.

### 6.3.1.2 Crystal Monitor Reset

A Crystal Monitor sub-block typically contains a mechanism to determine whether or not the system clock frequency is above a predetermined limit. If the clock frequency falls below the limit when the Crystal Monitor is enabled, the sub-block will typically request the reset vector that is associated with this function from the Core.

### 6.3.1.3 COP Reset

A Computer Operating Properly (COP) sub-block helps protect against software failures. When the COP is enabled, software might, for example, write a particular code sequence to a specific address in order to keep a watchdog timer from timing out. If software fails to execute the sequence properly, the sub-block will typically then request a reset vector from the Core.

### 6.3.2 Interrupts

The Core supports the following types of interrupt sources:

- nonmaskable interrupt requests
- Unimplemented Opcode Trap
- Software Interrupt instruction
- $\overline{\text { XIRQ }}$ pin interrupt request
- Maskable interrupt requests
- Optional highest priority maskable interrupt (defaults to $\overline{\mathrm{IRQ}}$ pin)
- $\overline{\mathrm{IRQ}}$ pin interrupt request
- System peripheral block I bit maskable interrupt requests

A block (or blocks) within the SoC design must evaluate the system peripheral block I bit maskable interrupt sources and request the proper interrupt vector from the Core. All other interrupt requests are handled within the Core. Once the CPU receives the request it then fetches the vector to the proper interrupt service routine. The CPU will then calculate and stack a return address and the contents of the CPU registers. Finally, it will set the I bit (and the X bit if $\overline{\mathrm{XIRQ}}$ is the source) and fill the instruction queue from the address pointed to by the vector. The vector mapping for all interrupt sources is shown in Table 6-3 below with detailed descriptions given in the sub-sections that follow.

Table 6-3 Interrupt Sources

| Interrupt <br> Source | Exception <br> Priority | Mask | Vector <br> Address |
| :--- | :---: | :---: | :--- |
| Unimplemented opcode trap (TRAP) | 4 | None | \$FFF8-\$FFF9 |
| Software interrupt instruction (SWI) | 4 | None | \$FFF6-\$FFF7 |
| Nonmaskable external interrupt pin (XIRQ pin) | 5 | X bit | \$FFF4-\$FFF5 |
| Highest priority I-Maskable interrupt (defaults to IRQ pin) | 6 | I bit | \$FFxx-\$FFxx+1 |
| Maskable external interrupt pin (IRQ pin) | 6 or 7 | I bit | \$FFF2-\$FFF3 |
| System peripheral block interrupt requests | $\geq 8$ | I bit | \$FFF0-\$FF00 |

Interrupts can be classified according to their maskability. TRAP and SWI are nonmaskable. The $\overline{\mathrm{XIRQ}}$ pin is masked at reset by the X bit, but once software clears the X bit, the $\overline{\mathrm{XIRQ}}$ pin is nonmaskable until another reset occurs. The remaining interrupt sources can be masked by the I bit. I bit maskable interrupt User Guide - S12CPU15jtereps.scale Semiconductor, Inc.
requests come from the $\overline{\mathrm{IRQ}}$ pin and peripheral blocks within the system such as timers and serial ports. These I bit maskable sources have default priorities that follow the address order of the interrupt vectors: the higher the address, the higher the priority of the interrupt request. The $\overline{\mathrm{IRQ}}$ pin is initially assigned the highest I bit maskable interrupt priority. The system can give one I bit maskable source priority over other I bit maskable sources configured at integration of the Core into the SoC design. The documentation for each system should provide more information.

### 6.3.2.1 Unimplemented Opcode Trap (TRAP)

Only 54 of the 256 positions on page 2 of the opcode map are used. Attempting to execute one of the 202 unused opcodes on page 2 causes a nonmaskable interrupt without an interrupt request. All 202 unused opcodes share the same interrupt vector, \$FFF8:\$FFF9.

TRAP processing stacks the CCR and then sets the I bit to prevent other interrupts during the TRAP service routine. An RTI instruction at the end of the service routine restores the I bit to its preinterrupt state.

The CPU uses the next address after an unimplemented page 2 opcode as a return address. This differs from the M68HC11 illegal opcode interrupt, which uses the address of an illegal opcode as the return address. The stacked return address can be used to calculate the address of the unimplemented opcode for software-controlled traps.

### 6.3.2.2 Software Interrupt Instruction (SWI)

Execution of the SWI instruction causes a nonmaskable interrupt without an interrupt request.
SWI processing stacks the CCR and then sets the I bit to prevent other interrupts during the SWI service routine. An RTI instruction at the end of the service routine restores the I bit to its preinterrupt state.

NOTE: CPU processing of a TRAP or SWI cannot be interrupted. Also, TRAP and SWI are mutually exclusive instructions with no relative priority.

### 6.3.2.3 Nonmaskable External Interrupt Request Pin (XIRQ)

Driving the $\overline{\mathrm{XIRQ}}$ pin low generates an external interrupt request, subject initially to masking by the X bit. Reset sets the X bit, masking $\overline{\mathrm{XIRQ}}$ interrupt requests. Software can unmask $\overline{\mathrm{XIRQ}}$ interrupt requests once after reset by clearing the $X$ bit with an instruction such as ANDCC \# $\$ B F$. After the $X$ bit has been cleared, it cannot be set and XIRQ interrupt requests are nonmaskable until another reset occurs.
$\overline{\mathrm{XIRQ}}$ interrupt request processing stacks the CCR and then sets both the X and I bits to prevent other interrupts during the XIRQ service routine. An RTI instruction at the end of the service routine restores the X and I bits to their preinterrupt states.

### 6.3.2.4 Maskable External Interrupt Request Pin (IRQ)

Driving the $\overline{\text { IRQ }}$ pin low generates an external interrupt request, subject to masking by the I bit. $\overline{\overline{I R Q}}$ interrupt request processing stacks the CCR and then sets the I bit to prevent other interrupts during the $\overline{\overline{I R Q}}$ service routine. An RTI instruction at the end of the service routine restores the I bit to its preinterrupt state.

The Interrupt sub-block of the Core (INT) also has a control bit to disconnect the $\overline{\mathrm{IRQ}}$ input. Please see Section 10 of this guide for a more detailed description.

### 6.3.2.5 System Peripheral Block Interrupt Requests

Some system peripheral blocks can generate interrupt requests that are subject to masking by the I bit. Processing of an interrupt request from one of these sources stacks the CCR and then sets the I bit to prevent other interrupts during the service routine. An RTI instruction at the end of the service routine restores the I bit to its preinterrupt state.

Interrupt requests from a system peripheral block may also be subject to masking by interrupt enable bits in control registers. In addition, there may be interrupt flags with register read-write sequences required for flag clearing. The documentation for the system peripheral block should provide a detailed functional description.
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 7 Core Interface

This section provides a brief description of the Core interface to the rest of the SoC design. Detailed information on the Core interface, such as more complete descriptions of all signals and timing information, is provided in the HCS12 V1.5 Core Integration Guide.

### 7.1 Core Interface Overview

The Core is designed to be integrated into a SoC design as a fully synthesizable block. The Core interface is shown in Figure 7-1 below with the interface signals grouped by function. All signals related to the internal and I.P. bus interfacing appear on the right side of the Core block in the diagram. In addition to bus interfacing, the Core receives reset and clock inputs from the system and provides signals for interacting with the CPU for vector request and acknowledge and for functional operation of the stop and wait modes. The Core interacts with the external blocks of the overall system through the port/pad logic for Ports A, B, E (which include the physical $\overline{\mathrm{IRQ}}$ and $\overline{\mathrm{XIRQ}} \mathrm{pins}$ ) and K and the BDM BKGD pin interfaces. The memory configuration switches shown in the diagram are inputs to the Core block that are tied to a constant logic state at the time of integration into the SoC design to correctly define the on-chip memory configuration for proper Core operation within the system. :User Guide - S12CPU15tuters.scale Semiconductor, Inc.


Figure 7-1 Core Interface Signals

### 7.1.1 Signal Summary

A brief summary of the Core interface signals is given in Table 7-1 below. For detailed descriptions and timing information please consult the HCS12 V1.5 Core Integration Guide.

Table 7-1 Core Interface Signal Definitions

| Signal Name | Type | Functional Description |
| :--- | :---: | :--- |
| Internal Bus Interface Signals |  |  |
| core_ab_t2[19:0] | O | Core 16-bit Address Bus [19:0] |
| peri_rdb_L12[15:0] | I | 16-bit Read Data Bus data from Peripheral block |
| ram_rdb_L12[15:0] | I | 16-bit Read Data Bus data from on-chip RAM array |
| ee_rdb_L12[15:0] | I | 16-bit Read Data Bus data from on-chip EEPROM array |
| fee_rdb_L12[15:0] | I | 16-bit Read Data Bus data from on-chip Flash EEPROM or ROM <br> array |
| core_wdb_t4[15:0] | O | Core 16-bit Write Data Bus [15:0] |
| core_rw_t2 | O | Core Read/Write signal - active low Write |

Table 7-1 Core Interface Signal Definitions

| Signal Name | Type | Functional Description |
| :---: | :---: | :---: |
| core_sz8_t2 | 0 | Core bus data size requested signal 0-16-bit access <br> 1-8-bit access |
| core_exp_t2 | 0 | Expanded Mode selected signal |
| core_per_t2 | 0 | Peripheral Test Mode selected signal |
| core_smod_t2 | 0 | Special Mode selected signal |
| core_secure_t2 | 0 | Core secure mode signal |
| core_perisel_t2 | 0 | Core peripheral select to I.P. Bus Interface |
| core_ramregsel_t2 | 0 | On-chip RAM Register select from Core to memory and/or bus |
| core_ramarraysel_t2 | 0 | On-chip RAM Array select from Core to memory and /or bus |
| core_ramhal_t2 | 0 | On-chip RAM Array align signal from Core to memory and/or bus |
| core_eeregsel_t2 | 0 | On-chip EEPROM Register select from Core to memory and/or bus |
| core_eearraysel_t2 | 0 | On-chip EEPROM Array select from Core to memory and/or bus |
| core_feeregsel_t2 | O | On-chip Flash EEPROM Register select from Core to memory and/or bus |
| core_feearraysel_t2 | O | On-chip Flash EEPROM Array select from Core to memory and/or bus |
| ee_hold_t1 | 1 | On-chip EEPROM signal to Core to suspend CPU operation |
| fee_hold_t1 | 1 | On-chip Flash EEPROM signal to Core to suspend CPU operation |
| secreq | 1 | Security mode request from applicable memory |
| peri_ffxx_t3 | 1 | Interrupt Bus from I.P. Bus Interface |
| peri_rtifff0i_t3 | 1 | Real Time Interrupt signal |
| core_bdmact_t4 | O | Core BDM active signal for I.P. Bus Interface (freeze signal) |
| External Bus Interface Signals |  |  |
| core_paind[7:0] | 1 | Port A input data [7:0] |
| core_pado[7:0] | 0 | Port A data output [7:0] |
| core_paobe[7:0] | O | Port A output buffer enable [7:0] |
| core_paibe_t2 | 0 | Port A input buffer enable |
| core_papue_t2 | O | Port A pullup enable |
| core_padse_t2 | 0 | Port A drive strength enable |
| core_pbind[7:0] | 1 | Port B input data [7:0] |
| core_pbdo[7:0] | 0 | Port B data output [7:0] |
| core_pbobe[7:0] | 0 | Port B output buffer enable [7:0] |
| core_pbibe_t2 | 0 | Port B input buffer enable |
| core_pbpue_t2 | 0 | Port B pullup enable |
| core_pbdse_t2 | O | Port B drive strength enable |
| core_peind[7:0] | 1 | Port E input data [7:0] NOTE: PE1 is $\overline{\mathrm{IRQ}}$ pin input; PE0 is $\overline{\mathrm{XIRQ}}$ pin input. |
| core_pedo[7:0] | 0 | Port E data output [7:0] |
| core_peobe[7:0] | 0 | Port E output buffer enable [7:0] |
| core_peibe_t2 | 0 | Port E input buffer enable |
| core_pepue_t2 | 0 | Port E pullup enable |
| core_mdrste | 0 | Enable signal for EBI Mode pin pullups at the pad |
| core_pedse_t2 | 0 | Port E drive strength enable |

Table 7-1 Core Interface Signal Definitions

| Signal Name | Type | Functional Description |
| :---: | :---: | :---: |
| core_pkind[7:0] | I | Port K input data [7:0] |
| core_pkdo[7:0] | 0 | Port K data output [7:0] |
| core_pkobe[7:0] | 0 | Port K output buffer enable [7:0] |
| core_pkibe_t2 | 0 | Port K input buffer enable |
| core_pkpue_t2 | 0 | Port K pullup enable |
| core_pkdse_t2 | 0 | Port K drive strength enable |
| Clock and Reset Signals |  |  |
| See Section 8 of this guide. |  |  |
| Vector Request/Acknowledge Signals |  |  |
| core_vector_fetch_44 | O | Core CPU vector request |
| peri_rstv_request | I | System level reset vector request |
| peri_xmonv_request | I | System level Crystal Monitor reset vector request |
| peri_copv_request | 1 | System level COP Watchdog reset vector request |
| Stop and Wait Mode Control/Status Signals |  |  |
| See Section 8 of this guide. |  |  |
| Background Debug Mode (BDM) Interface Signals |  |  |
| bkgd_ind | 1 | BDM BKGD pin input data |
| Core_bkgd_dout_t4 | 0 | Data output for BDM BKGD pin |
| core_bkgd_obe | 0 | BDM BKGD pin output buffer enable |
| core_bkgd_ibe_t2 | 0 | BDM BKGD pin input buffer enable |
| core_bkgdpue_t2 | 0 | BDM BKGD pin pullup enable |
| Memory Configuration Signals |  |  |
| reg_sw0 | 1 | Register space size select switch to be tied to the appropriate logic level at system integration: <br> $0-1 \mathrm{~K}$ byte register space aligned to lower address <br> 1-2K byte register space. |
| pag_sw1 | 1 | On-chip memory size select switch bit 1 to be tied to the appropriate logic level at system integration. |
| pag_sw0 | 1 | On-chip memory size select switch bit 0 to be tied to the appropriate logic level at system integration. |
| ram_fmts | 1 | On-chip RAM fast memory transfer select to be tied to the appropriate logic level at system integration. |
| ram_sw2 | 1 | On-chip RAM size select switch bit 2 to be tied to the appropriate logic level at system integration. |
| ram_sw1 | 1 | On-chip RAM size select switch bit 1 to be tied to the appropriate logic level at system integration. |
| ram_sw0 | 1 | On-chip RAM size select switch bit 0 to be tied to the appropriate logic level at system integration. |
| eep_sw1 | 1 | On-chip EEPROM size select switch bit 1 to be tied to the appropriate logic level at system integration. |
| eep_sw0 | 1 | On-chip EEPROM size select switch bit 0 to be tied to the appropriate logic level at system integration. |
| rom_sw1 | 1 | On-chip Flash EEPROM or ROM size select switch bit 1 to be tied to the appropriate logic level at system integration. |
| rom_sw0 | 1 | On-chip Flash EEPROM or ROM size select switch bit 0 to be tied to the appropriate logic level at system integration. |

Table 7-1 Core Interface Signal Definitions

| Signal Name | Type | Functional Description |
| :--- | :---: | :--- |
| romon_exp_state |  | Reset state of the ROMON bit in the MISC Register to be tied to the <br> appropriate literal logic level at system integration (i.e. tied level is the <br> state out of reset and not inverted). |
| Scan Control Interface Signals |  |  |
| ipt_scan_mode | I | Scan mode select signal |

### 7.2 Signal Descriptions

General descriptions of the Core interface signals are given in the subsections below. The clock, reset and wait and stop mode signals are discussed in Section 8 of this guide. For detailed descriptions of these signals including timing information please consult the HCS12 V1.5 Core Integration Guide.

### 7.2.1 Internal Bus Interface Signals

These descriptions apply to the Core signals that interface with the on-chip memories either directly or through the Core bus and with the system peripheral blocks through the I.P. Bus Interface.

### 7.2.1.1 Core 20-bit Address Bus (core_ab_t2[19:0])

This 20-bit wide Core output provides the Core Address Bus to the system memory and peripheral blocks.

### 7.2.1.2 16-bit Read Data Bus from system peripheral blocks (peri_rdb_L12[15:0])

16-bit wide Read Data Bus input to the Core from the system peripherals via the I.P. Bus Interface block.

### 7.2.1.3 16-bit Read Data Bus from on-chip RAM (ram_rdb_L12[15:0])

16-bit wide Read Data Bus input to the Core from the on-chip RAM memory block.

### 7.2.1.4 16-bit Read Data Bus from on-chip EEPROM (ee_rdb_L12[15:0])

16-bit wide Read Data Bus input to the Core from the on-chip EEPROM memory block.

### 7.2.1.5 16-bit Read Data Bus from on-chip Flash EEPROM or ROM (fee_rdb_L12[15:0])

 16-bit wide Read Data Bus input to the Core from the on-chip Flash EEPROM or ROM memory block.
### 7.2.1.6 Core 16-bit Write Data Bus (core_wdb_t4[15:0])

This 16-bit wide Core output provides the Core Write Data Bus to the system memory and peripheral blocks.

### 7.2.1.7 Core Read/Write signal (core_rw_t2)

This single bit Core output indicates the direction of bus access (read or write with write being active low) by the Core.

### 7.2.1.8 Core bus data size request indicator (core_sz8_t2)

This single bit Core output indicates the size of data (8-bit or 16-bit when high or low, respectively) being read/written by a Core bus access.

### 7.2.1.9 Core Expanded Mode indicator (core_exp_t2)

This single bit Core output indicates that the Core is in Expanded Mode (i.e. the Core has been configured in one of the expanded modes via the MODE pins)

### 7.2.1.10 Core Peripheral Test Mode indicator (core_per_t2)

This single bit Core output indicates that the Core is in Peripheral Test Mode. In this mode, the cpu is disabled and the direction of the bus interface is switched such that the on-chip peripherals can be addressed directly. This mode is used for factory test only.

### 7.2.1.11 Core Special Mode indicator (core_smod_t2)

This single bit Core output indicates that the Core is in Special Mode (i.e. the Core has been configured in Special Mode via the MODE pins)

### 7.2.1.12 Core Secure Mode indicator (core_secure_t2)

This single bit Core output indicates that the Core is operating in secured mode. Please see Section 15 of this guide for functional details.

### 7.2.1.13 Peripheral select signal (core_perisel_t2)

This single bit Core output indicates that the Core is accessing an address within the peripheral space of the system memory map.

### 7.2.1.14 On-Chip RAM register space select signal (core_ramregsel_t2)

This single bit Core output indicates that the Core is accessing an address within the on-chip RAM register space of the system memory map.

### 7.2.1.15 On-Chip RAM array select signal (core_ramarraysel_t2)

This single bit Core output indicates that the Core is accessing an address within the on-chip RAM array space of the system memory map.

### 7.2.1.16 On-Chip RAM array align signal (core_ramhal_t2)

This single bit Core output reflects the state of the RAMHAL bit in the INITRAM register within the Module Mapping Control (MMC) sub-block of the Core. Please see Section 11 of this guide for further functional details.

### 7.2.1.17 On-Chip EEPROM register select signal (core_eeregsel_t2)

This single bit Core output indicates that the Core is accessing an address within the on-chip EEPROM register space of the system memory map.

### 7.2.1.18 On-Chip EEPROM array select signal (core_eearraysel_t2)

This single bit Core output indicates that the Core is accessing an address within the on-chip EEPROM array space of the system memory map.

### 7.2.1.19 On-Chip Flash EEPROM register select signal (core_feeregsel_t2)

This single bit Core output indicates that the Core is accessing an address within the on-chip Flash EEPROM register space of the system memory map.

### 7.2.1.20 On-Chip Flash EEPROM array select signal (core_feearraysel_t2)

This single bit Core output indicates that the Core is accessing an address within the on-chip Flash EEPROM array space of the system memory map.

### 7.2.1.21 On-Chip EEPROM hold signal to Core (ee_hold_t1)

This single bit input to the Core is used to suspend operation of the CPU when needed for functions of the on-chip EEPROM memory block.

### 7.2.1.22 On-Chip Flash EEPROM hold signal to Core (fee_hold_t1)

This single bit input to the Core is used to suspend operation of the CPU when needed for functions of the on-chip Flash EEPROM memory block.

### 7.2.1.23 Core Security Request (secreq)

This single bit input indicates to the Core that the system memory is in a secured state and that the Core should operate in secured mode. Please see Section 15 for functional details.

### 7.2.1.24 56-bit Interrupt request signals from peripheral block to Core (peri_ffxx_t3)

This 56-bit wide input to the Core provides the Core with the Interrupt request signals from all the system interrupt sources via the I.P. Bus Interface.

### 7.2.1.25 System Real Time Interrupt request (peri_rtifff0i_t3)

This input signal indicates to the Core that the system is requesting the interrupt vector for a Real Time Interrupt (RTI) from the Core.

### 7.2.1.26 Background Debug Mode active indicator (core_bdmact_t4)

This single bit output from the Core indicates that the Background Debug Mode (BDM) is active.

### 7.2.2 External Bus Interface Signals

These descriptions apply to the interface signals between the Core and the system External Bus Interface pad logic. Please see Section 12 of this guide for further functional details of the External Bus Interface.

### 7.2.2.1 Port A Input Data to Core (core_paind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port A.

### 7.2.2.2 Port A Output Data from Core (core_pado[7:0])

This 8-bit wide output from the Core provides the Port A data output to the system port/pad logic for Port A.

### 7.2.2.3 Port A output buffer enable from Core (core_paobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port A.

### 7.2.2.4 Port A input buffer enable from Core (core_paibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port A.

### 7.2.2.5 Port A pullup enable from Core (core_papue_t2)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for Port A should be enabled for all Port A pins.

### 7.2.2.6 Port A drive strength enable from Core (core_padse_t2)

This single bit output from the Core indicates whether all Port A pins will operate with full or reduced drive strength.

### 7.2.2.7 Port B Input Data to Core (core_pbind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port B.

### 7.2.2.8 Port B Output Data from Core (core_pbdo[7:0])

This 8-bit wide output from the Core provides the Port B data output to the system port/pad logic for Port B.

### 7.2.2.9 Port B output buffer enable from Core (core_pbobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port B.

### 7.2.2.10 Port B input buffer enable from Core (core_pbibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port B.

### 7.2.2.11 Port B pullup enable from Core (core_pbpue_t2)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for Port B should be enabled for all Port B pins.

### 7.2.2.12 Port B drive strength enable from Core (core_pbdse_t2)

This single bit output from the Core indicates whether all Port B pins will operate with full or reduced drive strength.

### 7.2.2.13 Port E Input Data to Core (core_peind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port E. When the system has an external $\overline{\mathrm{IRQ}}$ pin implemented, the input signal from the $\overline{\mathrm{IRQ}}$ pin pad logic must be tied to Port E Input Data Bit 1. Likewise, when the system has an external XIRQ pin implemented, the input signal from the $\overline{\mathrm{XIRQ}}$ pin pad logic must be tied to Port E Input Data Bit 0 . Both the $\overline{\overline{\mathrm{RQ}}}$ and $\overline{\text { XIRQ }}$ signals are active low (i.e. their asserted state is logic 0 ).

### 7.2.2.14 Port E Output Data from Core (core_pedo[7:0])

This 8-bit wide output from the Core provides the Port E data output to the system port/pad logic for Port E.

### 7.2.2.15 Port E output buffer enable from Core (core_peobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port E.

### 7.2.2.16 Port E input buffer enable from Core (core_peibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port E.

### 7.2.2.17 Port E pullup enable from Core (core_pepue_t2)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for Port E should be enabled for all Port E pins except the MODA (PE5) and MODB (PE6) pins.

### 7.2.2.18 Port E MODE pin pullup enable from Core (core_mdrste)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for the MODA (PE5) and MODB (PE6) pins within Port E should be enabled.

### 7.2.2.19 Port E drive strength enable from Core (core_pedse_t2)

This single bit output from the Core indicates whether all Port E pins will operate with full or reduced drive strength.

### 7.2.2.20 Port K Input Data to Core (core_pkind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port K.

### 7.2.2.21 Port K Output Data from Core (core_pkdo[7:0])

This 8-bit wide output from the Core provides the Port K data output to the system port/pad logic for Port K.

### 7.2.2.22 Port K output buffer enable from Core (core_pkobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port K.

### 7.2.2.23 Port K input buffer enable from Core (core_pkibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port K.

### 7.2.2.24 Port K pullup enable from Core (core_pkpue_t2)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for Port K should be enabled for all Port K pins.

### 7.2.2.25 Port K drive strength enable from Core (core_pkdse_t2)

This single bit output from the Core indicates whether all Port K pins will operate with full or reduced drive strength.

### 7.2.3 Clock and Reset Signals

Please see Section 8 of this guide.

### 7.2.4 Vector Request/Acknowledge Signals

These descriptions apply to signals that provide for vector requesting to and corresponding acknowledgment from the Core.

### 7.2.4.1 CPU vector fetch (core_vector_fetch_t4)

This Core output signal indicates that the CPU is executing a vector fetch as a result of a reset or interrupt sequence.

### 7.2.4.2 System level reset vector request (peri_rstv_request)

This input signal indicates to the Core that the system is requesting the external reset vector from the Core.

### 7.2.4.3 System level Crystal Monitor reset vector request (peri_xmonv_request)

This input signal indicates to the Core that the system is requesting the Crystal Monitor reset vector from the Core.

### 7.2.4.4 System level COP Watchdog reset vector request (peri_copv_request)

This input signal indicates to the Core that the system is requesting the COP Watchdog reset vector from the Core.

### 7.2.5 Stop and Wait Mode Control/Status Signals

Please see Section 8 of this guide.

### 7.2.6 Background Debug Mode (BDM) Interface Signals

These descriptions apply to the Core BDM sub-block interface with the system BKGD pad logic. Please see Section 14 of this guide for further functional details of the BDM.

### 7.2.6.1 BKGD pin Input Data to Core (bkgd_ind)

This single bit input to the Core provides the Core with the input data from the system port/pad logic for BDM BKGD pin.

### 7.2.6.2 BKGD pin Output Data from Core (core_bkgd_dout_t4)

This single bit output from the Core provides the BKGD pin data output to the system port/pad logic for the BDM BKGD pin.

### 7.2.6.3 BKGD pin output buffer enable from Core (core_bkgd_obe)

This single bit output from the Core provides the output buffer enable signal to the system port/pad logic for the BDM BKGD pin.

### 7.2.6.4 BKGD pin input buffer enable from Core (core_bkgd_ibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for the BDM BKGD pin.

### 7.2.6.5 BKGD pin pullup enable from Core (core_bkgdpue_t2)

This single bit output from the Core indicates that the pullup device within the system port/pad logic for the BKGD pin should be enabled for the BKGD pin.

### 7.2.7 Memory Configuration Signals

These input signals to the Core establish the system memory configuration. Each of these signals is to be tied off to the appropriate logic state at integration of the Core into the SoC design in order to configure the Core memory partitioning according to the needs of the system. Please consult the HCS12 V1.5 Core Integration Guide for details on defining the states of these signals.

### 7.2.8 Scan Control Interface Signals

These descriptions apply to the Core Scan test control signals.

### 7.2.8.1 Scan mode enable(ipt_scan_mode)

This single bit input indicates to the Core that the system is in Scan test mode and all logic within the Core that needs special conditions for Scan test mode will be handled appropriately.

### 7.3 Interface Operation

The subsections below give general descriptions of basic read and write operations of the Core. These operations include interfacing with system peripheral registers, on-chip memory registers and array elements, internal Core registers and external bus interface. For more detailed descriptions and timing information please consult the HCS12 V1.5 Core Integration Guide.

### 7.3.1 Read Operations

All read data coming into the Core is implemented by multiplexing the various input read data buses (peri_rdb_L12[15:0], ram_rdb_L12[15:0], ee_rdb_L12[15:0] and fee_rdb_L12[15:0]) onto the main internal Core read data bus. The active input read data bus is defined by the select signal that is active during the Core read cycle. The subsections below briefly discuss each of peripheral, on-chip memory register and array element and internal core register reads. In each of the figures used in these subsections, the read sequences are separated by write sequences to better illustrate the timing edges.

### 7.3.1.1 Peripheral Reads

The Core supports both 8-bit and 16-bit reads of peripheral registers. The timing relationship for a basic 8 -bit read of a peripheral register is shown in Figure 7-2 and that of a basic 16-bit read in Figure 7-3.

The Core clock (peri_clk24) provides the timing reference within the Core for all data transfers with the peripherals. The peripheral clock (peri_clk34) is the timing reference for all peripherals within the system tied to the I.P. Bus.


Figure 7-2 Basic 8-bit Peripheral Read Timing


Figure 7-3 Basic 16-bit Peripheral Read Timing

### 7.3.1.2 Memory Reads

The timing relationship for a basic 8-bit read of a on-chip memory register or array byte by the Core is shown in below in Figure 7-4 and that of a basic 16-bit read in Figure 7-5. In the diagrams, the MEM_rdb_L12 signal represents any of the on-chip memory read data bus signals (ram_rdb_L12, $e e \_r d b \_L 12$ or $f e e_{-} r d b \_L 12$ ) and core_MSEL_t2 represents any of the on-chip memory register or array selects (such as core_ramregsel_t2 or core_ramarraysel_t2 for the RAM and likewise for the EEPROM and Flash EEPROM).


Figure 7-4 Basic 8-bit Memory Read Timing


Figure 7-5 Basic 16-bit Memory Read Timing

### 7.3.1.3 Internal Core Register Reads

The timing for basic 8-bit and 16-bit reads of internal Core registers are shown in Figure 7-6 and Figure 7-7, respectively.


Figure 7-6 Basic 8-bit Core Register Read Timing


Figure 7-7 Basic 16-bit Core Register Read Timing

### 7.3.2 Write Operations

All write data exits the Core via the Core write data bus (core_wdb_t4[15:0]). The subsections below briefly discuss each of peripheral, on-chip memory register and array element and internal core register writes. In each of the figures used in these subsections, the write sequences are separated by read sequences to better illustrate the timing edges.

### 7.3.2.1 Peripheral Writes

The Core supports both 8 -bit and 16 -bit writes of peripheral registers. The timing relationship for a basic 8-bit write of a peripheral register is shown in Figure 7-8 and that of a basic 16-bit write in Figure 7-9. An example of the I.P. Bus read data bus timing is provided in the figures for further illustration purposes.


Figure 7-8 Basic 8-bit Peripheral Write Timing


Figure 7-9 Basic 16-bit Peripheral Write Timing

### 7.3.2.2 Memory Writes

The timing relationship for a basic 8-bit write of a on-chip memory register or array byte by the Core is shown in below in Figure 7-10 and that of a basic 16-bit write in Figure 7-11. As before, the $M E M \_r d b \_L 12$ signal represents any of the on-chip memory read data bus signals (ram_rdb_L12, $e e \_r d b \_L 12$ or $f e e \_r d b \_L 12$ ) and core_MSEL_t2 represents any of the on-chip memory register or array selects (such as core_ramregsel_t2 or core_ramarraysel_t2 for the RAM and likewise for the EEPROM and Flash EEPROM).


Figure 7-10 Basic 8-bit Memory Write Timing


Figure 7-11 Basic 16-bit Memory Write Timing

### 7.3.2.3 Internal Core Register Writes

The timing for basic 8-bit and 16-bit writes of internal Core registers are shown in Figure 7-12 and Figure 7-13, respectively.


Figure 7-12 Basic 8-bit Core Register Write Timing


Figure 7-13 Basic 16-bit Core Register Write Timing

### 7.3.3 Multiplexed External Bus Interface

A timing diagram of the multiplexed external bus is shown in. Major bus signals are included in the diagram. While both a data write and data read cycle are shown, only one would occur on a particular bus cycle. Table 7-2 gives the preliminary timing characteristics for the signals illustrated in .


Figure 7-14 General External Bus Timing

## : User Guide - S12CPU15島efscale Semiconductor, Inc.

Table 7-2 Multiplexed Expansion Bus Timing - Preliminary Targets

| Num | Characteristic ${ }^{123}$ | Symbol | $16 \text { MHz }$ <br> Min Max |  | $20 \mathrm{MHz}$ <br> Min Max |  | $25 \text { MHz }$ <br> Min Max |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Frequency of operation (E-clock) | $\mathrm{f}_{0}$ | D.C. | 16.0 | D.C. | 20.0 | D.C. | 25.0 | MHz |
| 1 | Cycle time | $\mathrm{t}_{\mathrm{cyc}}$ | 62 |  | 50 |  | 40 |  | ns |
| 2 | Pulse width, E low | PW ${ }_{\text {EL }}$ | 28 |  | 22 |  | 18 |  | ns |
| 3 | Pulse width, E high ${ }^{4}$ | $\mathrm{PW}_{\text {EH }}$ | 28 |  | 22 |  | 18 |  | ns |
| 5 | Address delay time | $t_{\text {AD }}$ |  | 12 |  | 10 |  | 8 | ns |
| 6 | n/a | n/a |  |  |  |  |  |  | ns |
| 7 | Address valid time to E rise ( $\mathrm{PWW}_{\mathrm{EL}} \mathrm{T}_{\mathrm{AD}}$ ) | $\mathrm{t}_{\mathrm{AV}}$ | 16 |  | 12 |  | 10 |  | ns |
| 8 | Muxed address hold time | $\mathrm{t}_{\mathrm{MAH}}$ | 2 |  | 2 |  | 1 |  | ns |
| 9 | Address hold to data valid | $\mathrm{t}_{\text {AHDS }}$ | 4 |  | 3 |  | 2 |  | ns |
| 10 | Data hold to address | $t_{\text {DHA }}$ |  | 5 |  | 4 |  | 3 | ns |
| 11 | Read data setup time | $t_{\text {DSR }}$ | 14 |  | 10 |  | 8 |  | ns |
| 12 | Read data hold time | $\mathrm{t}_{\text {DHR }}$ | 0 |  | 0 |  | 0 |  | ns |
| 13 | Write data delay time | $t_{\text {DDW }}$ |  | 12 |  | 10 |  | 8 | ns |
| 14 | Write data hold time | $\mathrm{t}_{\text {DHW }}$ | 2 |  | 2 |  | 1 |  | ns |
| 15 | Write data setup time ${ }^{4}\left(\mathrm{PW}_{\mathrm{EH}^{-}} \mathrm{t}_{\text {DDW }}\right)$ | t ${ }_{\text {DSW }}$ | 16 |  | 12 |  | 10 |  | ns |
| 16 | Read/write delay time | $t_{\text {RWD }}$ |  | 12 |  | 10 |  | 8 | ns |
| 17 | Read/write valid time to E rise ( $\mathrm{PW}_{\mathrm{EL}^{-\mathrm{t}_{\mathrm{RWWD}}} \text { ) }}$ | $t_{\text {RWV }}$ | 16 |  | 12 |  | 10 |  | ns |
| 18 | Read/write hold time | $t_{\text {RWH }}$ | 2 |  | 2 |  | 1 |  | ns |
| 19 | Low strobe delay time | tLSD |  | 12 |  | 10 |  | 8 | ns |
| 20 |  | tLSV | 16 |  | 12 |  | 10 |  | ns |
| 21 | Low strobe hold time | tLSH | 2 |  | 2 |  | 1 |  | ns |
| 22 | Address access time ${ }^{4}\left(\mathrm{t}_{\mathrm{cyc}}{ }^{\left.-\mathrm{t}_{\mathrm{AD}}-\mathrm{t}_{\mathrm{DSR}}\right)}\right.$ | $t_{\text {ACCA }}$ | 36 |  | 30 |  | 24 |  | ns |
| 23 | E high access time ${ }^{4}\left(\mathrm{PW}_{\mathrm{EH}^{-} \mathrm{t}_{\mathrm{DSR}}}\right)$ | $t_{\text {ACCE }}$ | 14 |  | 12 |  | 10 |  | ns |
| 26 | Chip select delay time | $\mathrm{t}_{\text {CSD }}$ |  | 22 |  | 18 |  | 15 | ns |
| 27 | Chip select access time ${ }^{4}\left(\mathrm{t}_{\text {cyc }}{ }^{-\mathrm{t}_{\text {CSD }}}{ }^{-\mathrm{t}_{\text {DSR }}}\right)$ | $t_{\text {ACCS }}$ | 26 |  | 22 |  | 17 |  | ns |
| 28 | Chip select hold time | $\mathrm{t}_{\mathrm{CSH}}$ |  | 1 |  | 1 |  | 1 | ns |
| 29 | Chip select negated time | ${ }^{\text {t CSN }}$ | 12 |  | 10 |  | 8 |  | ns |

NOTES:

1. Crystal input is required to be within $45 \%$ to $55 \%$ duty.
2. Reduced drive must be off to meet these timings.
3. Unequal loading of pins will affect relative timing numbers.
4. Affected by clock stretch: add $\mathrm{N} \mathrm{x}_{\mathrm{cyc}}$ where $\mathrm{N}=0,1,2$ or 3 , depending on the number of clock stretches.

### 7.3.4 General Internal Read Visibility Timing

Internal writes have the same timing as external writes. Internal read visibility is shown in Figure 7-15 and Table $\mathbf{7 - 3}$ shows the associated timing numbers.


Figure 7-15 General Internal Read Visibility Timing

Table 7-3 Expansion Bus Timing - Preliminary Targets

| Num | Characteristic ${ }^{123}$ | Symbol | 16 MHz |  | 20 MHz |  | 25 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
|  | Frequency of operation (E-clock) | $\mathrm{f}_{0}$ | D.C. | 16.0 | D.C. | 20.0 | D.C. | 25.0 | MHz |
| 1 | Cycle time | $\mathrm{t}_{\mathrm{cyc}}$ | 62 |  | 50 |  | 40 |  | ns |
| 2 | Pulse width, E low | PW ${ }_{\text {EL }}$ | 28 |  | 22 |  | 18 |  | ns |
| 3 | Pulse width, E high ${ }^{4}$ | PW ${ }_{\text {EH }}$ | 28 |  | 22 |  | 18 |  | ns |
| 31RG | IVIS read data set-up time - Registers |  | 11 |  | 5 |  | 2 |  | ns |
| 31RM | IVIS read data set-up time - RAM |  | 11 |  | 5 |  | 2 |  | ns |
| 31EE | IVIS read data set-up time EEPROM |  | 11 |  | 5 |  | 2 |  | ns |
| 31FL | IVIS read data set-up time - FLASH ${ }^{5}$ |  | 6 |  | 0 |  | 0 |  | ns |

Table 7-3 Expansion Bus Timing - Preliminary Targets


NOTES:

1. Crystal input is required to be within $45 \%$ to $55 \%$ duty.
2. Reduced drive must be off to meet these timings.
3. Unequal loading of pins will affect relative timing numbers.
4. Affected by clock stretch: add $N x t_{\text {cyc }}$ where $N=0,1,2$ or 3 , depending on the number of clock stretches.
5. Timing is tighter than other memories due to larger array size.

### 7.3.5 Detecting Access Type from External Signals

The external signals $\overline{\mathrm{LSTRB}}, \mathrm{R} / \overline{\mathrm{W}}$, and A0 indicate the type of bus access that is taking place. Accesses to the internal RAM are the only type of access that would produce $\overline{\mathrm{LSTRB}}=\mathrm{A} 0=1$ because the internal RAM is specifically designed to allow misaligned 16 -bit accesses in a single cycle. In these cases, the data for the address that was accessed is on the low half of the data bus and the data for address +1 is on the high half of the data bus. This operation only occurs when internal visibility is on.
Table 7-4 shows the relationship between these signals and the type of access.
Table 7-4 Access Type vs. Bus Control Pins

| $\overline{\text { LSTRB }}$ | $\mathbf{A 0}$ | $\mathbf{R} / \overline{\mathbf{W}}$ | Type of Access |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 1 | 8-bit read of an even address |
| 0 | 1 | 1 | 8-bit read of an odd address |
| 1 | 0 | 0 | 8-bit write of an even address |
| 0 | 1 | 0 | 8-bit write of an odd address |
| 0 | 0 | 1 | 16-bit read of an even address |
| 1 | 1 | 1 | 16-bit read of an odd address <br> (low/high data swapped) |
| 0 | 0 | 0 | 16-bit write to an even address <br> 16-bit write to an odd address <br> (low/high data swapped) |
| 1 | 1 | 0 |  |

## Section 8 Core Clock and Reset Connections

This section details the HCS12 V1.5 Core external clock connections. In addition, this section will discuss the reset timing needs of the Core since this is associated very closely with the external clocking requirements.

### 8.1 Clocking Overview

The HCS12 V1.5 Core is implemented as a single clock source design with complete Mux-D scan test implementation. Since the Core is compatible with the feature set of the MHC12 microcontroller product family, many signal and timing requirements exist for the system clock and reset generation block(s) to support these features. Many of these requirements are driven by the interaction of the Core with the clock and reset generation block(s) in the system due to CPU wait and stop mode functionality and the various time based reset and interrupt functions (such as Crystal Monitor and COP Watchdog resets and Real Time Interrupt functions) available on the HCS12 family of products. A diagram of the Core interface signals is given in Figure 8-1 below.


Figure 8-1 Core Interface Signals

The Core interfaces with the system clock and reset generation block(s) in order to synchronize the actions of the HCS12 CPU with the rest of the system. Through the interface signals, the Core supports the use of a system Phase-Locked Loop (PLL), Crystal Monitor, COP Watchdog and Real Time Interrupt as well as clocking options during CPU wait and stop modes. Each of these aspects are discussed in the subsections that follow.

### 8.1.1 Basic Clock Relationship

The basic system clock timing in shown in Figure 8-2 below. The system clock generation block is required to provide the main Core clocks (peri_clk24, peri_clk2, and peri_clk4), the main peripheral clock (peri_clk34) and the system clk23 (peri_clk23) to the Core (the Core uses peri_clk23 to generate the ECLK signal). The method of clock generation (i.e. crystal, PLL, etc.) is left up to the system integrator as long as the clocks provided meet the phase relationship shown in the figure.


Figure 8-2 System Clock Timing Diagram

The remaining clock input to the Core, peri_phase_oscdX, is the same frequency as the peri_clk34 as derived directly from the oscillator. When using the PLL for the system clocks, the BDM sub-block must maintain a constant rate clock and cannot depend upon the use of the PLL generated clock. Because of this, this signal operates at the same frequency as peri_clk34 prior to engaging the PLL (or as derived directly from the oscillator). Once the PLL is engaged, this clock must maintain the pre-PLL frequency in order to keep the BDM synchronized.

### 8.1.2 Reset Relationship

The Core depends upon the use of two input signals, reset_pin_ind and peri_reset_ta4, for controlling the reset conditions of all logic within the Core. The active low reset_pin_ind signal timing follows that of the physical system reset pin indicating immediately when a system reset is requested (for example when the RESET pin is pulled low externally). This signal is used as a load enable on the MODE pins of the MEBI sub-block to ensure that the Core mode of operation is known and set up immediately upon a system reset request. The peri_reset_ta4 signal will generally be asserted (logic 1) asynchronously by the reset generation block at the time that a system reset is requested. Further, the assumption is that this signal will stay asserted until such time that the clock generation block has determined that the clocks to the Core are stable and that the Core should proceed with a system reset sequence.

### 8.1.3 Phase-Locked Loop Interface

The Core allows for the implementation of a on-chip Phase-Locked Loop (PLL) and interacts with it through the peri_pllsel_t3, peri_test_clk_enable and peri_test_clk input signals. If a PLL is implemented, the Core assumes it will operate on the peripheral clock (peri_clk34) and thus the peri_pllsel_t3 signal must be asserted (logic 1) on the phase three rising edge of this clock when the PLL is first engaged and to be negated (logic 0 ) when the PLL is disabled. The peri_test_clk and peri_test_clk_enable signals are provided in order to facilitate test features for the PLL. When the peri_test_clk_enable signal is asserted (logic 1), the Core will register the signal on the phase four rising edge of peri_clk24 and will then output the clock signal being input on peri_test_clk directly on Port E Bit 6 of the system. This test feature is only valid in Special modes and setting of the PIPOE bit in the PEAR register overrides the clock output.

### 8.1.4 HCS12 CPU Wait and Stop Modes

The Core inputs peri_cwai_t3 and peri_syswai_t3 indicate to the Core what the state of the system clocks will be during CPU wait mode with the former reflecting the Core clock (peri_clk24) state and the latter the state of all system clocks. These inputs typically come from the clock and reset generation block(s) and could either be hard-wired to a given logic value or reflect the state of software bits controlling the clock functionality. The Core assumes that the asserted (logic 1) state indicates that the clock(s) will cease during wait mode and that the negated (logic 0) state indicates that the clock(s) will run during wait mode.

The Core will reflect the CPU mode through the state of the core_wait_t24 and core_stop_t 24 signals. The core_wait_t 24 or core_stop_t 24 signal will assert when the CPU executes a WAI or STOP instruction, respectively, and both will remain negated (logic 0 ) during normal operation. In the case of exit from either wait or stop mode due to a valid interrupt, the core_wakeup_ta signal will assert (logic 1) asynchronously upon receiving the valid interrupt request. This signal will then negate (logic 0) asynchronously once the interrupt source is negated (indicating that the interrupt has been serviced and is no longer being requested).

### 8.2 Signal Summary

Each of the Core I/O signals that interface with the system clock and reset generation block(s) are listed in Table 8-1 below with the signal type and a brief functional description for completeness.

Table 8-1 Core Clock and Reset Interface Signals

| Signal Name | Type | Functional Description |
| :---: | :---: | :---: |
| Clock and Reset Signals |  |  |
| peri_reset_ta4 | I | System reset signal |
| reset_pin_ind | 1 | System level reset pin input data |
| peri_clk2 | 1 | System clock clk2 for Core |
| peri_clk4 | 1 | System clock clk4 for Core |
| peri_clk24 | 1 | System clock clk24 for Core |
| peri_clk34 | 1 | System clock clk34 for peripherals on I.P. Bus Interface |
| peri_clk23 | 1 | System clock clk23 used by Core to generate ECLK |
| peri_phase_oscdX | 1 | Oscillator Clock divided by 'X' |
| peri_test_clk_enable | 1 | PLL test feature clock enable signal |
| peri_test_clk | 1 | PLL test feature clock signal |
| peri_pllsel_t3 | 1 | PLL selected signal |
| core_eclk_load | 0 | External clock load enable signal |
| core_neclk_t2 | 0 | External clock disable signal |
| Stop and Wait Mode Control/Status Signals |  |  |
| core_stop_t24 | 0 | Core CPU stop mode signal |
| core_wait_t24 | 0 | Core CPU wait mode signal |
| core_wakeup_ta | 0 | Core wakeup from stop or wait mode due to interrupt |
| peri_cwai_t3 | 1 | Core wait signal: controls whether clk24 runs during CPU wait mode. 0 clk24 runs during wait, 1 - clk24 ceases during wait. |
| peri_syswai_t3 | 1 | System level wait signal: controls whether system clocks run during CPU wait mode. 0 - all clocks run during wait, 1 - no clocks run during wait. |

### 8.3 Detailed Clock and Reset Signal Descriptions

General descriptions of the Core clock and reset interface signals are given in the subsections below. Also included are the stop and wait mode signals due to the necessary interaction with the clock and reset requirements. For detailed descriptions of these signals including timing information please consult the HCS12 V1.5 Core Integration Guide.

### 8.3.1 Clock and Reset Signals

These descriptions apply to system level clock and reset signals needed by the Core.

### 8.3.1.1 System Reset signal (peri_reset_ta4)

This single bit asynchronous input to the Core indicates the system reset condition.

### 8.3.1.2 System level reset input data (reset_pin_ind)

This active-low single bit input is used within the Core as a load enable for the MODE pin logic on Port E of the system.

### 8.3.1.3 System level clock for the Core (peri_clk2)

This clock input is one of the main clocks for the Core.

### 8.3.1.4 System level clock for the Core (peri_clk4)

This clock input is one of the main clocks for the Core.

### 8.3.1.5 System level clock for the Core (peri_clk24)

This clock input is one of the main clocks for the Core.

### 8.3.1.6 System level clock for peripheral blocks (peri_clk34)

This clock input is the main clock source for all peripheral blocks integrated in the system and accessed by the Core through the I.P. Bus Interface.

### 8.3.1.7 System ECLK clock (peri_clk23)

This clock input is the main clock source used by the Core to generate the system ECLK.

### 8.3.1.8 Divided Down System Oscillator Clock (peri_phase_oscdX)

This clock input to the Core is used within the Core by the Background Debug Mode sub-block to keep the BDM synchronized.

User Guide - S12CPU15tuters.scale Semiconductor, Inc.

### 8.3.1.9 System Test Clock enable (peri_test_clk_enable)

This single bit input to the Core indicates that the phase-locked loop (PLL) test clock should be output on the system Port E bit 6 pin when the PIPOE bit is zero.

### 8.3.1.10 System Test Clock (peri_test_clk)

This clock input to the Core is the PLL test clock.

### 8.3.1.11 System clock source select signal (peri_pllsel_t3)

This single bit input to the Core indicates whether clocks within the system are derived from the crystal or PLL.

### 8.3.1.12 ECLK load enable signal (core_eclk_load)

This single bit output from the Core is the load enable signal for the system external clock, ECLK.

### 8.3.1.13 ECLK disable signal (core_neclk_t2)

This single bit output from the Core is the disable signal for the system external clock, ECLK.

### 8.3.2 Stop and Wait Mode Control/Status Signals

These descriptions apply to signals that provide for controlling some of the functionality and status indication of CPU stop and wait modes.

### 8.3.2.1 CPU stop mode indicator (core_stop_t24)

This Core output signal indicates whether the CPU is in stop mode.

### 8.3.2.2 CPU wait mode indicator (core_wait_t24)

This Core output signal indicates whether the CPU is in wait mode.

### 8.3.2.3 Core wakeup indicator for wait and stop mode (core_wakeup_ta)

This asynchronous Core output signal indicates that the CPU has received an interrupt request and is ready to resume normal operation.
8.3.2.4 Core wait signal from system clock generation block (peri_cwai_t3)

This Core input signal indicates to the CPU whether the main Core clock, peri_clk24, will run during CPU wait mode.

### 8.3.2.5 System level wait signal (peri_syswai_t3)

This Core input signal indicates to the Core whether all system clocks will run during CPU wait mode.

## Section 9 Core Power Connections

This section details the HCS12 V1.5 Core power connections.

### 9.1 Power Overview

The HCS12 V1.5 Core operates from a single power and a single ground connection.

### 9.1.1 Power and Ground Summary

The Core requires a single power (typically termed VDD) and a single ground (typically termed VSS) connection that is implicit when integrating into a synthesized design. There are no signals at the Core interface for power and ground.
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 10 Interrupt (INT)

This section describes the functionality of the Interrupt (INT) sub-block of the Core.

### 10.1 Overview

The Interrupt sub-block decodes the priority of all system exception requests and provides the applicable vector for processing the exception. The INT supports I-bit maskable and X-bit maskable interrupts, a nonmaskable Unimplemented Opcode Trap, a nonmaskable software interrupt (SWI) or Background Debug Mode request, and three system reset vector requests. All interrupt related exception requests are handled by the Interrupt.

### 10.1.1 Features

- Provides 2 to 122 I bit maskable interrupt vectors (\$FF00-\$FFF2)
- Provides 1 X bit maskable interrupt vector (\$FFF4)
- Provides a nonmaskable Unimplemented Opcode Trap (TRAP) vector (\$FFF8)
- Provides a nonmaskable software interrupt (SWI) or Background Debug Mode request vector (\$FFF6)
- Provides 3 system reset vectors (\$FFFA-\$FFFE)
- Determines the appropriate vector and drives it onto the address bus at the appropriate time
- Signals the CPU that interrupts are pending
- Provides control registers which allow testing of interrupts
- Provides additional input signals which prevents requests for servicing I and X interrupts
- Wakes the system from stop or wait mode when an appropriate interrupt occurs or whenever $\overline{\text { XIRQ }}$ is active, even if $\overline{\text { XIRQ }}$ is masked
- Provides asynchronous path for all I and X interrupts, (\$FF00-\$FFF4)
- (Optional) Selects and stores the highest priority I interrupt based on the value written into the HPRIO register


### 10.1.2 Block Diagram

A block diagram of the Interrupt sub-block is shown in Figure 10-1 below.


Figure 10-1 Interrupt Block Diagram

### 10.2 Interface Signals

All interfacing with the Interrupt sub-block is done within the Core. The Interrupt does however receive direct input from the Multiplexed External Bus Interface (MEBI) sub-block of the Core for the $\overline{\overline{I R Q}}$ and $\overline{\text { XIRQ }}$ pin data.

### 10.3 Registers

A summary of the registers associated with the Interrupt sub-block is shown in Figure 10-2 below. Detailed descriptions of the registers and associated bits are given in the subsections that follow.

| Address | Name |  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$0015 | ITCR | read write | 0 | 0 | 0 | WRTINT | ADR3 | ADR2 | ADR1 | ADR0 |
| \$0016 | ITEST | read write | INTE | INTC | INTA | INT8 | INT6 | INT4 | INT2 | INT0 |
| \$001F | HPRIO | read write | PSEL7 | PSEL6 | PSEL5 | PSEL4 | PSEL3 | PSEL2 | PSEL1 | 0 |
|  |  |  |  | = Unimplemented |  | $X=$ Indeterminate |  |  |  |  |

Figure 10-2 Interrupt Register Summary

### 10.3.1 Interrupt Test Control Register

Address:\$0015

| Read | it | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 0 | 0 | IT |  |  |  |  |
| Write: |  |  |  | WRTINT | ADR3 | ADR2 | ADR1 | ADRO |
| Reset: | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |

Figure 10-3 Interrupt Test Control Register (ITCR)
Read: see individual bit descriptions
Write: see individual bit descriptions
WRTINT - Write to the Interrupt Test Registers
Read: anytime
Write: only in special modes and with I bit mask and X bit mask set.
$1=$ Disconnect the interrupt inputs from the priority decoder and use the values written into the ITEST registers instead.
$0=$ Disables writes to the test registers; reads of the test registers will return the state of the interrupt inputs.

NOTE: Any interrupts which are pending at the time that WRTINT is set will remain until they are overwritten.

ADR3 - ADR0 - Test register select bits

Read: anytime
Write: anytime
These bits determine which test register is selected on a read or write. The hexadecimal value written here will be the same as the upper nibble of the lower byte of the vector selects. That is, an "F" written into ADR3 - ADR0 will select vectors \$FFFE - $\$$ FFF0 while a " 7 " written to ADR3 - ADR0 will select vectors \$FF7E - \$FF70.

### 10.3.2 Interrupt Test Registers



Figure 10-4 Interrupt TEST Registers (ITEST)
Read: Only in special modes. Reads will return either the state of the interrupt inputs of the Interrupt sub-block (WRTINT $=0$ ) or the values written into the TEST registers (WRTINT $=1$ ). Reads will always return zeroes in normal modes.
Write: Only in special modes and with WRTINT = 1 and CCR I mask $=1$.
INTE - INT0 - Interrupt TEST bits
These registers are used in special modes for testing the interrupt logic and priority independent of the system configuration. Each bit is used to force a specific interrupt vector by writing it to a logic one state. Bits are named with INTE through INT0 to indicate vectors $\$$ FFxE through $\$$ FFx0. These bits can be written only in special modes and only with the WRTINT bit set (logic one) in the Interrupt Test Control Register (ITCR). In addition, I interrupts must be masked using the I bit in the CCR. In this state, the interrupt input lines to the Interrupt sub-block will be disconnected and interrupt requests will be generated only by this register. These bits can also be read in special modes to view that an interrupt requested by a system block (such as a peripheral block) has reached the INT module.

There is a test register implemented for every 8 interrupts in the overall system. All of the test registers share the same address and are individually selected using the value stored in the ADR3-ADR0 bits of the Interrupt Test Control Register (ITCR).

NOTE: When ADR3-ADR0 have the value of $\$ F$, only bits 2-0 in the ITEST register will be accessible. That is, vectors higher than \$FFF4 cannot be tested using the test registers and bits $7-3$ will always read as a logic zero. If ADR3-ADR0 point to an unimplemented test register, writes will have no effect and reads will always return a logic zero value.

### 10.3.3 Highest Priority I Interrupt (Optional)



Figure 10-5 Highest Prionity I Intemupt Register (HPRIO)
Read: anytime
Write: only if I mask in CCR $=1$
PSEL7 - PSEL1 - Highest priority I interrupt select bits
The state of these bits determines which I bit maskable interrupt will be promoted to highest priority (of the I bit maskable interrupts). To promote an interrupt, the user writes the least significant byte of the associated interrupt vector address to this register. If an unimplemented vector address or a non I bit masked vector address (value higher than \$F2) is written, IRQ (\$FFF2) will be the default highest priority interrupt.

### 10.4 Operation

The Interrupt sub-block processes all exception requests made by the CPU. These exceptions include interrupt vector requests and reset vector requests. Each of these exception types and their overall priority level is discussed in the subsections below.

### 10.4.1 Interrupt Exception Requests

As shown in Figure 10-1 above, the INT mainly contains a register block to provide interrupt status and control, an optional Highest Priority I Interrupt (HPRIO) block and a priority decoder to evaluate whether pending interrupts are valid and assess their priority.

### 10.4.1.1 Interrupt Registers

The INT registers are accessible only in special modes of operation and function as described in 10.3.1 and 10.3.2 previously.

### 10.4.1.2 Highest Priority I bit Maskable Interrupt

When the optional HPRIO block is implemented, the user is allowed to promote a single I bit maskable interrupt to be the highest priority I interrupt. The HPRIO evaluates all interrupt exception requests and passes the HPRIO vector to the priority decoder if the highest priority I interrupt is active.

### 10.4.1.3 Interrupt Priority Decoder

The priority decoder evaluates all interrupts pending and determines their validity and priority. When the CPU requests an interrupt vector, the decoder will provide the vector for the highest priority interrupt request. Because the vector is not supplied until the CPU requests it, it is possible that a higher priority interrupt request could override the original exception that caused the CPU to request the vector. In this case, the CPU will receive the highest priority vector and the system will process this exception instead of the original request.

NOTE: Care must be taken to ensure that all exception requests remain active until the system begins execution of the applicable service routine; otherwise, the exception request may not get processed.

If for any reason the interrupt source is unknown (e.g. an interrupt request becomes inactive after the interrupt has been recognized but prior to the vector request), the vector address will default to that of the last valid interrupt that existed during the particular interrupt sequence. If the CPU requests an interrupt vector when there has never been a pending interrupt request, the INT will provide the Software Interrupt (SWI) vector address.

### 10.4.2 Reset Exception Requests

The INT supports three system reset exception request types: normal system reset or power-on-reset request, Crystal Monitor reset request and COP Watchdog reset request. The type of reset exception request must be decoded by the system and the proper request made to the Core. The INT will then provide the service routine address for the type of reset requested.

### 10.4.3 Exception Priority

The priority (from highest to lowest) and address of all exception vectors issued by the INT upon request by the CPU is shown in Table 10-1 below.

Table 10-1 Exception Vector Map and Priority

| Vector Address | Source |
| :---: | :--- |
| \$FFFE-\$FFFF | System reset |
| \$FFFC-\$FFFD | Crystal Monitor reset |
| \$FFFA-\$FFFB | COP reset |
| \$FFF8-\$FFF9 | Unimplemented opcode trap |
| \$FFF6-\$FFF7 | Software interrupt instruction (SWI) or BDM vector request |
| \$FFF4-\$FFF5 | $\overline{\text { XIRQ signal }}$ |
| \$FFF2-\$FFF3 | $\overline{\text { IRQ signal }}$ |
| \$FFF0-\$FF00 | Device-specific I bit maskable interrupt sources (priority in <br> descending order) |

### 10.5 Modes of Operation

The functionality of the INT sub-block in various modes of operation is discussed in the subsections that follow.

### 10.5.1 Normal Operation

The INT operates the same in all normal modes of operation.

### 10.5.2 Special Operation

Interrupts may be tested in special modes through the use of the interrupt test registers as described in 10.3.1 and 10.3.2 previously.

### 10.5.3 Emulation Modes

The INT operates the same in emulation modes as in normal modes.

### 10.6 Low-Power Options

The INT does not contain any user-controlled options for reducing power consumption. The operation of the INT in low-power modes is discussed in the following subsections.

### 10.6.1 Run Mode

The INT does not contain any options for reducing power in run mode.

### 10.6.2 Wait Mode

Clocks to the INT can be shut off during system wait mode and the asynchronous interrupt path will be used to generate the wakeup signal upon recognition of a valid interrupt or any XIRQ request.

### 10.6.3 Stop Mode

Clocks to the INT can be shut off during system stop mode and the asynchronous interrupt path will be used to generate the wakeup signal upon recognition of a valid interrupt or any XIRQ request.

### 10.7 Motorola Internal Information

The INT does not contain any functionality that is considered to be for Motorola internal use only.
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 11 Module Mapping Control (MMC)

This section describes the functionality of the Module Mapping Control (MMC) sub-block of the Core.

### 11.1 Overview

The Module Mapping Control (MMC) sub-block of the Core performs all mapping and select operations for the on-chip and external memory blocks. The MMC also handles mapping functions for the system peripheral blocks and provides a global peripheral select to be decoded by the Motorola I.P. Bus when the Core is addressing a portion of the peripheral register map space. All bus-related data flow and multiplexing for the Core is handled within the MMC as well. Finally, the MMC contains logic to determine the state of system security.

### 11.1.1 Features

- Registers for mapping of address space for on-chip RAM, EEPROM, and Flash EEPROM (or ROM) memory blocks and associated registers
- Memory mapping control and selection based upon address decode and system operating mode
- Core Address Bus control
- Core Data Bus control and multiplexing
- Core Security state decoding
- Emulation Chip Select signal generation ( $\overline{\mathrm{ECS}})$
- External Chip Select signal generation ( $\overline{\mathrm{XCS}})$
- Internal memory expansion
- Miscellaneous system control functions via the MISC register
- Reserved registers for test purposes
- Configurable system memory options defined at integration of Core into the System-on-a-Chip (SOC).


### 11.1.2 Block Diagram

The block diagram of the MMC is shown in Figure 11-1 below.


Figure 11-1 Module Mapping Control Block Diagram

### 11.2 Interface Signals

All interfacing with the MMC sub-block is done within the Core.

### 11.3 Registers

A summary of the registers associated with the MMC sub-block is shown in Figure 11-2 below. Detailed descriptions of the registers and bits are given in the subsections that follow.


Figure 11-2 Module Mapping Control Register Summary

### 11.3.1 Initialization of Internal RAM Position Register (INITRM)

Address: $\quad$ Base $+\$ 10$


Figure 11-3 INITRM Register

Read: Anytime
Write: Once in Normal and Emulation Modes, anytime in Special Modes
NOTE: Writes to this register take one cycle to go into effect.
This register initializes the position of the internal RAM within the on-chip system memory map.
RAM15 - RAM11 - Internal RAM Map Position
These bits determine the upper five bits of the base address for the system's internal RAM array.
RAMHAL - RAM High-align
RAMHAL specifies the alignment of the internal RAM array.
$0=$ Aligns the RAM to the lowest address ( $\$ 0000$ ) of the mappable space
$1=$ Aligns the RAM to the higher address (\$FFFF) of the mappable space
11.3.2 Initialization of Internal Registers Position Register (INITRG)

Address: $\quad$ Base $+\$ 11$


Figure 11-4 INITRG Register

Read: Anytime
Write: Once in Normal and Emulation modes and anytime in Special modes

This register initializes the position of the internal registers within the on-chip system memory map. The registers occupy either a 1 K byte or 2 K byte space and can be mapped to any 2 K byte space within the first 32 K bytes of the system's address space.

## REG14-REG11 - Internal Register Map Position

These four bits in combination with the leading zero supplied by bit 7 of INITRG determine the upper five bits of the base address for the system's internal registers (i.e. the minimum base address is $\$ 0000$ and the maximum is $\$ 7 \mathrm{FFF}$ ).

### 11.3.3 Initialization of Internal EEPROM Position Register (INITEE)

Address: $\quad$ Base $+\$ 12$


Figure 11-5 INITEE Register

Read: Anytime
Write: Once in Normal and Emulation modes with the exception of the EEON bit which can be written anytime and write anytime in Special modes

NOTE: Writes to this register take one cycle to go into effect.
This register initializes the position of the internal EEPROM within the on-chip system memory map.
EE15-EE11 - Internal EEPROM map position
These bits determine the upper five bits of the base address for the system's internal EEPROM array.

### 11.3.4 Miscellaneous System Control Register (MISC)

Address: Base + \$13

|  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read: | 0 | 0 | 0 | 0 | EXSTR1 | EXSTR0 | ROMHM | ROMON |
| Write: |  |  |  |  |  |  |  |  |
| Expanded Reset: | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |
| Peripheral or Single Chip Reset | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |
|  |  | = Unimplemented |  |  |  |  |  |  |

Figure 11-6 Miscellaneous System Control Register (MISC)
NOTES:

1. The reset state of this bit is determined at the chip integration level.

Read: Anytime
Write: As stated in each bit description below
NOTE:Writes to this register take one cycle to go into effect
This register initializes miscellaneous control functions.
EXSTR1,0 - External Access Stretch Bits $1 \& 0$
Write: Once in Normal and Emulation modes and anytime in Special modes
This two bit field determines the amount of clock stretch on accesses to the external address space as shown in Table 11-1 below. In Single Chip and Peripheral modes these bits have no meaning or effect.

Table 11-1 External Stretch Bit Definition

| Stretch bit EXSTR1 | Stretch bit EXSTR0 | Number of E Clocks Stretched |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | 3 |

ROMHM - Flash EEPROM or ROM only in second half of memory map
Write: Once in Normal and Emulation modes and anytime in Special modes

1 = Disables direct access to the Flash EEPROM or ROM in the lower half of the memory map. These physical locations of the Flash EEPROM or ROM can still be accessed through the Program Page window.
$0=$ The fixed page(s) of Flash EEPROM or ROM in the lower half of the memory map can be accessed.

ROMON - Enable Flash EEPROM or ROM
Write: Once in Normal and Emulation modes and anytime in Special modes
This bit is used to enable the Flash EEPROM or ROM memory in the memory map.
1 = Enables the Flash EEPROM or ROM in the memory map.
$0=$ Disables the Flash EEPROM or ROM from the memory map.

### 11.3.5 Reserved Test Register Zero (MTSTO)



Figure 11-7 Reserved Test Register Zero (MTSTO)

Read: Anytime
Write: No effect - this register location is used for internal test purposes.

### 11.3.6 Reserved Test Register One (MTST1)



Figure 11-8 Reserved Test Register One (MTST1)

Read: Anytime
Write: No effect - this register location is used for internal test purposes.

User Guide - S12CPu15感星s.scale Semiconductor, Inc.

### 11.3.7 Memory Size Register Zero (MEMSIZO)



Figure 11-9 Memory Size Register Zero

Read: Anytime
Write: Writes have no effect
The MEMSIZ0 register reflects the state of the register, EEPROM and RAM memory space configuration switches at the Core boundary which are configured at system integration. This register allows read visibility to the state of these switches.
reg_sw0 - Allocated System Register Space
$1=$ Allocated system register space size is 2 K byte
$0=$ Allocated system register space size is 1 K byte
eep_sw1:eep_sw0 - Allocated System EEPROM Memory Space
The allocated system EEPROM memory space size is as given in Table 11-2 below.
Table 11-2 Allocated EEPROM Memory Space

| eep_sw1:eep_sw0 | Allocated EEPROM Space |
| :---: | :---: |
| 00 | 0 K byte |
| 01 | 2 K byte |
| 10 | 4 K byte |
| 11 | 8 K byte |

ram_sw2:ram_sw0 - Allocated System RAM Memory Space
The allocated system RAM memory space size is as given in Table 11-3 below.
Table 11-3 Allocated RAM Memory Space

| ram_sw2:ram_sw0 | Allocated RAM Space | RAM mappable region | INITRM bits used |
| :---: | :---: | :---: | :---: |
| 000 | $2 k$ Byte | 2 k Byte | RAM15-RAM11 |
| 001 | 4 k Byte | 4 k Byte | RAM15-RAM12 |
| 010 | 6 k Byte | 8 k Byte ${ }^{1}$ | RAM15-RAM13 |
| 011 | 8 k Byte | 8 k Byte | RAM15-RAM13 |
| 100 | 10 k Byte | 16 k Byte $^{1}$ | RAM15-RAM14 |

Table 11-3 Allocated RAM Memory Space

| ram_sw2:ram_sw0 | Allocated RAM Space | RAM mappable region | INITRM bits used |
| :---: | :---: | :---: | :---: |
| 101 | 12 k Byte | 16 k Byte $^{1}$ | RAM15-RAM14 |
| 110 | 14 k Byte | 16 k Byte ${ }^{1}$ | RAM15-RAM14 |
| 111 | 16 k Byte | 16 k Byte | RAM15-RAM14 |

NOTES:

1. Alignment of the Allocated RAM space within the RAM mappable region is dependent on the value of RAMHAL.

NOTE: As stated, the bits in this register provide read visibility to the system physical memory space allocations defined at system integration. The actual array size for any given type of memory block may differ from the allocated size. Please refer to the chip-level documentation for actual sizes.

### 11.3.8 Memory Size Register One (MEMSIZ1)



Figure 11-10 Memory Size Register One

Read: Anytime
Write: Writes have no effect
The MEMSIZ1 register reflects the state of the Flash EEPROM or ROM physical memory space and paging switches at the Core boundary which are configured at system integration. This register allows read visibility to the state of these switches.
rom_sw1:rom_sw0 - Allocated System Flash EEPROM or ROM Physical Memory Space
The allocated system Flash EEPROM or ROM physical memory space is as given in Table 11-4 below.

Table 11-4 Allocated Flash EEPROM/ROM Physical Memory Space

| rom_sw1:rom_sw0 | Allocated Flash <br> or ROM Space |
| :---: | :---: |
| 00 | 0 K byte |
| 01 | 16 K byte |
| 10 | 48 K byte ${ }^{1}$ |
| 11 | $64 \mathrm{~K} \mathrm{byte}^{1}$ |

1 The ROMHM software bit in the MISC register determines the accessibility of the Flash EEPROM/ROM memory space. Please refer to 11.3.4 for a detailed functional description of the ROMHM bit.

User Guide - S12CPu15tutersscale Semiconductor, Inc.
pag_sw1:pag_sw0 - Allocated Off-Chip Flash EEPROM or ROM Memory Space
The allocated off-chip Flash EEPROM or ROM memory space size is as given in Table 11-5 below.
Table 11-5 Allocated Off-Chip Memory Options

| pag_sw1:pag_sw0 | Off-Chip Space | On-Chip Space |
| :---: | :---: | :---: |
| 00 | 876 K byte | 128 K byte |
| 01 | 768 K byte | 256 K byte |
| 10 | 512 K byte | 512 K byte |
| 11 | 0 K byte | 1 M byte |

NOTE: As stated, the bits in this register provide read visibility to the system memory space and on-chip/off-chip partitioning allocations defined at system integration. The actual array size for any given type of memory block may differ from the allocated size. Please refer to the chip-level documentation for actual sizes.

### 11.3.9 Program Page Index Register (PPAGE)



## Figure 11-11 Program Page Index Register (PPAGE)

Read: Anytime
Write: Anytime
The HCS12 Core architecture limits the physical address space available to 64 K bytes. The Program Page Index Register allows for integrating up to 1 M byte of Flash EEPROM or ROM into the system by using the six page index bits to page 16K byte blocks into the Program Page Window located from $\$ 8000$ to $\$ B F F F$ as defined in Table 11-6 below. CALL and RTC instructions have a special single wire mechanism to read and write this register without using the address bus.

NOTE: Normal writes to this register take one cycle to go into effect. Writes to this register using the special single wire mechanism of the CALL and RTC instructions will be complete before the end of the associated instruction.

PIX5 - PIX0 - Program Page Index Bits 5-0
These six page index bits are used to select which of the 64 Flash EEPROM or ROM array pages is to be accessed in the Program Page Window as shown in Table 11-6.

Table 11-6 Program Page Index Register Bits

| PIX5 | PIX4 | PIX3 | PIX2 | PIX1 | PIX0 | Program Space Selected |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 | 16 K page 0 |
| 0 | 0 | 0 | 0 | 0 | 1 | 16 K page 1 |
| 0 | 0 | 0 | 0 | 1 | 0 | 16 K page 2 |
| 0 | 0 | 0 | 0 | 1 | 1 | 16 K page 3 |
| . | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | . |
| $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ | $\cdot$ |
| 1 | 1 | 1 | 1 | 0 | 0 | 16 K page 60 |
| 1 | 1 | 1 | 1 | 0 | 1 | 16 K page 61 |
| 1 | 1 | 1 | 1 | 1 | 0 | 16K page 62 |
| 1 | 1 | 1 | 1 | 1 | 1 | 16K page 63 |

### 11.4 Operation

The MMC sub-block performs four basic functions of the Core operation: bus control, address decoding and select signal generation, memory expansion and security decoding for the system. Each aspect is described in the subsections following.

### 11.4.1 Bus Control

The MMC controls the address bus and data buses that interface the Core with the rest of the system. This includes the multiplexing of the input data buses to the Core onto the main CPU read data bus and control of data flow from the CPU to the output address and data buses of the Core. In addition, the MMC handles all CPU read data bus swapping operations.

### 11.4.2 Address Decoding

As data flows on the Core address bus, the MMC decodes the address information, determines whether the internal Core register or firmware space, the peripheral space or a memory register or array space is being addressed and generates the correct select signal. This decoding operation also interprets the mode of operation of the system and the state of the mapping control registers in order to generate the proper select. The MMC also generates two external chip select signals, Emulation Chip Select ( $\overline{\mathrm{ECS}}$ ) and External Chip Select ( $\overline{\mathrm{XCS}}$ ).

### 11.4.2.1 Select Priority and Mode Considerations

Although internal resources such as control registers and on-chip memory have default addresses, each can be relocated by changing the default values in control registers. Normally, I/O addresses, control registers, vector spaces, expansion windows, and on-chip memory are mapped so that their address ranges do not overlap. The MMC will make only one select signal active at any given time. This activation is based upon the priority outlined in Table 11-7 below. If two or more blocks share the same address space, only the select signal for the block with the highest priority will become active. An example of this is if the registers and the RAM are mapped to the same space, the registers will have priority over the RAM and the portion of RAM mapped in this shared space will not be accessible. The expansion windows have the lowest priority. This means that registers, vectors, and on-chip memory are always visible to a program regardless of the values in the page select registers.

Table 11-7 Select Signal Priority

| Priority | Address Space |
| :---: | :---: |
| Highest | BDM (internal to Core) firmware or register space |
| $\ldots$ | Internal register space |
| $\ldots$ | RAM memory block |
| $\ldots$ | EEPROM memory block |
| $\ldots$ | On-chip Flash EEPROM or ROM |
| Lowest | Remaining external space |

In expanded modes, all address space not used by internal resources is by default external memory space. The data registers and data directions registers for Ports A and B are removed from the on-chip memory map and become external accesses. If the EME bit in the MODE register (see 12.3.8) is set, the data and data direction registers for Port E are also removed from the on-chip memory map and become external accesses.

In Special Peripheral mode, the first 16 registers associated with bus expansion are removed from the on-chip memory map (PORTA, PORTB, DDRA, DDRB, PORTE, DDRE, PEAR, MODE, PUCR, RDRIV and the EBI reserved registers).

In emulation modes, if the EMK bit in the MODE register (see 12.3.8) is set, the data and data direction registers for Port K are removed from the on-chip memory map and become external accesses.

### 11.4.2.2 Emulation Chip Select Signal

When the EMK bit in the MODE register (see 12.3.8) is set, Port K bit 7 is used as an active-low emulation chip select signal, $\overline{\text { ECS. This signal is active when the system is in Emulation mode, the EMK bit is set }}$ and the Flash EEPROM or ROM space is being addressed subject to the conditions outlined in 11.4.3.2 below. When the EMK bit is clear, this pin is used for general purpose I/O.

### 11.4.2.3 External Chip Select Signal

When the EMK bit in the MODE register (see 12.3.8) is set, Port K bit 6 is used as an active-low external chip select signal, $\overline{\mathrm{XCS}}$. This signal is active only when the $\overline{\mathrm{ECS}}$ signal described above is not active and when the system is addressing the external address space. Accesses to unimplemented locations within the
register space or to locations that are removed from the map (i.e. Ports A and B in Expanded modes) will not cause this signal to become active. When the EMK bit is clear, this pin is used for general purpose I/O.

### 11.4.3 Memory Expansion

The HCS12 Core architecture limits the physical address space available to 64 K bytes. The Program Page Index Register allows for integrating up to 1 M byte of Flash EEPROM or ROM into the system by using the six page index bits to page 16 K byte blocks into the Program Page Window located from $\$ 8000$ to $\$ B F F F$ in the physical memory space. The paged memory space can consist of solely on-chip memory or a combination of on-chip and off-chip memory. This partitioning is configured at system integration through the use of the paging configuration switches (pag_sw1:pag_sw0) at the Core boundary. The options available to the integrator are as given in Table 11-8 below (this table matches Table 11-5 but is repeated here for easy reference).

Table 11-8 Allocated Off-Chip Memory Options

| pag_sw1:pag_sw0 | Off-Chip Space | On-Chip Space |
| :---: | :---: | :---: |
| 00 | 876 K byte | 128 K byte |
| 01 | 768 K byte | 256 K byte |
| 10 | 512 K byte | 512 K byte |
| 11 | 0 K byte | 1 M byte |

Based upon the system configuration, the Program Page Window will consider its access to be either internal or external as defined in Table 11-9 below.

Table 11-9 External/Internal Page Window Access

| pag_sw1:pag_sw0 | Partitioning | PIX5:0 Value | Page Window Access |
| :---: | :---: | :---: | :---: |
| 00 | 876K off-Chip, 128K on-Chip | \$00-\$37 | external |
|  |  | \$38-\$3F | internal |
| 01 | 768 K off-chip, 256K on-chip | \$00-\$2F | external |
|  |  | \$30-\$3F | internal |
| 10 | 512K off-chip, 512K on-chip | \$00-\$1F | external |
|  |  | \$20-\$3F | internal |
| 11 | OK off-chip, 1M on-chip | n/a | external |
|  |  | \$00-\$3F | internal |

NOTE: The partitioning as defined in Table 11-9 above applies only to the allocated memory space and the actual memory sizes implemented in the system may differ. Please refer to the chip-level documentation for actual sizes.

The PPAGE register holds the page select value for the Program Page WIndow. The value of the PPAGE register can be manipulated by normal read and write instructions as well as the CALL and RTC instructions.

Control registers, vector spaces and a portion of on-chip memory are located in unpaged portions of the 64 K byte physical address space. The stack and I/O addresses should also be in unpaged memory to make them accessible from any page.

The starting address of a service routine must be located in unpaged memory because the 16-bit exception vectors cannot point to addresses in paged memory. However, a service routine can call other routines that are in paged memory. The upper 16K byte block of memory space ( $\$ \mathrm{C} 000-\$ F F F F)$ is unpaged. It is recommended that all reset and interrupt vectors point to locations in this area.

### 11.4.3.1 CALL and Return from Call Instructions

CALL and RTC are uninterruptable instructions that automate page switching in the program expansion window. CALL is similar to a JSR instruction, but the subroutine that is called can be located anywhere in the normal 64 K byte address space or on any page of program expansion memory. CALL calculates and stacks a return address, stacks the current PPAGE value, and writes a new instruction-supplied value to PPAGE. The PPAGE value controls which of the 64 possible pages is visible through the 16 K byte expansion window in the 64 K byte memory map. Execution then begins at the address of the called subroutine.

During the execution of a CALL instruction, the CPU:

- Writes the old PPAGE value into an internal temporary register and writes the new instruction-supplied PPAGE value into the PPAGE register.
- Calculates the address of the next instruction after the CALL instruction (the return address), and pushes this 16-bit value onto the stack.
- Pushes the old PPAGE value onto the stack.
- Calculates the effective address of the subroutine, refills the queue, and begins execution at the new address on the selected page of the expansion window.

This sequence is uninterruptable; there is no need to inhibit interrupts during CALL execution. A CALL can be performed from any address in memory to any other address.

The PPAGE value supplied by the instruction is part of the effective address. For all addressing mode variations except indexed-indirect modes, the new page value is provided by an immediate operand in the instruction. In indexed-indirect variations of CALL, a pointer specifies memory locations where the new page value and the address of the called subroutine are stored. Using indirect addressing for both the new page value and the address within the page allows values calculated at run time rather than immediate values that must be known at the time of assembly.

The RTC instruction terminates subroutines invoked by a CALL instruction. RTC unstacks the PPAGE value and the return address and refills the queue. Execution resumes with the next instruction after the CALL.

During the execution of an RTC instruction, the CPU:

- Pulls the old PPAGE value from the stack
- Pulls the 16 -bit return address from the stack and loads it into the PC
- Writes the old PPAGE value into the PPAGE register
- Refills the queue and resumes execution at the return address

This sequence is uninterruptable; an RTC can be executed from anywhere in memory, even from a different page of extended memory in the expansion window.

The CALL and RTC instructions behave like JSR and RTS, except they use more execution cycles. Therefore, routinely substituting CALL/RTC for JSR/RTS is not recommended. JSR and RTS can be used to access subroutines that are on the same page in expanded memory. However, a subroutine in expanded memory that can be called from other pages must be terminated with an RTC. And the RTC unstacks a PPAGE value. So any access to the subroutine, even from the same page, must use a CALL instruction so that the correct PPAGE value is in the stack.

### 11.4.3.2 Extended Address (XAB19:14) and ECS Signal Functionality

If the EMK bit in the MODE register is set (see 12.3.8) the PIX5:0 values will be output on XAB19:14 respectively (Port K bits 5:0) when the system is addressing within the physical Program Page Window address space ( $\$ 8000-\$ B F F F)$ and is in an expanded mode. When addressing anywhere else within the physical address space (outside of the paging space), the XAB19:14 signals will be assigned a constant value based upon the physical address space selected. In addition, the active-low emulation chip select signal, $\overline{\mathrm{ECS}}$, will likewise function based upon the assigned memory allocation. In the cases of 48 K byte and 64 K byte allocated physical Flash/ROM space, the operation of the $\overline{\mathrm{ECS}}$ signal will additionally depend upon the state of the ROMHM bit (see 11.3.4) in the MISC register. Table 11-10, Table 11-11, Table 11-12 and Table 11-13 below summarize the functionality of these signals based upon the allocated memory configuration. Again, this signal information is only available externally when the EMK bit is set and the system is in an expanded mode.

Table 11-10 OK Byte Physical Flash/ROM Allocated

| Address Space | Page Window Access | ROMHM | ECS | XAB19:14 |
| :---: | :---: | :---: | :---: | :---: |
| $\$ 0000-\$ 3 F F F$ | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 1 | $\$ 3 \mathrm{D}$ |
| $\$ 4000-\$ 7 F F F$ | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 1 | $\$ 3 \mathrm{E}$ |
| $\$ 8000-\$$ BFFF | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 0 | PIX5:0 |
| $\$ C 000-\$$ FFFF | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 0 | $\$ 3 \mathrm{~F}$ |

Table 11-11 16K Byte Physical Flash/ROM Allocated

| Address Space | Page Window Access | ROMHM | ECS | XAB19:14 |
| :---: | :---: | :---: | :---: | :---: |
| $\$ 0000-\$ 3 F F F$ | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 1 | $\$ 3 \mathrm{D}$ |
| $\$ 4000-\$ 7 F F F$ | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 1 | $\$ 3 \mathrm{E}$ |
| $\$ 8000-\$$ BFFF | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 1 | PIX5:0 |
| $\$ C 000-\$$ FFFF | $\mathrm{n} / \mathrm{a}$ | $\mathrm{n} / \mathrm{a}$ | 0 | $\$ 3 \mathrm{~F}$ |

Table 11-12 48K Byte Physical Flash/ROM Allocated

| Address Space | Page Window Access | ROMHM | $\overline{\text { ECS }}$ | XAB19:14 |
| :---: | :---: | :---: | :---: | :---: |
| \$0000 - \$3FFF | n/a | $\mathrm{n} / \mathrm{a}$ | 1 | $\$ 3 \mathrm{D}$ |
| $\$ 4000-\$ 7 F F F$ | $\mathrm{n} / \mathrm{a}$ | 0 | 0 | $\$ 3 \mathrm{E}$ |
|  |  | 1 | 1 |  |

Table 11-12 48K Byte Physical Flash/ROM Allocated

| Address Space | Page Window Access | ROMHM | $\overline{\text { ECS }}$ | XAB19:14 |
| :---: | :---: | :---: | :---: | :---: |
| $\$ 8000-\$ B F F F$ | external | $\mathrm{n} / \mathrm{a}$ | 1 | PIX5:0 |
|  | internal |  | 0 |  |
| \$C000 - \$FFFF | n/a | $\mathrm{n} / \mathrm{a}$ | 0 | $\$ 3 F$ |

Table 11-13 64K Byte Physical Flash/ROM Allocated

| Address Space | Page Window Access | ROMHM | ECS | XAB19:14 |
| :---: | :---: | :---: | :---: | :---: |
| $\$ 0000-\$ 3 F F F$ | $\mathrm{n} / \mathrm{a}$ | 0 | 0 | $\$ 3 \mathrm{D}$ |
|  |  | 1 | 1 |  |
| $\$ 4000-\$ 7 F F F$ | $\mathrm{n} / \mathrm{a}$ | 0 | 0 | $\$ 3 \mathrm{E}$ |
|  |  | 1 | 1 |  |
| $\$ 8000-\$ B F F F$ | external | $\mathrm{n} / \mathrm{a}$ | 1 | PIX5:0 |
|  | internal | $\mathrm{n} / \mathrm{a}$ | 0 |  |
| $\$$ \$C000 - \$FFFF | n/a | $\mathrm{n} / \mathrm{a}$ | 0 | $\$ 3 \mathrm{~F}$ |

A graphical example of a memory paging for a system configured as 1 M byte on-chip Flash/ROM with 64 K allocated physical space is given in Figure 11-12 below for illustration.


Figure 11-12 Memory Paging Example: 1M Byte On-Chip Flash/ROM, 64K Allocation

### 11.5 Motorola Internal Information

The subsection aspects of the MMC that are considered to be for Motorola internal use only.

### 11.5.1 Test Registers

There are two test registers for the MMC, MTST[1:0]. These registers are used for internal test purposes to gain visibility into the module select logic.

In all modes, if the FLAGSE bit in MTST1 is set, accesses to internal registers or memory will cause the associated flag to assert. For example, an access into the RAM array will cause the MT01 bit (Bit 1in MTST0-RAM Array bit) to set. These registers can be read in any mode. If the FLAGSE bit is set, reading the register will cause it to be cleared. A write will have no effect in all modes.

### 11.5.1.1 Mapping Test Register 0 (MTSTO)



Figure 11-13 Mapping Test Register Zero (MTSTO)

Read: Anytime
Write: No effect
MT0 7-0 - Mapping Test 0
The individual bits are assigned as follows:
MT07-Core*
MT06 - Peripheral
MT05 - EE Array
MT04-EE Register
MT03 - Flash Array
MT02 - Flash Register
MT01 - RAM Array
MT00 - RAM Register

* This flag bit will not get set when you are accessing any of the MTST registers


### 11.5.1.2 Mapping Test Register 1 (MTST1)

| Address: $\quad$ Base + \$17 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read: | MT17 | MT16 | MT15 | MT14 | MT13 | MT12 | MT11 | MT10 |
| Write: |  | PNORME | FLAGSE | BKGDPUE |  |  |  |  |
| Reset: | 0 | 00 |  | 1 | 0 | 0 | 0 | 0 |
|  |  | = Unimplemented |  |  |  |  |  |  |

Figure 11-14 Mapping Test Register One (MTST1)

Read: Anytime
Write: See individual bit descriptions
MT17-Unimplemented (reads back zero)
MT16 - Mapping Test Register 1 Bit 6 (PNORME).
Normally, the system will enter peripheral mode and be in a special mode. Setting this bit will put the system into normal peripheral mode. This is so that testing of register normal mode read/write conditions can be performed while in peripheral mode.
Normal, Special \& Emulation: Write never.
Peripheral: Write anytime.
$1=$ The system operates in normal peripheral mode.
$0=$ The system operates in special peripheral mode.
MT15 - Mapping Test Register 1 Bit 5 (FLAGSE).
This bit is used to enable the select signal flag function of the MTST registers. When asserted, the MTST registers that have an associated block select signal flag bit will act as flag registers, where an access to the block causes the flag bit to assert. When unasserted, the MTST registers will not act as flag bits.
Normal \& Emulation: Write never.
Special: Write anytime.
$1=$ The MTST registers act as flag bits for the block select signals.
$0=$ The MTST registers do not act as flag bits for the block select signals.
MT14 - Mapping Test Register 3 Bit 4 (BKGDPUE)
This bit used to enable/disable the pull-up on the BKGD pin.
Normal \& Emulation: Write never
Special: Write anytime
$1=$ The pull-up on the BKGD pin is enabled.
$0=$ The pull-up on the BKGD pin is disabled.
MT 13-10 - Mapping Test Register 1 Bits 3:0

### 11.5.2 MMC Bus Control

This subsection discusses aspects of the bus control/multiplexing performed by the MMC.

### 11.5.2.1 Address Bus

The MMC multiplexes the EBI Alternate Address Bus, BDM Alternate Address Bus, and the CPU Address Bus to form the main address bus for the Core. The EBI Alternate Address Bus is the address bus source in peripheral mode. The BDM Alternate Address Bus is the address bus source whenever the BDM is driving the bus. The CPU Address Bus is the address bus source whenever the CPU has a valid address, the BDM is not driving the bus and the system is not operating in peripheral mode.

### 11.5.2.2 Write Data Bus

The CPU Write Data bus, EBI Alternate Write Data bus or BDM Alternate Write Data bus supply data to the master bus. The CPU Write Data bus is the write data source unless the cycle is a BDM access or the system is operating in peripheral mode. The BDM Alternate Write Data bus is the write data source only when the BDM is driving the bus. The EBI Alternate Write Data bus is the write data source in peripheral mode.

### 11.5.2.3 Read Data Bus

The MMC provides the control to split 16-bit accesses into two cycle operations, when needed. The CPU is paused during the second cycle of the two cycle access. For reads, the MMC takes care of swapping and holding the read data bus so that the CPU will receive the data on the correct location of its read data bus.

An access may also take two cycles when the Interrupt or BDM is driving the address bus, if the system is in a narrow mode and the 16 -bit access is to external memory space. In these cases, $\mathrm{AB}[0]$ will be forced high during the second cycle.

The MMC will also force those accesses that would normally be two cycle operations into a single cycle operation based upon the Wide Bus Enable signal. This signal will assert when performing a 16-bit access in narrow mode to those locations that are removed from the memory map, as summarized by Table 11-14.

Table 11-14 Wide Bus Enable Signal Generation

| Address | Register Names | Conditions | mmc_widebuse_t2 |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} \$ 0000- \\ \$ 0003 \end{gathered}$ | PORTA PORTB DDRA DDRB | $\begin{aligned} & \text { initrg }[4: 0]=\underset{\text { ebi_narrow_t2 }}{\text { mmc_ab_t2[15:11] }} \& ~ e b i \_e m u l \_t 2 ~ \& ~ \\ & \text { ent } \end{aligned}$ | 1 |
| $\begin{gathered} \$ 0008-1 \\ \$ 0009 \end{gathered}$ | PORTE DDRE | $\begin{aligned} \text { initrg[4:0] }= & =\text { mmc_ab_t2[15:11] \& ebi_emul_t2 \& } \\ & \text { ebi_narrow_t2 \& ebi_eme_t2 } \end{aligned}$ | 1 |
| $\begin{aligned} & \text { \$000A - } \\ & \text { \$000D } \end{aligned}$ | PEAR <br> MODE <br> PUCR <br> RDRIV | $\begin{aligned} & \text { initrg }[4: 0]=\underset{\text { ebi_narrow_t2 }}{\text { mmc_ab_t2[15:11] }} \& ~ e b i \_e m u l \_t 2 ~ \& ~ \\ & \text { eb } \end{aligned}$ | 1 |


| $\$ 0032-$ <br> $\$ 0033$ | PORTK <br> DDRK |  <br> ebi_narrow_t2 \& ebi_emk_t2 | 1 |
| :---: | :---: | :---: | :---: |
| All Others | - | - | 0 |

Table 11-15 summarizes the different access types, where the data is on the internal or external read data bus and where the CPU is expecting the data. The source of the CPU's read data bus for external accesses is the ebi_extrdb and for internal accesses is the rdb_t2.

IMS refers to the Internal Memory Select signal ( $1=$ Internal, $0=$ External). FMTS refers to the Fast Memory Transfer Select signal, which asserts anytime an access is made to the RAM except for the last byte of the array.

Table 11-15 Read Data Bus Swapping

| MODE | o <br> 00 <br> 0 <br> 0 <br> 10 <br> 0 <br> 0 <br> 0 <br> 0 <br> 0 <br> 0 <br> 0 | $\stackrel{\infty}{\underline{\infty}}$ | $\sum_{i L}^{\infty}$ | $\stackrel{\infty}{N}$ | 을 | CYCLES | Read Data Bus (Internal or External) <br> -> CPU Read Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Single Chip | X | 1 | X | 0 | 0 | 1 | $\begin{aligned} & \text { rdbh -> core_rdbh } \\ & \text { rdbl -> core_rdbl } \end{aligned}$ |
|  | X | 1 | 0 | 0 | 1 | 2 | 1. rdbl -> core_rdbh <br> 2. rdbh -> core_rdbl |
|  | X | 1 | x | 1 | 0 | 1 | rdbh -> core_rdbl |
|  | X | 1 | X | 1 | 1 | 1 | rdbl -> core_rdbl |
|  | X | 1 | 1 | 0 | 1 | 1 | $\begin{aligned} & \text { rdbl -> core_rdbh } \\ & \text { rdbh -> core_rdbl } \end{aligned}$ |
| Normal <br> Expanded Narrow | X | 0 | X | 0 | 0 | 2 | 1. extrdbh -> core_rdbh <br> 2. extrdbl -> core_rdbl |
|  | X | 0 | X | 0 | 1 | 2 | 1. extrdbl -> core_rdbh <br> 2. extrdbh -> core_rdbl |
|  | X | 0 | X | 1 | 0 | 1 | extrdbh -> core_rdbl |
|  | X | 0 | X | 1 | 1 | 1 | extrdbl -> core_rdbl |
|  | X | 1 | X | 0 | 0 | 1 | $\begin{aligned} & \text { rdbh -> core_rdbh } \\ & \text { rdbl -> core_rdbl } \end{aligned}$ |
|  | X | 1 | 0 | 0 | 1 | 2 | 1. rdbl -> core_rdbh <br> 2. $\mathrm{rdbh}->$ core_rdbl |
|  | X | 1 | x | 1 | 0 | 1 | rdbh -> core_rdbl |
|  | X | 1 | x | 1 | 1 | 1 | rdbl -> core_rdbl |
|  | X | 1 | 1 | 0 | 1 | 1 | $\begin{aligned} & \text { rdbl -> core_rdbh } \\ & \text { rdbh } \rightarrow \text { core_rdbl } \end{aligned}$ |

Table 11-15 Read Data Bus Swapping

| MODE | $\begin{aligned} & \stackrel{0}{0} \\ & \stackrel{0}{0} \\ & \tilde{w} \\ & 0 \\ & 0 \\ & 0 \\ & \stackrel{0}{3} \end{aligned}$ | $\sum_{\underline{\infty}}^{\infty}$ | $\sum_{i}^{\infty}$ | $\begin{aligned} & \infty \\ & \mathbb{N} \end{aligned}$ | $\frac{\text { 흘 }}{\mathbf{M}}$ | CYCLES | Read Data Bus (Internal or External) <br> -> CPU Read Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Emulation <br> Expanded Narrow | 0 | 0 | X | 0 | 0 | 2 | 1. extrdbh -> core_rdbh 2. extrdbl -> core_rdbl |
|  | X | 0 | X | 0 | 1 | 2 | 1. extrdbl -> core_rdbh <br> 2. extrdbh $->$ core_rdbl |
|  | 1 | 0 | X | 0 | 0 | 1 | $\begin{aligned} & \text { extrdbh -> core_rdbh } \\ & \text { extrdbl -> core_rdbl } \end{aligned}$ |
|  | X | 0 | x | 1 | 0 | 1 | extrdbh -> core_rdbl |
|  | X | 0 | X | 1 | 1 | 1 | extrdbl -> core_rdbl |
|  | X | 1 | X | 0 | 0 | 1 | $\begin{aligned} & \text { rdbh -> core_rdbh } \\ & \text { rdbl -> core_rdbl } \end{aligned}$ |
|  | X | 1 | 0 | 0 | 1 | 2 | 1. rdbl -> core_rdbh <br> 2. $\mathrm{rdbh}->$ core_rdbl |
|  | X | 1 | x | 1 | 0 | 1 | rdbh -> core_rdbl |
|  | X | 1 | X | 1 | 1 | 1 | rdbl -> core_rdbl |
|  | X | 1 | 1 | 0 | 1 | 1 | $\begin{aligned} & \text { rdbl -> core_rdbh } \\ & \text { rdbh }->\text { core_rdbl } \end{aligned}$ |
| Expanded Wide | X | X | X | 0 | 0 | 1 | (ext)rdbh -> core_rdbh (ext)rdbl -> core_rdbl |
|  | X | X | 0 | 0 | 1 | 2 | 1. (ext)rdbl -> core_rdbh <br> 2. (ext)rdbh -> core_rdbl |
|  | X | X | x | 1 | 0 | 1 | (ext)rdbh -> core_rdbl |
|  | X | X | X | 1 | 1 | 1 | (ext)rdbl -> core_rdbl |
|  | X | X | 1 | 0 | 1 | 1 | $\begin{aligned} & \text { (ext)rdbl -> core_rdbh } \\ & \text { (ext)rdbh -> core_rdbl } \end{aligned}$ |

## Section 12 Multiplexed External Bus Interface (MEBI)

This section describes the functionality of the Multiplexed External Bus Interface (MEBI) sub-block of the Core.

### 12.1 Overview

The MEBI sub-block of the Core serves to provide access and/or visibility to internal Core data manipulation operations including timing reference information at the external boundary of the Core and/or system. Depending upon the system operating mode and the state of bits within the control registers of the MEBI, the internal 16 -bit read and write data operations will be represented in 8 -bit or 16 -bit accesses externally. Using control information from other blocks within the system, the MEBI will determine the appropriate type of data access to be generated.

### 12.1.1 Features

- External bus controller with four 8-bit ports (A,B, E and K)
- Data and data direction registers for ports $\mathrm{A}, \mathrm{B} \mathrm{E}$ and K when used as general purpose I/O
- Control register to enable/disable alternate functions on Port E and Port K
- Mode control register
- Control register to enable/disable pullups on Ports A, B, E and K
- Control register to enable/disable reduced output drive on Ports A, B, E and K
- Control register to configure external clock behavior
- Control register to configure $\overline{\overline{\mathrm{RQ}}}$ pin operation
- Logic to capture and synchronize external interrupt pin inputs


### 12.1.2 Block Diagram

The block diagram of the MEBI sub-block is shown in Figure 12-1 below.


Figure 12-1 MEBI Block Diagram
In the figure, the signals on the right hand side represent pins that are accessible externally to the Core and/or system.

### 12.2 Interface Signals

Much of the interfacing with the MEBI sub-block is done within the Core; however, many of the MEBI signals pass through the Core boundary and interface with the system port/pad logic for Ports A, B, E and
K. The Core interface signals associated with the MEBI are shown in Table 12-1 below. The functional descriptions of the signals are provided below for completeness.

Table 12-1 MEBI Interface Signal Definitions

| Signal Name | Type | Functional Description |
| :--- | :---: | :--- |
| External Bus Interface Signals |  |  |
| core_paind[7:0] | I | Port A input data [7:0] |
| core_pado[7:0] | O | Port A data output [7:0] |
| core_paobe[7:0] | O | Port A output buffer enable [7:0] |
| core_paibe_t2 | O | Port A input buffer enable |
| core_papue_t2 | O | Port A pullup enable |
| core_padse_t2 | O | Port A drive strength enable |
| core_pbind[7:0] | I | Port B input data [7:0] |
| core_pbdo[7:0] | O | Port B data output [7:0] |
| core_pbobe[7:0] | O | Port B output buffer enable [7:0] |
| core_pbibe_t2 | O | Port B input buffer enable |
| core_pbpue_t2 | O | Port B pullup enable |
| core_pbdse_t2 | O | Port B drive strength enable |
| core_peind[7:0] |  | Port E input data [7:0] <br> NOTE: PE1 is IRQ pin input; PE0 is XIRQ pin input. |
| core_pedo[7:0] | O | Port E data output [7:0] |
| core_peobe[7:0] | O | Port E output buffer enable [7:0] |
| core_peibe_t2 | O | Port E input buffer enable |
| core_pepue_t2 | O | Port E pullup enable |
| core_mdrste | O | Enable signal for EBI Mode pin pullups at the pad |
| core_pedse_t2 | O | Port E drive strength enable |
| core_pkind[7:0] |  | Port K input data [7:0] |
| core_pkdo[7:0] | O | Port K data output [7:0] |
| core_pkobe[7:0] | O | Port K output buffer enable [7:0] |
| core_pkibe_t2 | O | Port K input buffer enable |
| core_pkpue_t2 | O | Port K pullup enable |
| core_pkdse_t2 | O | Port K drive strength enable |

### 12.2.1 MEBI Signal Descriptions

These descriptions apply to the MEBI signals that pass through the Core boundary and interface with the system External Bus Interface port/pad logic.

### 12.2.1.1 Port A Input Data to Core (core_paind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port A.

### 12.2.1.2 Port A Output Data from Core (core_pado[7:0])

This 8-bit wide output from the Core provides the Port A data output to the system port/pad logic for Port A.

### 12.2.1.3 Port A output buffer enable from Core (core_paobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port A.

### 12.2.1.4 Port A input buffer enable from Core (core_paibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port A.

### 12.2.1.5 Port A pullup enable from Core (core_papue_t2)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for Port A should be enabled for all Port A pins.

### 12.2.1.6 Port A drive strength enable from Core (core_padse_t2)

This single bit output from the Core indicates whether all Port A pins will operate with full or reduced drive strength.

### 12.2.1.7 Port B Input Data to Core (core_pbind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port B.

### 12.2.1.8 Port B Output Data from Core (core_pbdo[7:0])

This 8-bit wide output from the Core provides the Port B data output to the system port/pad logic for Port B.

### 12.2.1.9 Port B output buffer enable from Core (core_pbobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port B.

### 12.2.1.10 Port B input buffer enable from Core (core_pbibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port B.

### 12.2.1.11 Port B pullup enable from Core (core_pbpue_t2)

When asserted (logic 1), this single bit output from the Core indicates that the pullup devices within the system port/pad logic for Port B should be enabled for all Port B pins.

### 12.2.1.12 Port $B$ drive strength enable from Core (core_pbdse_t2)

This single bit output from the Core indicates whether all Port B pins will operate with full or reduced drive strength.

### 12.2.1.13 Port E Input Data to Core (core_peind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port E. When the system has an external $\overline{\mathrm{IRQ}}$ pin implemented, the input signal from the $\overline{\mathrm{IRQ}}$ pin pad logic must be tied to Port E Input Data Bit 1. Likewise, when the system has an external XIRQ pin implemented, the input signal from the $\overline{\mathrm{XIRQ}}$ pin pad logic must be tied to Port E Input Data Bit 0 . Both the $\overline{\overline{\mathrm{RQ}}}$ and $\overline{\mathrm{XIRQ}}$ signals are active low (i.e. their asserted state is logic 0 ).

### 12.2.1.14 Port E Output Data from Core (core_pedo[7:0])

This 8-bit wide output from the Core provides the Port E data output to the system port/pad logic for Port E.

### 12.2.1.15 Port E output buffer enable from Core (core_peobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port E.

### 12.2.1.16 Port E input buffer enable from Core (core_peibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port E.

### 12.2.1.17 Port E pullup enable from Core (core_pepue_t2)

This single bit output from the Core indicates whether or not the pullup devices within the system port/pad logic for Port E should be enabled for all Port E pins except the MODA (PE5) and MODB (PE6) pins.

### 12.2.1.18 Port E MODE pin pullup enable from Core (core_mdrste)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for the MODA (PE5) and MODB (PE6) pins within Port E should be enabled.

### 12.2.1.19 Port E drive strength enable from Core (core_pedse_t2)

This single bit output from the Core indicates whether all Port E pins will operate with full or reduced drive strength.

### 12.2.1.20 Port K Input Data to Core (core_pkind[7:0])

This 8-bit wide input to the Core provides the Core with the input data from the system port/pad logic for Port K.

### 12.2.1.21 Port K Output Data from Core (core_pkdo[7:0])

This 8-bit wide output from the Core provides the Port K data output to the system port/pad logic for Port K.

### 12.2.1.22 Port K output buffer enable from Core (core_pkobe[7:0])

This 8-bit wide output from the Core provides the bit-by-bit output buffer enable signal to the system port/pad logic for Port K.

### 12.2.1.23 Port K input buffer enable from Core (core_pkibe_t2)

This single bit output from the Core provides the input buffer enable signal to the system port/pad logic for Port K.

### 12.2.1.24 Port K pullup enable from Core (core_pkpue_t2)

This single bit output from the Core indicates that the pullup devices within the system port/pad logic for Port K should be enabled for all Port K pins.

### 12.2.1.25 Port $K$ drive strength enable from Core (core_pkdse_t2)

This single bit output from the Core indicates whether all Port K pins will operate with full or reduced drive strength.

### 12.3 Registers

A summary of the registers associated with the MEBI sub-block is shown in Figure 12-2 below. Detailed descriptions of the registers and bits are given in the subsections that follow.

| Address | Name |  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$0000 | PORTA | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0001 | PORTB | read <br> write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0002 | DDRA | read <br> write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0003 | DDRB | read <br> write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|  | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$0004 | Reserved | write |  |  |  |  |  |  |  |  |
| \$0005 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  | write |  |  |  |  |  |  |  |  |
|  |  | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$0006 | Reserved | write |  |  |  |  |  |  |  |  |
| \$0007 | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  | write |  |  |  |  |  |  |  |  |
| \$0008 | PORTE | read | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0009 | DDRE | read | Bit 7 | 6 | 5 | 4 | 3 | 2 | 0 | 0 |
|  |  | write |  |  |  |  |  |  |  |  |
| \$000A | PEAR | read | NOACCE | 0 | PIPOE | NECLK | LSTRE | RDWE | 0 | 0 |
|  |  |  |  |  |  | 0 |  | 0 |  |  |
| \$000B | MODE | read | MODC | MODB | MODA | 0 | IVIS | 0 | EMK | EME |
| \$000C | PUCR | read | PUPKE | 0 | 0 | PUPEE | 0 | 0 | PUPBE | PUPAE |
| \$000C | PUCR | write | PUPKE |  |  | PUPEE |  |  | PUPBE | PUPAE |
| \$000D | RDRIV | read | RDPK | 0 | 0 | RDPE | 0 | 0 | RDPB | RDPA |
|  |  | write |  |  |  | R 0 |  |  | RDPB | RDPA |
| \$000E | EBICTL | read write | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ESTR |
| \$000F | Reserved | read | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$000F | Reserved | write |  |  |  |  |  |  |  |  |
| \$001E | IRQCR | read | IRQE | IRQEN | 0 | 0 | 0 | 0 | 0 | 0 |
| \$001E | IRQCR | write | IRQE | IRQEN |  |  |  |  |  |  |
| \$0032 | PORTK | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$0033 | DDRK | read write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|  |  |  |  | $=$ Unimplemented |  | $\mathrm{X}=$ Indeterminate |  |  |  |  |

Figure 12-2 MEBI Register Map Summary

### 12.3.1 Port A Data Register (PORTA)

| Address: $\quad$ Base + \$__0 |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | BIT 7 | 6 | 5 | 4 | 3 | 2 | 1 | BIT 0 |
| Read: <br> Write: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Reset: | - | - | - | - | - | - | - | - |
| Single Chip: | PA7 | PA6 | PA5 | PA4 | PA3 | PA2 | PA1 | PA0 |
| Exp Wide, Emul. Nar with IVIS \& Periph: | AB/ DB15 | $\begin{gathered} \text { AB/ } \\ \text { DB14 } \end{gathered}$ | $\begin{gathered} \text { AB/ } \\ \text { DB13 } \end{gathered}$ | $\begin{gathered} \text { AB/ } \\ \text { DB12 } \end{gathered}$ | AB/ DB11 | $\begin{gathered} \text { AB/ } \\ \text { DB10 } \end{gathered}$ | AB/ <br> DB9 | AB/ <br> DB8 |
| Expanded Narrow: | AB15 \& DB15/ DB7 | AB14 \& DB14/ DB6 | AB13 \& DB13/ DB5 | AB12 \& DB12/ DB4 | AB11 \& DB11/ DB3 | AB10 \& DB10/ DB2 | AB9 \& DB9/ DB1 | AB8 \& DB8/ DB0 |

Figure 12-3 Port A Data Register (PORTA)

Read: anytime when register is in the map
Write: anytime when register is in the map
Port A bits 7 through 0 are associated with address lines A15 through A8 respectively and data lines D15/D7 through D8/D0 respectively. When this port is not used for external addresses such as in single-chip mode, these pins can be used as general purpose I/O. Data Direction Register A (DDRA) determines the primary direction of each pin. DDRA also determines the source of data for a read of PORTA.

This register is not in the on-chip memory map in expanded and peripheral modes.

## CAUTION:

To ensure that you read the value present on the PORTA pins, always wait at least one cycle after writing to the DDRA register before reading from the PORTA register.

### 12.3.2 Data Direction Register A (DDRA)

Address: $\quad$ Base $+\$ \ldots 2$

Reset:
Read:

Write: $\quad$| Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Figure 12-4 Data Direction Register A (DDRA)

Read: anytime when register is in the map
Write: anytime when register is in the map
This register controls the data direction for Port A. When Port A is operating as a general purpose I/O port, DDRA determines the primary direction for each Port A pin. A " 1 " causes the associated port pin to be an output and a " 0 " causes the associated pin to be a high-impedance input. The value in a DDR bit also affects the source of data for reads of the corresponding PORTA register. If the DDR bit is zero (input) the buffered pin input state is read. If the DDR bit is one (output) the associated port data register bit state is read.

This register is not in the on-chip map in expanded and peripheral modes. It is reset to $\$ 00$ so the DDR does not override the three-state control signals.

DDRA7-0 — Data Direction Port A
$1=$ Configure the corresponding I/O pin as an output
$0=$ Configure the corresponding I/O pin as an input

### 12.3.3 Port B Data Register (PORTB)



Figure 12-5 Port B Data Register (PORTB)

Read: anytime when register is in the map
Write: anytime when register is in the map Port B bits 7 through 0 are associated with address lines A7 through A0 respectively and data lines D7 through D0 respectively. When this port is not used for external addresses, such as in single-chip mode, these pins can be used as general purpose I/O. Data Direction Register B (DDRB) determines the primary direction of each pin. DDRB also determines the source of data for a read of PORTB.

This register is not in the on-chip map in expanded and peripheral modes
CAUTION:
To ensure that you read the value present on the PORTB pins, always wait at least one cycle after writing to the DDRB register before reading from the PORTB register.

### 12.3.4 Data Direction Register B (DDRB)

Address: $\quad$ Base $+\$ \ldots 3$

Read:
Write:
Reset:


Figure 12-6 Data Direction Register B (DDRB)

Read: anytime when register is in the map
Write: anytime when register is in the map

This register controls the data direction for Port B . When Port B is operating as a general purpose I/O port, DDRB determines the primary direction for each Port B pin. A " 1 " causes the associated port pin to be an output and a " 0 " causes the associated pin to be a high-impedance input. The value in a DDR bit also affects the source of data for reads of the corresponding PORTB register. If the DDR bit is zero (input) the buffered pin input state is read. If the DDR bit is one (output) the associated port data register bit state is read.

This register is not in the on-chip map in expanded and peripheral modes. It is reset to $\$ 00$ so the DDR does not override the three-state control signals.

DDRB7-0 — Data Direction Port B
$1=$ Configure the corresponding I/O pin as an output
$0=$ Configure the corresponding I/O pin as an input

### 12.3.5 Port E Data Register (PORTE)



Figure 12-7 Port E Data Register (PORTE)

Read: anytime when register is in the map
Write: anytime when register is in the map
Port E is associated with external bus control signals and interrupt inputs. These include mode select (MODB/IPIPE1, MODA/IPIPE0), E clock, size ( $\overline{\mathrm{LSTRB}} / \overline{\mathrm{TAGLO}})$, read / write (R/到), $\overline{\mathrm{IRQ}}$, and $\overline{\text { XIRQ }}$. When not used for one of these specific functions, Port E pins 7-2 can be used as general purpose I/O and pins 1-0 can be used as general purpose input. The Port E Assignment Register (PEAR) selects the function of each pin and DDRE determines whether each pin is an input or output when it is configured to be general purpose I/O. DDRE also determines the source of data for a read of PORTE.

Some of these pins have software selectable pullups (PE7, ECLK, $\overline{\mathrm{LSTRB}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{IRQ}}$ and $\overline{\mathrm{XIRQ}}$ ). A single control bit enables the pullups for all of these pins when they are configured as inputs

This register is not in the on-chip map in peripheral mode or in expanded modes when the EME bit is set

It is unwise to write PORTE and DDRE as a word access. If you are changing Port E pins from being inputs to outputs, the data may have extra transitions during the write. It is best to initialize PORTE before enabling as outputs.

CAUTION:
To ensure that you read the value present on the PORTE pins, always wait at least one cycle after writing to the DDRE register before reading from the PORTE register

### 12.3.6 Data Direction Register E (DDRE)



Figure 12-8 Data Direction Register E (DDRE)

Read: anytime when register is in the map
Write: anytime when register is in the map
Data Direction Register E is associated with Port E. For bits in Port E that are configured as general purpose I/O lines, DDRE determines the primary direction of each of these pins. A " 1 " causes the associated bit to be an output and a " 0 " causes the associated bit to be an input. Port E bit 1 (associated with $\overline{\overline{I R Q}}$ ) and bit 0 (associated with $\overline{\mathrm{XIRQ}}$ ) cannot be configured as outputs. Port E , bits 1 and 0 , can be read regardless of whether the alternate interrupt function is enabled. The value in a DDR bit also affects the source of data for reads of the corresponding PORTE register. If the DDR bit is zero (input) the buffered pin input state is read. If the DDR bit is one (output) the associated port data register bit state is read.

This register is not in the on-chip map in peripheral mode. It is also not in the map in expanded modes while the EME control bit is set.

DDRE7-2 - Data Direction Port E
$1=$ Configure the corresponding I/O pin as an output
$0=$ Configure the corresponding I/O pin as an input
CAUTION:
It is unwise to write PORTE and DDRE as a word access. If you are changing Port E pins from inputs to outputs, the data may have extra transitions during the write. It is best to initialize PORTE before enabling as outputs.

### 12.3.7 Port E Assignment Register (PEAR)

| Address: | Base + \$__A |  | 5 | 4 | 3 | 2 | 1 | BIT 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | BIT 7 | 6 |  |  |  |  |  |  |  |
| Read: | NOACC$E$ | 0 | PIPOE | NECLK | LSTRE | RDWE | 0 | 0 | Special Single Chip |
| Write: |  |  |  |  |  |  |  |  |  |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| Reset: | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | Special Test |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Peripheral |
| Reset: | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | Emulation Exp Nar |
| Reset: | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | Emulation Exp Wide |
| Reset: | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | Normal Single Chip |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Normal Exp Nar |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Normal Exp Wide |
|  |  | = Unimplemented |  |  |  |  |  |  |  |

Figure 12-9 Port E Assignment Register (PEAR)

Read: anytime (provided this register is in the map).
Write: each bit has specific write conditions. Please refer to the descriptions of each bit on the following pages.Port E serves as general purpose I/O or as system and bus control signals. The PEAR register is used to choose between the general purpose I/O function and the alternate control functions. When an alternate control function is selected, the associated DDRE bits are overridden.

The reset condition of this register depends on the mode of operation because bus control signals are needed immediately after reset in some modes. In normal single chip mode, no external bus control signals are needed so all of Port E is configured for general purpose I/O. In normal expanded modes, only the E clock is configured for its alternate bus control function and the other bits of Port E are configured for general purpose I/O. As the reset vector is located in external memory, the E clock is required for this access. $\mathrm{R} / \overline{\mathrm{W}}$ is only needed by the system when there are external writable resources. If the normal expanded system needs any other bus control signals, PEAR would need to be written before any access that needed the additional signals. In special test and emulation modes, IPIPE1, IPIPE0, E, $\overline{\mathrm{LSTRB}}$ and $\mathrm{R} / \overline{\mathrm{W}}$ are configured out of reset as bus control signals

This register is not in the on-chip map in emulation and peripheral modes.

## NOACCE - CPU No Access Output Enable

Normal: write once
Emulation: write never
Special: write anytime
$1=$ The associated pin (Port E bit 7) is output and indicates whether the cycle is a CPU free cycle.
$0=$ The associated pin (Port E bit 7) is general purpose I/O.
This bit has no effect in single chip or peripheral modes.
PIPOE - Pipe Status Signal Output Enable
Normal: write once
Emulation: write never
Special: write anytime.
$1=$ The associated pins (Port E bits 6:5) are outputs and indicate the state of the instruction queue $0=$ The associated pins (Port E bits 6:5) are general purpose I/O.
This bit has no effect in single chip or peripheral modes.
NECLK - No External E Clock
Normal and Special: write anytime
Emulation: write never
$1=$ The associated pin (Port E bit-4) is a general purpose I/O pin.
$0=$ The associated pin (Port E bit-4) is the external E clock pin. External E clock is free-running if ESTR=0
External E clock is available as an output in all modes.
LSTRE - Low Strobe ( $\overline{\mathrm{LSTRB}}$ ) Enable
Normal: write once
Emulation: write never
Special: write anytime.
$1=$ The associated pin (Port E bit-3) is configured as the $\overline{\mathrm{LSTRB}}$ bus control output. If BDM tagging is enabled, $\overline{\text { TAGLO }}$ is multiplexed in on the rising edge of ECLK and $\overline{\text { LSTRB }}$ is driven out on the falling edge of ECLK.
$0=$ The associated pin (Port E bit-3) is a general purpose I/O pin.
This bit has no effect in single chip, peripheral or normal expanded narrow modes.
NOTE: $\overline{L S T R B}$ is used during external writes. After reset in normal expanded mode, $\overline{L S T R B}$ is disabled to provide an extra I/O pin. If $\overline{\operatorname{LSTRB}}$ is needed, it should be enabled before any external writes. External reads do not normally need $\overline{L S T R B}$ because all 16 data bits can be driven even if the system only needs 8 bits of data.

RDWE - Read / Write Enable
Normal: write once

Emulation: write never
Special: write anytime
$1=$ The associated pin (Port E bit-2) is configured as the $\mathrm{R} / \overline{\mathrm{W}}$ pin
$0=$ The associated pin (Port E bit-2) is a general purpose I/O pin.
This bit has no effect in single chip or peripheral modes.
NOTE: $\quad R / \overline{\mathrm{W}}$ is used for external writes. After reset in normal expanded mode, $R / \bar{W}$ is disabled to provide an extra I/O pin. If $R / \bar{W}$ is needed it should be enabled before any external writes.

### 12.3.8 MODE Register (MODE)



Figure 12-10 MODE Register (MODE)

Read: anytime (provided this register is in the map).
Write: each bit has specific write conditions. Please refer to the descriptions of each bit on the following pages.

The MODE register is used to establish the operating mode and other miscellaneous functions (i.e. internal visibility and emulation of Port E and K).

In peripheral modes, this register is not accessible but it is reset as shown to configure system features. Changes to bits in the MODE register are delayed one cycle after the write.

This register is not in the on-chip map in emulation and peripheral modes.
MODC, MODB, MODA - Mode Select bits
These bits indicate the current operating mode.
If MODA=1, then MODC, MODB, MODA are write never.
If $M O D C=M O D A=0$, then $\mathrm{MODC}, \mathrm{MODB}, \mathrm{MODA}$ are write anytime except that you cannot change to or from peripheral mode
If $\mathrm{MODC}=1, \mathrm{MODB}=0$ and $\mathrm{MODA}=0$, then MODC is write never, and MODB, MODA are write once, except that you cannot change to peripheral, special test, special single chip, or emulation modes.

Table 12-2 MODC, MODB, MODA Write Capability ${ }^{1}$

| MODC | MODB | MODA | Mode | MODx Write Capability |
| :---: | :---: | :---: | :--- | :---: |
| 0 | 0 | 0 | Special Single Chip | MODC, B, A write anytime but not to $110^{2}$ |
| 0 | 0 | 1 | Emulation Narrow | no write |
| 0 | 1 | 0 | Special Test | MODC, B, A write anytime but not to $110^{2}$ |
| 0 | 1 | 1 | Emulation Wide | no write |
| 1 | 0 | 0 | Normal Single Chip | nODC write never, MODB, A write once but not |
| to 110 |  |  |  |  |

NOTES:

1. No writes to the MOD bits are allowed while operating in a SECURE mode. For more details refer to the security specification document.
2. If you are in a special single chip or special test mode and you write to this register, changing to normal single chip mode, then one allowed write to this register remains. If you write to normal expanded or emulation mode, then no writes remain.

Table 12-3 Mode Select and State of Mode Bits

| Input <br> BKGD <br> \& bit <br> MODC | Input <br> \& bit <br> MODB | Input <br> \& bit <br> MODA | Mode Description |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Special Single Chip, BDM allowed and ACTIVE. BDM is "allowed" in all other <br> modes but a serial command is required to make BDM "active". |
| 0 | 0 | 1 | Emulation Expanded Narrow, BDM allowed |

Table 12-3 Mode Select and State of Mode Bits

| Input <br> BKGD <br> \& bit <br> MODC | Input <br> \& bit <br> MODB | Input <br> \& bit <br> MODA |  |
| :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | Special Test (Expanded Wide), BDM allowed |
| 0 | 1 | 1 | Emulation Expanded Wide, BDM allowed |
| 1 | 0 | 0 | Normal Single Chip, BDM allowed |
| 1 | 0 | 1 | Normal Expanded Narrow, BDM allowed |
| 1 | 1 | 0 | Peripheral; BDM allowed but bus operations would cause bus conflicts (must <br> not be used) |
| 1 | 1 | 1 | Normal Expanded Wide, BDM allowed |

IVIS - Internal Visibility (for both read and write accesses)
This bit determines whether internal accesses generate a bus cycle that is visible on the external bus.
Normal: write once
Emulation: write never
Special: write anytime
$1=$ Internal bus operations are visible on external bus.
$0=$ No visibility of internal bus operations on external bus.
Reference Section 12.4.9 for mode availability of this bit.
EMK - Emulate Port K
Normal: write once
Emulation: write never
Special: write anytime
$1=$ If in any expanded mode, PORTK and DDRK are removed from the memory map.
$0=$ PORTK and DDRK are in the memory map so Port K can be used for general purpose I/O.
In single-chip modes, PORTK and DDRK are always in the map regardless of the state of this bit.
In peripheral modes, PORTK and DDRK are never in the map regardless of the state of this bit.
EME - Emulate Port E
Normal and Emulation: write never
Special: write anytime
$1=$ If in any expanded mode or special peripheral mode, PORTE and DDRE are removed from the memory map. Removing the registers from the map allows the user to emulate the function of these registers externally.
$0=$ PORTE and DDRE are in the memory map so Port E can be used for general purpose I/O.
In single-chip modes, PORTE and DDRE are always in the map regardless of the state of this bit.

### 12.3.9 Pullup Control Register (PUCR)

Address: $\quad$ Base + \$___C


Figure 12-11 Pullup Control Register (PUCR)
NOTES:

1. The reset state of this register may be controlled by an instantiation parameter as described in the HCS12 V1.5 Core Integration Guide. The default value of this parameter is shown. Please refer to the specific device User's Guide to determine the actual reset state of this register.

Read: anytime (provided this register is in the map).
Write: anytime (provided this register is in the map).
This register is used to select pullup resistors for the pins associated with the core ports. Pullups are assigned on a per-port basis and apply to any pin in the corresponding port that is currently configured as an input.

This register is not in the on-chip map in emulation and peripheral modes.
NOTE:These bits have no effect when the associated pin(s) are outputs. (The pullups are inactive.)
PUPKE - Pullup Port K Enable
1 = Enable pullup devices for Port K input pins.
$0=$ Port K pullups are disabled.
PUPEE - Pullup Port E Enable
1 = Enable pullup devices for Port E input pins bits 7, 4-0.
$0=$ Port E pullups on bit 7, 4-0 are disabled.
PUPBE - Pullup Port B Enable
$1=$ Enable pullup devices for all Port B input pins.
$0=$ Port B pullups are disabled.
PUPAE - Pullup Port A Enable
1 = Enable pullup devices for all Port A input pins.
$0=$ Port A pullups are disabled.

### 12.3.10 Reduced Drive Register (RDRIV)

Address: $\quad$ Base + \$__D


Figure 12-12 Reduced Drive Register (RDRIV)

Read: anytime (provided this register is in the map)
Write: anytime (provided this register is in the map)
This register is used to select reduced drive for the pins associated with the core ports. This gives reduced power consumption and reduced RFI with a slight increase in transition time (depending on loading). This feature would be used on ports which have a light loading. The reduced drive function is independent of which function is being used on a particular port.

This register is not in the on-chip map in emulation and peripheral modes.
RDPK - Reduced Drive of Port K
1 = All Port K output pins have reduced drive enabled.
$0=$ All Port K output pins have full drive enabled.
RDPE - Reduced Drive of Port E
$1=$ All Port E output pins have reduced drive enabled.
$0=$ All Port E output pins have full drive enabled.
RDPB - Reduced Drive of Port B
$1=$ All Port B output pins have reduced drive enabled.
$0=$ All Port B output pins have full drive enabled.
RDPA - Reduced Drive of Ports A
$1=$ All Port A output pins have reduced drive enabled.
$0=$ All Port A output pins have full drive enabled.

### 12.3.11 Extemal Bus Interface Control Register (EBICTL)

Address: $\quad$ Base $+\$ \ldots \quad E$


Figure 12-13 External Bus Interface Control Register (EBICTL)

Read: anytime (provided this register is in the map)
Write: refer to individual bit descriptions below
The EBICTL register is used to control miscellaneous functions (i.e. stretching of external E clock).
This register is not in the on-chip map in peripheral mode.
ESTR - E clock Stretches
This control bit determines whether the E clock behaves as a simple free-running clock or as a bus control signal that is active only for external bus cycles.
Normal and Emulation: write once
Special: write anytime
$1=\mathrm{E}$ stretches high during stretch cycles and low during non-visible internal accesses.
$0=\mathrm{E}$ never stretches (always free running).
This bit has no effect in single chip modes.

### 12.3.12 IRQ Control Register (IRQCR)



Figure 12-14 IRQ Control Register (IRQCR)
Read: see individual bit descriptions below
Write: see individual bit descriptions below

IRQE - IRQ select edge sensitive only
Special: read or write anytime
Normal: read anytime, write once
Emulation: read anytime, write never
$1=I R Q$ configured to respond only to falling edges. Falling edges on the IRQ pin will be detected anytime $\operatorname{IRQE}=1$ and will be cleared only upon a reset or the servicing of the IRQ interrupt (i.e. vector $=\$$ FFF2).
$0=$ IRQ configured for low level recognition
IRQEN - External IRQ enable
Normal, emulation, and special modes: read or write anytime
$1=$ External IRQ pin is connected to interrupt logic.
$0=$ External IRQ pin is disconnected from interrupt logic
NOTE: In this state the edge detect latch is disabled.

### 12.3.13 Reserved Registers.



Figure 12-15 Reserved Registers

These register locations are not used (reserved). All unused registers and bits in this block return logic zeros when read. Writes to these registers have no effect.

These registers are not in the on-chip map in peripheral mode.

### 12.3.14 Port K Data Register (PORTK).



Figure 12-16 Port K Data Register (PORTK)

Read: anytime
Write: anytime
This port is associated with the internal memory expansion emulation pins. When the port is not enabled to emulate the internal memory expansion, the port pins are used as general-purpose I/O. When Port K is operating as a general purpose I/O port, DDRK determines the primary direction for each Port K pin. A " 1 " causes the associated port pin to be an output and a " 0 " causes the associated pin to be a
high-impedance input. The value in a DDR bit also affects the source of data for reads of the corresponding PORTK register. If the DDR bit is zero (input) the buffered pin input is read. If the DDR bit is one (output) the output of the port data register is read.This register is not in the map in peripheral or expanded modes while the EMK control bit in MODE register is set.

When inputs, these pins can be selected to be high impedance or pulled up, based upon the state of the PUPKE bit in the PUCR register.

Bit 7-Port K bit 7.
This bit is used as an emulation chip select signal for the emulation of the internal memory expansion, or as general purpose I/O, depending upon the state of the EMK bit in the MODE register. While this bit is used as a chip select, the external bit will return to its de-asserted state (vdd) for approximately $1 / 4$ cycle just after the negative edge of ECLK, unless the external access is stretched and ECLK is free-running (ESTR bit in EBICTL = 0). See the HCS12v1.5 MMC spec for additional details on when this signal will be active.

Bit 6 - Port K bit 6.
This bit is used as an external chip select signal for most external accesses that are not selected by $\overline{\text { ECS }}$ (see the MMC spec for more details), depending upon the state the of the EMK bit in the MODE register. While this bit is used as a chip select, the external pin will return to its de-asserted state (vdd) for approximately $1 / 4$ cycle just after the negative edge of ECLK, unless the external access is stretched and ECLK is free-running (ESTR bit in EBICTL $=0$ ).

Bit 5-Bit 0-Port K bits 5-0.
These six bits are used to determine which Flash/ROM or external memory array page is being accessed. They can be viewed as expanded addresses XAB19- XAB14 of the 20-bit address used to access up to1M byte internal Flash/ROM or external memory array. Alternatively, these bits can be used for general purpose I/O depending upon the state of the EMK bit in the MODE register.

### 12.3.15 Port K Data Direction Register (DDRK)



Figure 12-17 Port K Data Direction Register (DDRK)

Read: anytime.
Write: anytime.

User Guide - S12CPU15FrGerscale Semiconductor, Inc.
This register determines the primary direction for each port K pin configured as general-purpose I/O. This register is not in the map in peripheral or expanded modes while the EMK control bit in MODE register is set.

DDRK 7-0 - The Data Direction Port K.
$1=$ Associated pin is an output
$0=$ Associated pin is a high-impedance input
CAUTION:
It is unwise to write PORTK and DDRK as a word access. If you are changing Port K pins from inputs to outputs, the data may have extra transitions during the write. It is best to initialize PORTK before enabling as outputs.

CAUTION:
To ensure that you read the correct value from the PORTK pins, always wait at least one cycle after writing to the DDRK register before reading from the PORTK register.

### 12.4 Operation

There are four main sub-blocks within the MEBI: external bus control, external data bus interface, control and registers.

### 12.4.1 External Bus Control

The external bus control generates the miscellaneous control functions (pipe signals, ECLK, $\overline{\text { LSTRB }}$ and $R / \bar{W})$ that will be sent external on Port E , bits 6-2. It also generates the external addresses.

### 12.4.2 External Data Bus Interface

The external data bus interface block manages data transfers from/to the external pins to/from the internal read and write data buses. This block selectively couples 8 -bit or 16 -bit data to the internal data bus to implement a variety of data transfers including 8-bit, 16 -bit, 16 -bit swapped and 8 -bit external to 16 -bit internal accesses. Modes, addresses, chip selects, etc. affect the type of accesses performed during each bus cycle.

### 12.4.3 Control

The control block generates the register read/write control signals and miscellaneous port control signals.

### 12.4.4 Registers

The register block includes the fourteen 8-bit registers and five reserved register locations associated with the MEBI sub-block.

### 12.4.5 External System Pin Functional Descriptions

In typical SoC implementations, the MEBI sub-block of the Core interfaces directly with external system pins. Table 12-4 below outlines the pin names and functions and gives a brief description of their operation.

Table 12-4 External System Pins Associated With MEBI

| Pin Name | Pin Functions | Description |
| :---: | :---: | :---: |
| $\begin{aligned} & \text { PA7/A15/D15/D7 } \\ & \text { thru } \\ & \text { PA0/A8/D8/D0 } \end{aligned}$ | PA7-PA0 | General purpose I/O pins, see PORTA and DDRA registers. |
|  | A15-A8 | High-order address lines multiplexed during ECLK low. Outputs except in special peripheral mode where they are inputs from an external tester system. |
|  | D15-D8 | High-order bidirectional data lines multiplexed during ECLK high in expanded wide modes, peripheral mode \& visible internal accesses (IVIS=1) in emulation expanded narrow mode. Direction of data transfer is generally indicated by R/W. |
|  | D15/D7 thru D8/D0 | Alternate high-order and low-order bytes of the bidirectional data lines multiplexed during ECLK high in expanded narrow modes and narrow accesses in wide modes. Direction of data transfer is generally indicated by R/W. |
| $\begin{aligned} & \text { PB7/A7/D7 } \\ & \text { thru } \\ & \text { PB0/A0/D0 } \end{aligned}$ | PB7-PB0 | General purpose I/O pins, see PORTB and DDRB registers. |
|  | A7-A0 | Low-order address lines multiplexed during ECLK low. Outputs except in special peripheral mode where they are inputs from an external tester system. |
|  | D7-D0 | Low-order bidirectional data lines multiplexed during ECLK high in expanded wide modes, peripheral mode \& visible internal accesses (with IVIS=1) in emulation expanded narrow mode. Direction of data transfer is generally indicated by R/W. |
| PE7/ <br> NOACC | PE7 | General purpose I/O pin, see PORTE and DDRE registers. |
|  | NOACC | CPU No Access output. Indicates whether the current cycle is a free cycle. Only available in expanded modes. |
| PE6/IPIPE1/ MODB/CLKTO | MODB | At the rising edge of $\overline{R E S E T}$, the state of this pin is registered into the MODB bit to set the mode. |
|  | PE6 | General purpose I/O pin, see PORTE and DDRE registers. |
|  | IPIPE1 | Instruction pipe status bit 1, enabled by PIPOE bit in PEAR. |
|  | CLKTO | System Clock Test Output. Only available in special modes. PIPOE=1 overrides this function. The enable for this function is in the clock module. |
| PE5/IPIPE0/ MODA | MODA | At the rising edge on RESET, the state of this pin is registered into the MODA bit to set the mode. |
|  | PE5 | General purpose I/O pin, see PORTE and DDRE registers. |
|  | IPIPE0 | Instruction pipe status bit 0, enabled by PIPOE bit in PEAR. |
| PE4/ECLK | PE4 | General purpose I/O pin, see PORTE and DDRE registers. |
|  | ECLK | Bus timing reference clock, can operate as a free-running clock at the system clock rate or to produce one low-high clock per visible access, with the high period stretched for slow accesses. ECLK is controlled by the NECLK bit in PEAR, the IVIS bit in MODE and the ESTR bit in EBICTL. |

:User Guide - S12CPU15t5ters.scale Semiconductor, Inc.

Table 12-4 External System Pins Associated With MEBI

| Pin Name | Pin Functions | Description |
| :---: | :---: | :---: |
| $\frac{\text { PE3/ } \overline{\text { LSTRB } / ~} /}{\text { TAGLO }}$ | PE3 | General purpose I/O pin, see PORTE and DDRE registers. |
|  | LSTRB | Low strobe bar, 0 indicates valid data on D7-D0. |
|  | SZ8 | In peripheral mode, this pin is an input indicating the size of the data transfer ( $0=16$-bit; $1=8$-bit). |
|  | $\overline{\text { TAGLO }}$ | In expanded wide mode or emulation narrow modes, when instruction tagging is on and low strobe is enabled, a 0 at the falling edge of $E$ tags the low half of the instruction word being read into the instruction queue. |
| PE2/R/W | PE2 | General purpose I/O pin, see PORTE and DDRE registers. |
|  | R/W | Read/write, indicates the direction of internal data transfers. This is an output except in peripheral mode where it is an input. |
| PE1/IRQ | PE1 | General purpose input-only pin, can be read even if $\overline{\mathrm{IRQ}}$ enabled. |
|  | $\overline{\mathrm{IRQ}}$ | Maskable interrupt request, can be level sensitive or edge sensitive. |
| PE0/XIRQ | PE0 | General purpose input-only pin. |
|  | $\overline{\mathrm{XIRQ}}$ | Non-maskable interrupt input. |
| PK7/ECS | PK7 | General purpose I/O pin, see PORTK and DDRK registers. |
|  | ECS | emulation chip select |
| PK6/XCS | PK6 | General purpose I/O pin, see PORTK and DDRK registers. |
|  | $\overline{\text { XCS }}$ | external data chip select |
| PK5/X19 thru PK0/X14 | PK5 - PK0 | General purpose I/O pins, see PORTK and DDRK registers. |
|  | X19-X14 | Memory expansion addresses |
| $\frac{\mathrm{BKGD} / \mathrm{MODC} /}{\mathrm{TAGHI}}$ | MODC | At the rising edge on $\overline{R E S E T}$, the state of this pin is registered into the MODC bit to set the mode. (This pin always has an internal pullup.) |
|  | BKGD | Pseudo-open-drain communication pin for the single-wire background debug mode. There is an internal pullup resistor on this pin. |
|  | TAGHI | When instruction tagging is on, a 0 at the falling edge of $E$ tags the high half of the instruction word being read into the instruction queue. |

### 12.4.6 Detecting Access Type from External Signals

The external signals $\overline{\mathrm{LSTRB}}, \mathrm{R} / \overline{\mathrm{W}}$, and AB0 indicate the type of bus access that is taking place. Accesses to the internal RAM module are the only type of access that would produce $\overline{\mathrm{LSTRB}}=\mathrm{AB} 0=1$, because the internal RAM is specifically designed to allow misaligned 16-bit accesses in a single cycle. In these cases
the data for the address that was accessed is on the low half of the data bus and the data for address +1 is on the high half of the data bus.

Table 12-5 Access Type vs. Bus Control Pins

| $\overline{\text { LSTRB }}$ | AB0 | $\mathbf{R} / \overline{\mathbf{W}}$ | Type of Access |
| :---: | :---: | :---: | :--- |
| 1 | 0 | 1 | 8-bit read of an even address |
| 0 | 1 | 1 | 8-bit read of an odd address |
| 1 | 0 | 0 | 8-bit write of an even address |
| 0 | 1 | 0 | 8-bit write of an odd address |
| 0 | 0 | 1 | 16-bit read of an even address |
| 1 | 1 | 1 | 16-bit read of an odd address <br> (low/high data swapped) |
| 0 | 0 | 0 | 16-bit write to an even address <br> 1 |
| 1 | 0 | 16-bit write to an odd address <br> (low/high data swapped) |  |

### 12.4.7 Stretched Bus Cycles

In order to allow fast internal bus cycles to coexist in a system with slower external memory resources, the HCS12 supports the concept of stretched bus cycles (module timing reference clocks for timers and baud rate generators are not affected by this stretching). Control bits in the MISC register in the MMC sub-block of the Core specify the amount of stretch ( $0,1,2$, or 3 periods of the internal bus-rate clock). While stretching, the CPU state machines are all held in their current state. At this point in the CPU bus cycle, write data would already be driven onto the data bus so the length of time write data is valid is extended in the case of a stretched bus cycle Read data would not be captured by the system until the E clock falling edge. In the case of a stretched bus cycle, read data is not required until the specified setup time before the falling edge of the stretched E clock. The external address, chip selects, and R/W signals remain valid during the period of stretching (throughout the stretched E high time)

### 12.4.8 Modes of Operation

The MEBI sub-block controls the mode of the Core operation through the use of the BKGD, MODB and MODA external system pins which are captured into the MODC, MODB and MODA controls bits, respectively, at the rising edge of the system $\overline{\text { RESET }}$ pin. The setup and hold times associated with these pins are given in Table 12-6 below.

Table 12-6 Mode Pin Setup and Hold Timing

| Characteristic | Timing |
| :---: | :---: |
| Mode programming setup time (time before reset is detected high that mode pins <br> must hold their state to guarantee the proper state is entered) | 2 bus clock <br> cycles |

Table 12-6 Mode Pin Setup and Hold Timing

| Characteristic | Timing |
| :---: | :---: |
| Mode programming hold (time after reset is detected high that mode pins must hold <br> their state to guarantee the proper state is entered) | 0 ns |

The four 8-bit Ports (A, B, E and K ) associated with the MEBI sub-block can serve as general purpose I/O pins or alternatively as the address, data and control signals for a multiplexed expansion bus. Address and data are multiplexed on Ports A and B. The control pin functions are dependent on the operating mode and the control registers PEAR and MODE. The initial state of bits in the PEAR and MODE registers are also established during reset to configure various aspects of the expansion bus. After the system is running, application software can access the PEAR and MODE registers to modify the expansion bus configuration.

Some aspects of Port E are not mode dependent. Bit 1 of Port E is a general purpose input or the $\overline{\mathrm{IRQ}}$ interrupt input. $\overline{\overline{I R Q}}$ can be enabled by bits in the CPU condition code register but it is inhibited at reset so this pin is initially configured as a simple input with a pullup. Bit-0 of Port E is a general purpose input or the $\overline{\text { XIRQ }}$ interrupt input. $\overline{\text { XIRQ }}$ also can be enabled by bits in the CPU condition code register but it is inhibited at reset so this pin is initially configured as a simple input with a pullup. The ESTR bit in the EBICTL register is set to one by reset in any user mode. This assures that the reset vector can be fetched even if it is located in an external slow memory device. The PE6/MODB/IPIPE1 and PE5/MODA/IPIPE0 pins act as high-impedance mode select inputs during reset.

The following subsections discuss the default bus setup and describe which aspects of the bus can be changed after reset on a per mode basis.

### 12.4.8.1 Special Single Chip Mode

When the system is reset in this mode, the background debug mode is enabled and "active". The system does not fetch the reset vector and execute application code as it would in other modes. Instead, the active background mode is in control of CPU execution and BDM firmware is waiting for additional serial commands through the BKGD pin. When a serial command instructs the system to return to normal execution, the system will be configured as described below unless the reset states of internal control registers have been changed through background commands after the system was reset.

There is no external expansion bus after reset in this mode. Ports A and B are initially simple bidirectional I/O pins that are configured as high-impedance inputs with internal pullups enabled; however, writing to the mode select bits in the MODE register (which is allowed in special modes) can change this after reset. All of the Port E pins (except PE4/ECLK) are initially configured as general purpose high-impedance inputs with pullups enabled. PE4/ECLK is configured as the E clock output in this mode.

The pins associated with Port E bits 6, 5, 3, and 2 cannot be configured for their alternate functions IPIPE1, IPIPE0, $\overline{\text { LSTRB }}$, and $\mathrm{R} / \overline{\mathrm{W}}$, respectively, while the system is in single chip modes. The associated control bits PIPOE, LSTRE and RDWE are reset to zero. Writing the opposite value into these bits in this mode does not change the operation of the associated Port E pins.

Port E, bit 4 can be configured for a free-running E clock output by clearing NECLK=0. Typically, the only use for an E clock output while the system is in single chip modes would be to get a constant speed clock for use in the external application system.

### 12.4.8.2 Emulation Expanded Narrow Mode

Expanded narrow modes are intended to allow connection of single 8-bit external memory devices for lower cost systems that do not need the performance of a full 16-bit external data bus. Accesses to internal resources that have been mapped external (i.e. PORTA, PORTB, DDRA, DDRB, PORTE, DDRE, PEAR, PUCR, RDRIV) will be accessed with a 16-bit data bus on Ports A and B. Accesses of 16-bit external words to addresses which are normally mapped external will be broken into two separate 8 -bit accesses using Port A as an 8-bit data bus. Internal operations continue to use full 16-bit data paths. They are only visible externally as 16 -bit information if IVIS $=1$.

Ports A and B are configured as multiplexed address and data output ports. During external accesses, address A15, data D15 and D7 are associated with PA7, address A0 is associated with PB0 and data D8 and D0 are associated with PA0. During internal visible accesses and accesses to internal resources that have been mapped external, address A15 and data D15 is associated with PA7 and address A0 and data D0 is associated with PB0.

The bus control related pins in Port E (PE7/NOACC, PE6/MODB/IPIPE1, PE5/MODA/IPIPE0, PE4/ECLK, PE3/ $\overline{\mathrm{LSTRB}} / \overline{\mathrm{TAGLO}}$, and PE2/R/ $\overline{\mathrm{W}}$ ) are all configured to serve their bus control output functions rather than general purpose I/O. Notice that writes to the bus control enable bits in the PEAR register in emulation mode are restricted.

The main difference between emulation modes and normal modes is that some of the bus control and system control signals cannot be written in emulation modes.

### 12.4.8.3 Peripheral Mode

This mode is intended for Motorola factory testing of the system. In this mode, the CPU is inactive and an external (tester) bus master drives address, data and bus control signals in through Ports A, B and E. In effect, the whole system acts as if it was a peripheral under control of an external CPU. This allows faster testing of on-chip memory and peripherals than previous testing methods. Since the mode control register is not accessible in peripheral mode, the only way to change to another mode is to reset the system into a different operating mode.

### 12.4.8.4 Emulation Expanded Wide Mode

In expanded wide modes, Ports A and B are configured as a 16-bit multiplexed address and data bus and Port E provides bus control and status signals. These signals allow external memory and peripheral devices to be interfaced to the system. These signals can also be used by a logic analyzer to monitor the progress of application programs.
The bus control related pins in Port E (PE7/NOACC, PE6/MODB/IPIPE1, PE5/MODA/IPIPE0, PE4/ECLK, PE3/ $\overline{\mathrm{LSTRB}} / \overline{\mathrm{TAGLO}}$, and PE2/R/W) are all configured to serve their bus control output functions rather than general purpose I/O. Notice that writes to the bus control enable bits in the PEAR register in emulation mode are restricted.

The main difference between emulation modes and normal modes is that some of the bus control and system control signals cannot be written in emulation modes.

### 12.4.8.5 Normal Single Chip Mode

There is no external expansion bus in this mode. All pins of Ports A, B and K are configured as general purpose I/O pins. Port E bits 1 and 0 are available as general purpose input only pins with internal pullups and the other remaining pins are bidirectional I/O pins that are initially configured as high-impedance inputs with internal pullups enabled.

The pins associated with Port E bits 6, 5, 3, and 2 cannot be configured for their alternate functions IPIPE1, IPIPE0, $\overline{\text { LSTRB }}$, and R/ $\overline{\mathrm{W}}$ while the system is in single chip modes. The associated control bits PIPOE, LSTRE, and RDWE, respectively, are reset to zero. Writing the opposite state into them in this mode does not change the operation of the associated Port E pins.

In normal single chip mode, the MODE register is writable one time. This allows a user program to change the bus mode to narrow or wide expanded mode and/or turn on visibility of internal accesses.

Port E, bit 4 can be configured for a free-running E clock output by clearing NECLK=0. Typically, the only use for an E clock output while the system is in single chip modes would be to get a constant speed clock for use in the external application system.

### 12.4.8.6 Normal Expanded Narrow Mode

This mode is used for lower cost production systems that use 8-bit wide external EPROMs or RAMs. Such systems take extra bus cycles to access 16 -bit locations but this may be preferred over the extra cost of additional external memory devices.

Ports A and B are configured as a 16-bit address bus and Port A is multiplexed with data. Internal visibility is not available in this mode because the internal cycles would need to be split into two 8 -bit cycles.

Since the PEAR register can only be written one time in this mode, use care to set all bits to the desired states during the single allowed write.

The PE3/ $\overline{\mathrm{LSTRB}}$ pin is always a general purpose I/O pin in normal expanded narrow mode. Although it is possible to write the LSTRE bit in PEAR to " 1 " in this mode, the state of LSTRE is overridden and Port E bit 3 cannot be reconfigured as the $\overline{\text { LSTRB }}$ output.

It is possible to enable the pipe status signals on Port E bits 6 and 5 by setting the PIPOE bit in PEAR, but it would be unusual to do so in this mode. $\overline{\text { LSTRB }}$ would also be needed to fully understand system activity. Development systems where pipe status signals are monitored would typically use special test mode or occasionally emulation expanded narrow mode.

The PE4/ECLK pin is initially configured as ECLK output with stretch. The E clock output function depends upon the settings of the NECLK bit in the PEAR register, the IVIS bit in the MODE register and the ESTR bit in the EBICTL register. In normal expanded narrow mode, the E clock is available for use in external select decode logic or as a constant speed clock for use in the external application system.
The PE $2 / \mathrm{R} / \overline{\mathrm{W}}$ pin is initially configured as a general purpose input with a pullup but this pin can be reconfigured as the $R / \overline{\mathrm{W}}$ bus control signal by writing " 1 " to the RDWE bit in PEAR. If the expanded narrow system includes external devices that can be written such as RAM, the RDWE bit would need to be set before any attempt to write to an external location. If there are no writable resources in the external system, PE2 can be left as a general purpose I/O pin.

### 12.4.8.7 Special Test Mode

In expanded wide modes, Ports A and B are configured as a 16-bit multiplexed address and data bus and Port E provides bus control and status signals. In special test mode, the write protection of many control bits is lifted so that they can be thoroughly tested without needing to go through reset.

### 12.4.8.8 Normal Expanded Wide Mode

In expanded wide modes, Ports A and B are configured as a 16-bit multiplexed address and data bus and Port E bit 4 is configured as the E clock output signal. These signals allow external memory and peripheral devices to be interfaced to the system.

Port E pins other than PE4/ECLK are configured as general purpose I/O pins (initially high-impedance inputs with internal pullup resistors enabled). Control bits PIPOE, NECLK, LSTRE, and RDWE in the PEAR register can be used to configure Port E pins to act as bus control outputs instead of general purpose I/O pins.

It is possible to enable the pipe status signals on Port E bits 6 and 5 by setting the PIPOE bit in PEAR, but it would be unusual to do so in this mode. Development systems where pipe status signals are monitored would typically use the emulation variation of this mode.

The Port E bit 2 pin can be reconfigured as the R/ $\overline{\mathrm{W}}$ bus control signal by writing " 1 " to the RDWE bit in PEAR. If the expanded system includes external devices that can be written, such as RAM, the RDWE bit would need to be set before any attempt to write to an external location. If there are no writable resources in the external system, PE2 can be left as a general purpose I/O pin.

The Port E bit 3 pin can be reconfigured as the $\overline{\text { LSTRB }}$ bus control signal by writing " 1 " to the LSTRE bit in PEAR. The default condition of this pin is a general purpose input because the $\overline{\text { LSTRB }}$ function is not needed in all expanded wide applications.

The Port E bit 4 pin is initially configured as ECLK output with stretch. The E clock output function depends upon the settings of the NECLK bit in the PEAR register, the IVIS bit in the MODE register and the ESTR bit in the EBICTL register. The E clock is available for use in external select decode logic or as a constant speed clock for use in the external application system.

### 12.4.9 Internal Visibility

Internal visibility is available when the system is operating in expanded wide modes, special test mode, or emulation narrow mode. It is not available in single-chip, peripheral or normal expanded narrow modes. Internal visibility is enabled by setting the IVIS bit in the MODE register.

If an internal access is made while $\mathrm{E}, \mathrm{R} / \overline{\mathrm{W}}$, and $\overline{\mathrm{LSTRB}}$ are configured as bus control outputs and internal visibility is off (IVIS=0), E will remain low for the cycle, R//W will remain high, and address, data and the $\overline{\text { LSTRB }}$ pins will remain at their previous state.

When internal visibility is enabled (IVIS=1), certain internal cycles will be blocked from going external to prevent possible corruption of external devices. Specifically, during cycles when the BDM is selected, $\mathrm{R} / \overline{\mathrm{W}}$ will remain high, data will maintain its previous state, and address and $\overline{\mathrm{LSTRB}}$ pins will be updated User Guide - S12CPU15UtGeqs.scale Semiconductor, Inc.
with the internal value. During CPU no access cycles when the BDM is not driving, $\mathrm{R} / \overline{\mathrm{W}}$ will remain high, and address, data and the $\overline{\mathrm{LSTRB}}$ pins will remain at their previous state.

### 12.4.10 Secure Mode

When the system is operating in a secure mode, internal visibility is not available (i.e. IVIS=1 has no effect). Also, the IPIPE signals will not be visible, regardless of operating mode. IPIPE1-IPIPE0 will display zeroes if they are enabled. In addition, the MOD bits in the MODE control register cannot be written.

### 12.5 Low-Power Options

The MEBI does not contain any user-controlled options for reducing power consumption. The operation of the MEBI in low-power modes is discussed in the following subsections.

### 12.5.1 Run Mode

The MEBI does not contain any options for reducing power in run mode; however, the external addresses are conditioned with expanded mode to reduce power in single chip modes.

### 12.5.2 Wait Mode

The MEBI does not contain any options for reducing power in wait mode.

### 12.5.3 Stop Mode

The MEBI will cease to function during execution of a CPU STOP instruction.

### 12.6 Motorola Internal Information

This subsection details information about the MEBI sub-block that is for Motorola use only and should not be published in any form outside of Motorola.

### 12.6.1 Peripheral Mode Operation

The only way to enter peripheral mode is via reset with the pins configured as shown in Table 12-7. The only way to exit peripheral mode is to change the mode pin configuration and pull reset. It is not possible to enter/exit peripheral mode by writing the MODx bits in the MODE register.

Table 12-7 Peripheral Mode Pin Configuration

| MODC (BKGD) | MODB (PE6) | MODA (PE5) |
| :---: | :---: | :---: |
| 1 | 1 | 0 |

Peripheral mode is a special mode immediately out of reset. It may be changed to a normal mode by writing the PNORME bit in the MTST1 register of the MMC sub-block to ' 1 '.

In peripheral mode, the direction of the address and data buses is reversed compared to other modes of operation. Address, $\mathrm{R} / \overline{\mathrm{W}}$ and SZ8 all come from the external test system and drive the bus interface pins of Ports A, B and E of the system. The data bus is configured to pass data directly through Ports A and B to the internal data bus. Accesses are all initiated by the external test system.

The burden of deciding which port to access for 8-bit data or swapped data is the responsibility of the external test system. The MEBI does not modify peripheral mode accesses in any way. Misaligned 16-bit accesses are not allowed to blocks that require two cycles to complete such as system peripherals. Misaligned 16-bit accesses are allowed to blocks that can handle fast transfers such as a RAM memory block.

### 12.6.2 Special Test Clock

When the peri_test_clk_enable signal at the Core interface is asserted in special modes, the peri_test_clk signal will be driven out on Port E , bit 6 when PIPOE $=0$.
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 13 Breakpoint (BKP)

This section describes the functionality of the Breakpoint (BKP) sub-block of the Core.

### 13.1 Overview

The Breakpoint sub-block of the Core provides for hardware breakpoints that are used to debug software on the CPU by comparing actual address and data values to predetermined data in setup registers. A successful comparison will place the CPU in Background Debug Mode or initiate a software interrupt (SWI).

The Breakpoint sub-block contains two modes of operation:

- Dual Address Mode, where a match on either of two addresses will cause the system to enter Background Debug Mode or initiate a Software Interrupt (SWI).
- Full Breakpoint Mode, where a match on address and data will cause the system to enter Background Debug Mode or initiate a Software Interrupt (SWI).

There are two types of breakpoints, forced and tagged. Forced breakpoints occur at the next instruction boundary if a match occurs and tagged breakpoints allow for breaking just before a specific instruction executes. Tagged breakpoints will only occur on addresses. Tagging on data is not allowed; however, if this occurs nothing will happen within the BKP.

The BKP allows breaking within a 256 byte address range and/or within expanded memory. It allows matching of the data as well as the address and to match 8-bit or 16-bit data. Forced breakpoints can match on a read or a write cycle.

### 13.1.1 Features

- Full or Dual Breakpoint Mode
- Compare on address and data (Full)
- Compare on either of two addresses (Dual)
- BDM or SWI Breakpoint
- Enter BDM on breakpoint (BDM)
- Execute SWI on breakpoint (SWI)
- Tagged or Forced Breakpoint
- Break just before a specific instruction will begin execution (TAG)
- Break on the first instruction boundary after a match occurs (Force)
- Single, Range or Page address compares
- Compare on address (Single)
- Compare on address 256 byte (Range)
: User Guide - S12CPU15ỨGefscale Semiconductor, Inc.
- Compare on any 16K Page (Page)
- Compare address on read or write on forced breakpoints
- High and/or low byte data compares


### 13.1.2 Block Diagram

A block diagram of the Breakpoint sub-block is shown in Figure 13-1 below. The Breakpoint contains three main sub-blocks: the Register Block, the Compare Block and the Control Block. The Register Block consists of the eight registers that make up the Breakpoint register space. The Compare Block performs all required address and data signal comparisons. The Control Block generates the signals for the CPU for the tag high, tag low, force SWI and force BDM functions. In addition, it generates the register read and write signals and the comparator block enable signals.

NOTE:There is a two cycle latency for address compares for forces, a two cycle latency for write data compares, and a three cycle latency for read data compares.


Figure 13-1 Breakpoint Block Diagram

### 13.2 Interface Signals

All interfacing with the Breakpoint sub-block is done within the Core.

### 13.3 Registers

A summary of the registers associated with the Breakpoint sub-block is shown in Figure 13-2 below. Detailed descriptions of the registers and bits are given in the subsections that follow.

| Address | Name |  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$0028 | BKPCT0 | read <br> write | BKEN | BKFULL | BKBDM | BKTAG | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$0029 | BKPCT1 | read write | BKOMBH | BKOMBL | BK1MBH | BK1MBL | BKORWE | BK0RW | BK1RWE | BK1RW |
| \$002A | BKP0X | read <br> write | 0 | 0 | BK0V5 | BKOV4 | BK0V3 | BK0V2 | BK0V1 | BKOVO |
|  |  |  |  |  |  |  |  |  |  |  |
| \$002B | BKPOH | read write | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 |
| \$002C | BKPOL | read <br> write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| \$002D | BKP1X | read <br> write | 0 | 0 | BK1V5 | BK1V4 | BK1V3 | BK1V2 | BK1V1 | BK1V0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$002E | BKP1H | read write | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 |
| \$002F | BKP1L | read <br> write | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|  |  |  |  | = Unimplemented |  | $X=$ Indeterminate |  |  |  |  |

Figure 13-2 Breakpoint Register Summary

### 13.3.1 Breakpoint Control Register 0 (ВКРCTO)

Read: anytime
Write: anytime


Figure 13-3 Breakpoint Control Register 0 (ВКРCTO)

This register is used to set the breakpoint modes.
BKEN - Breakpoint Enable
This bit enables the module
$0=$ Breakpoint module off
$1=$ Breakpoint module on
BKFULL - Full Breakpoint Mode Enable
This bit controls whether the breakpoint module is in Dual Mode or Full Mode
$0=$ Dual Address Mode enabled
1 = Full Breakpoint Mode enabled
BKBDM - Breakpoint Background Debug Mode Enable
This bit determines if the breakpoint causes the system to enter Background Debug Mode(BDM) or initiate a Software Interrupt (SWI)
$0=$ Go to Software Interrupt on a compare
$1=$ Go to BDM on a compare
BKTAG - Breakpoint on Tag
This bit controls whether the breakpoint will cause a break on the next instruction boundary (force) or on a match that will be an executable opcode (tagged). Non-executed opcodes cannot cause a tagged breakpoint
$0=$ On match, break at the next instruction boundary (force)
$1=$ On match, break if the match is an instruction that will be executed (tagged)

### 13.3.2 Breakpoint Control Register 1 (BKPCT1)

Read: anytime
Write: anytime


Figure 13-4 Breakpoint Control Register 1 (BKPCT1)

This register is used to configure the functionality of the Breakpoint sub-block within the Core.
BK0MBH:BK0MBL - Breakpoint Mask High Byte and Low Byte for First Address
In Dual or Full Mode, these bits may be used to mask (disable) the comparison of the high and low bytes of the first address breakpoint. The functionality is as given in Table 13-1 below

Table 13-1 Breakpoint Mask Bits for First Address

| BKOMBH:BKOMBL | Address Compare | BKPOX | BKPOH | BKPOL |
| :---: | :---: | :---: | :---: | :---: |
| $x: 0$ | Full Address Compare | Yes $^{1}$ | Yes | Yes |
| $0: 1$ | 256 byte Address Range | Yes $^{(1)}$ | Yes | No |
| $1: 1$ | $16 K$ byte Address Range | Yes $^{(1)}$ | No | No |

NOTES:

1. If page is selected.

The $\mathrm{x}: 0$ case is for a Full Address Compare. When a program page is selected, the full address compare will be based on bits for a 20-bit compare. The registers used for the compare are \{BKP0X[5:0], BKP0H[5:0],BKP0L[7:0]\}. When a program page is not selected, the full address compare will be based on bits for a 16-bit compare. The registers used for the compare are \{BKP0H[7:0],BKP0L[7:0]\}.
The 1:0 case is not sensible because it would ignore the high order address and compare the low order and expansion addresses. Logic forces this case to compare all address lines (effectively ignoring the BK0MBH control bit).
The 1:1 case is useful for triggering a breakpoint on any access to a particular expansion page. This only makes sense if a program page is being accessed so that the breakpoint trigger will occur only if BKPOX compares.

BK1MBH:BK1MBL - Breakpoint Mask High Byte and Low Byte of Data (Second Address)

In Dual Mode, these bits may be used to mask (disable) the comparison of the high and/or low bytes of the second address breakpoint. The functionality is as given in Table 13-2 below.

Table 13-2 Breakpoint Mask Bits for Second Address (Dual Mode)

| BK1MBH:BK1MBL | Address Compare | BKP1X | BKP1H | BKP1L |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{x}: 0$ | Full Address Compare | Yes $^{1}$ | Yes | Yes |
| $0: 1$ | 256 byte Address Range | Yes $^{(1)}$ | Yes | No |
| $1: 1$ | $16 \mathrm{~K}^{1}$ byte Address Range | Yes $^{(1)}$ | No | No |

NOTES:

1. If page is selected.

The $\mathrm{x}: 0$ case is for a Full Address Compare. When a program page is selected, the full address compare will be based on bits for a 20-bit compare. The registers used for the compare are \{BKP1X[5:0],BKP1H[5:0],BKP1L[7:0]\}. When a program page is not selected, the full address compare will be based on bits for a 16-bit compare. The registers used for the compare are \{BKP1H[7:0],BKP1L[7:0]\}.
The 1:0 case is not sensible because it would ignore the high order address and compare the low order and expansion addresses. Logic forces this case to compare all address lines (effectively ignoring the BK1MBH control bit).
The $1: 1$ case is useful for triggering a breakpoint on any access to a particular expansion page. This only makes sense if a program page is being accessed so that the breakpoint trigger will occur only if BKP1X compares.
In Full Mode, these bits may be used to mask (disable) the comparison of the high and/or low bytes of the data breakpoint. The functionality is as given in Table 13-3 below.

Table 13-3 Breakpoint Mask Bits for Data Breakpoints (Full Mode)

| BK1MBH:BK1MBL | Data Compare | BKP1X | BKP1H | BKP1L |
| :---: | :---: | :---: | :---: | :---: |
| $0: 0$ | High and Low Byte <br> Compare | No $^{1}$ | Yes | Yes |
| $0: 1$ | High Byte | No $^{(1)}$ | Yes | No |
| $1: 0$ | Low Byte | $\mathrm{No}^{(1)}$ | No | Yes |
| $1: 1$ | No Compare | $\mathrm{No}^{(1)}$ | No | No |

NOTES:

1. Expansion addresses for breakpoint 1 are not available in this mode.

BK0RWE - R/ $\overline{\mathrm{W}}$ Compare Enable User Guide - S12CPU15jtereps.scale Semiconductor, Inc.

Enables the comparison of the $\mathrm{R} / \overline{\mathrm{W}}$ signal for first address breakpoint. This bit is not useful in tagged breakpoints.
$0=\mathrm{R} / \overline{\mathrm{W}}$ is not used in the comparisons
$1=\mathrm{R} / \overline{\mathrm{W}}$ is used in comparisons
BK0RW - R/ $\overline{\mathrm{W}}$ Compare Value
When BK0RWE=1, this bit determines the type of bus cycle to match on first address breakpoint.
When BK0RWE=0, this bit has no effect.
$0=$ Write cycle will be matched
$1=$ Read cycle will be matched

## BK1RWE - R/ $\overline{\mathrm{W}}$ Compare Enable

In Dual Mode, this bit enables the comparison of the $\mathrm{R} / \overline{\mathrm{W}}$ signal to further specify what causes a match for the second address breakpoint. This bit is not useful on tagged breakpoints or in Full Mode and is therefore a don't care.
$0=\mathrm{R} / \overline{\mathrm{W}}$ is not used in comparisons
$1=\mathrm{R} / \overline{\mathrm{W}}$ is used in comparisons
BK1RW — R/ $\overline{\mathrm{W}}$ Compare Value
When BK1RWE=1, this bit determines the type of bus cycle to match on the second address breakpoint. When BK1RWE=0, this bit has no effect.
$0=$ Write cycle will be matched
$1=$ Read cycle will be matched

### 13.3.3 Breakpoint First Address Expansion Register (BKPOX)

Read: anytime
Write: anytime


Figure 13-5 Breakpoint First Address Expansion Register (BKPOX)

This register contains the data to be matched against expansion address lines for the first address breakpoint when a page is selected.

BK0V[5:0] - Value of first breakpoint address to be matched in memory expansion space.

### 13.3.4 Breakpoint First Address High Byte Register (BKPOH)

Read: anytime
Write: anytime


Figure 13-6 Breakpoint First Address High Byte Register (BKPOH)

This register is used to set the breakpoint when compared against the high byte of the address.
13.3.5 Breakpoint First Address Low Byte Register (BKPOL)

Read: anytime
Write: anytime

| Address | \$002C |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Read | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Write: |  |  |  |  |  |  |  |  |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Figure 13-7 Breakpoint First Address Low Byte Register (BKPOL)

This register is used to set the breakpoint when compared against the low byte of the address.

### 13.3.6 Breakpoint Second Address Expansion Register (BKP1X)

Read: anytime
Write: anytime

| Read: | it 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 0 | BK1V5 | BK1V4 | BK1V3 | BK1V2 | BK1V1 | BK1V0 |
| Write: |  |  |  |  |  |  |  |  |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  |  | or unim | mented |  |  |  |  |

Figure 13-8 Breakpoint Second Address Expansion Register (BKP1X)

In Dual Mode, this register contains the data to be matched against expansion address lines for the second address breakpoint when a page is selected. In Full Mode, this register is not used.

BK1V[5:0] - Value of first breakpoint address to be matched in memory expansion space.

### 13.3.7 Breakpoint Data (Second Address) High Byte Register (BKP1H)

Read: anytime
Write: anytime

| Address | \$002E |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Read |  |  |  |  |  |  |  |  |
| Write: |  |  |  |  |  |  |  |  |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Figure 13-9 Breakpoint Data High Byte Register (BKP1H)

In Dual Mode, this register is used to compare against the high order address lines. In Full Mode, this register is used to compare against the high order data lines.

### 13.3.8 Breakpoint Data (Second Address) Low Byte Register (BKP1L)

Read: anytime
Write: anytime


Figure 13-10 Breakpoint Data Low Byte Register (BKP1L)

In Dual Mode, this register is used to compare against the low order address lines. In Full Mode, this register is used to compare against the low order data lines.

### 13.4 Operation

The Breakpoint sub-block supports two modes of operation: Dual Address Mode and Full Breakpoint Mode. Within each of these modes, forced or tagged breakpoint types can be used. Forced breakpoints occur at the next instruction boundary if a match occurs and tagged breakpoints allow for breaking just before a specific instruction executes. The action taken upon a successful match can be to either place the CPU in Background Debug Mode or to initiate a software interrupt.

### 13.4.1 Modes of Operation

The Breakpoint can operate in Dual Address Mode or Full Breakpoint Mode. Each of these modes is discussed in the subsections below.

### 13.4.1.1 Dual Address Mode

When Dual Address Mode is enabled, two address breakpoints can be set. Each breakpoint can cause the system to enter Background Debug Mode or to initiate a software interrupt based upon the state of the BKBDM bit in the BKPCT0 Register being logic one or logic zero, respectively. BDM requests have a higher priority than SWI requests. No data breakpoints are allowed in this mode.

The BKTAG bit in the BKPCT0 register selects whether the breakpoint mode is force or tag. The BKxMBH:L bits in the BKPCT1 register select whether or not the breakpoint is matched exactly or is a range breakpoint. They also select whether the address is matched on the high byte, low byte, both bytes, and/or memory expansion. The BKxRW and BKxRWE bits in the BKPCT1 register select whether the type of bus cycle to match is a read, write, or both when performing forced breakpoints.

### 13.4.1.2 Full Breakpoint Mode

Full Breakpoint Mode requires a match on address and data for a breakpoint to occur. Upon a successful match, the system will enter Background Debug Mode or initiate a software interrupt based upon the state of the BKBDM bit in the BKPCT0 Register being logic one or logic zero, respectively. BDM requests have a higher priority than SWI requests. R/䲕 matches are also allowed in this mode.

User Guide - S12CPU15ƯGeq.2cale Semiconductor, Inc.

The BKTAG bit in the BKPCT0 register selects whether the breakpoint mode is forced or tagged. If the BKTAG bit is set in BKPCT0, then only address is matched, and data is ignored. The BK0MBH:L bits in the BKPCT1 register select whether or not the breakpoint is matched exactly, is a range breakpoint, or is in page space. The BK1MBH:L bits in the BKPCT1 register select whether the data is matched on the high byte, low byte, or both bytes. The BK0RW and BK0RWE bits in the BKPCT1 register select whether the type of bus cycle to match is a read or a write when performing forced breakpoints. BK1RW and BK1RWE bits in the BKPCT1 register are not used in Full Breakpoint Mode.

### 13.4.2 Breakpoint Priority

Breakpoint operation is first determined by the state of BDM . If BDM is already active, meaning the CPU is executing out of BDM firmware, Breakpoints are not allowed. In addition, while in BDM trace mode, tagging into BDM is not allowed. If BDM is not active, the Breakpoint will give priority to BDM requests over SWI requests. This condition applies to both forced and tagged breakpoints.

In all cases, BDM related breakpoints will have priority over those generated by the Breakpoint sub-block. This priority includes breakpoints enabled by the TAGLO and $\overline{\text { TAGHI external pins of the system that }}$ interface with the BDM directly and whose signal information passes through and is used by the Breakpoint sub-block.

> NOTE: BDM should not be entered from a breakpoint unless the ENABLE bit is set in the $B D M$. Even if the ENABLE bit in the BDM is negated, the CPU actually executes the BDM firmware code. It checks the ENABLE and returns if enable is not set. If the BDM is not serviced by the monitor then the breakpoint would be re-asserted when the BDM returns to normal CPU flow.

> There is no hardware to enforce restriction of breakpoint operation if the BDM is not enabled.

### 13.5 Motorola Internal Information

The Breakpoint sub-block does not contain any information that is considered to be for Motorola use only.

## Section 14 Background Debug Mode (BDM)

This section describes the functionality of the Background Debug Mode (BDM) sub-block of the Core.

### 14.1 Overview

The Background Debug Mode (BDM) sub-block is a single-wire, background debug system implemented in on-chip hardware for minimal CPU intervention. All interfacing with the BDM is done via the BKGD pin.

### 14.1.1 Features

- Single-wire communication with host development system
- Active out of reset in special single-chip mode
- Nine hardware commands using free cycles, if available, for minimal CPU intervention
- Hardware commands not requiring active BDM
- 15 firmware commands execute from the standard BDM firmware lookup table
- Instruction tagging capability
- Software control of BDM operation during wait mode
- Software selectable clocks
- BDM disabled when secure feature is enabled


### 14.1.2 Block Diagram

The block diagram of the BDM is shown in Figure 14-1 below.


Figure 14-1 BDM Block Diagram

### 14.2 Interface Signals

A single-wire interface pin is used to communicate with the BDM system. Two additional pins are used for instruction tagging. These pins are part of the Multiplexed External Bus Interface (MEBI) sub-block and all interfacing between the MEBI and BDM is done within the Core interface boundary. The functional descriptions of the pins are provided below for completeness.

- BKGD - Background interface pin
- $\overline{\text { TAGHI }}$ - High byte instruction tagging pin
- $\overline{\text { TAGLO }}$ - Low byte instruction tagging pin

BKGD and $\overline{\text { TAGHI }}$ share the same pin. $\overline{\text { TAGLO }}$ and $\overline{\text { LSTRB }}$ share the same pin.

### 14.2.1 Background Interface Pin (BKGD)

Debugging control logic communicates with external devices serially via the single-wire background interface pin (BKGD). During reset, this pin is a mode select input which selects between normal and special modes of operation. After reset, this pin becomes the dedicated serial interface pin for the background debug mode.

### 14.2.2 High Byte Instruction Tagging Pin (TAGHI)

This pin is used to tag the high byte of an instruction. When instruction tagging is on, a logic 0 at the falling edge of the external clock (ECLK) tags the high half of the instruction word being read into the instruction queue.

### 14.2.3 Low Byte Instruction Tagging Pin (TAGLO)

This pin is used to tag the low byte of an instruction. When instruction tagging is on and low strobe is enabled, a logic 0 at the falling edge of the external clock (ECLK) tags the low half of the instruction word being read into the instruction queue.

### 14.3 Registers

A summary of the registers associated with the BDM is shown in Figure 14-2 below. Registers are accessed by host-driven communications to the BDM hardware using READ_BD and WRITE_BD commands. Detailed descriptions of the registers and associated bits are given in the subsections that follow.


Figure 14-2 BDM Register Map Summary

### 14.3.1 BDM Status Register

Address: \$FF01


Figure 14-3 BDM Status Register (BDMSTS)
Read: All modes through BDM operation
Write: All modes but subject to the following:

- BDMACT can only be set by BDM hardware upon entry into BDM. It can only be cleared by the standard BDM firmware lookup table upon exit from BDM active mode.
- CLKSW can only be written via BDM hardware or standard BDM firmware write commands.
- All other bits, while writable via BDM hardware or standard BDM firmware write commands, should only be altered by the BDM hardware or standard firmware lookup table as part of BDM command execution.
- ENBDM should only be set via a BDM hardware command if the BDM firmware commands are needed. (This does not apply in Special Single Chip Mode).


## ENBDM - Enable BDM

This bit controls whether the BDM is enabled or disabled. When enabled, BDM can be made active to allow firmware commands to be executed. When disabled, BDM cannot be made active but BDM hardware commands are still allowed.
$1=$ BDM enabled
$0=\mathrm{BDM}$ disabled
NOTE: ENBDM is set by the firmware immediately out of reset in special single-chip mode. In secure mode, this bit will not be set by the firmware until after the EEPROM and FLASH erase verify tests are complete.

BDMACT - BDM active status

This bit becomes set upon entering BDM. The standard BDM firmware lookup table is then enabled and put into the memory map. BDMACT is cleared by a carefully timed store instruction in the standard BDM firmware as part of the exit sequence to return to user code and remove the BDM memory from the map.
$1=\mathrm{BDM}$ active
$0=\mathrm{BDM}$ not active
ENTAG - Tagging enable
This bit indicates whether instruction tagging in enabled or disabled. It is set when the TAGGO command is executed and cleared when BDM is entered. The serial system is disabled and the tag function enabled 16 cycles after this bit is written. BDM cannot process serial commands while tagging is active.
$1=$ Tagging enabled
$0=$ Tagging not enabled, or BDM active
SDV - Shift data valid
This bit is set and cleared by the BDM hardware. It is set after data has been transmitted as part of a firmware read command or after data has been received as part of a firmware write command. It is cleared when the next BDM command has been received or BDM is exited. SDV is used by the standard BDM firmware to control program flow execution.
$1=$ Data phase of command is complete
$0=$ Data phase of command not complete
TRACE - TRACE1 BDM firmware command is being executed
This bit gets set when a BDM TRACE1 firmware command is first recognized. It will stay set as long as continuous back-to-back TRACE1 commands are executed. This bit will get cleared when the next command that is not a TRACE1 command is recognized.
$1=$ TRACE1 command is being executed
$0=$ TRACE1 command is not being executed
CLKSW - Clock switch
The CLKSW bit controls which clock the BDM operates with. It is only writable from a hardware BDM command. A 150 cycle delay at the clock speed that is active during the data portion of the command will occur before the new clock source is guaranteed to be active. The start of the next BDM command uses the new clock for timing subsequent BDM communications.
$1=\mathrm{BDM}$ system operates with bus rate
$0=$ BDM system operates with alternate clock
WARNING:
The BDM will not operate with CLKSW $=0$ if the frequency of the alternate clock source, peri_phase_oscdX, is greater than one half of the bus frequency. Please refer to the users guide for the clock generation module to determine if this condition can occur.

UNSEC - Unsecure

## : User Guide - S12CPU15UGEe.scale Semiconductor, Inc.

This bit is only writable in special single chip mode from the BDM secure firmware and always gets reset to zero. It is in a zero state as secure mode is entered so that the secure BDM firmware lookup table is enabled and put into the memory map along with the standard BDM firmware lookup table.
The secure BDM firmware lookup table verifies that the on-chip EEPROM and Flash EEPROM are erased. This being the case, the UNSEC bit is set and the BDM program jumps to the start of the standard BDM firmware lookup table and the secure BDM firmware lookup table is turned off. If the erase test fails, the UNSEC bit will not be asserted.
$1=$ the system is in a unsecured mode
$0=$ the system is in a secured mode
WARNING:
When UNSEC is set, security is off and the user can change the state of the secure bits in the on-chip Flash EEPROM. Note that if the user does not change the state of the bits to "unsecured" mode, the system will be secured again when it is next taken out of reset.

### 14.3.2 BDM CCR Holding Register



Figure 14-4 BDM CCR Holding Register (BDMCCR)
Read: All modes
Write: All modes
NOTE: When BDM is made active, the CPU stores the value of the CCR register in the BDMCCR register. However, out of special single-chip reset, the BDMCCR is set to $\$ D 8$ and not $\$ D 0$ which is the reset value of the CCR register.

When entering background debug mode, the BDM CCR holding register is used to save the contents of the condition code register of the user's program. It is also used for temporary storage in the standard BDM firmware mode. The BDM CCR holding register can be written to modify the CCR value.

### 14.3.3 BDM Internal Register Position Register

Address: \$FF07

|  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read: | REG15 | REG14 | REG13 | REG12 | REG11 | 0 | 0 | 0 |
| Write: |  |  |  |  |  |  |  |  |
| Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Figure 14-5 BDM Internal Register Position (BDMINR)
Read: All modes
Write: Never
REG15-REG11 - Internal register map position
These five bits show the state of the upper five bits of the base address for the system's relocatable register block. BDMINR is a shadow of the INITRG register which maps the register block to any 2 K byte space within the first 32 K bytes of the 64 K byte address space.

### 14.4 Operation

The BDM receives and executes commands from a host via a single wire serial interface. There are two types of BDM commands, namely, hardware commands and firmware commands.

Hardware commands are used to read and write target system memory locations and to enter active background debug mode (see 14.4.3). Target system memory includes all memory that is accessible by the CPU.

Firmware commands are used to read and write CPU resources and to exit from active background debug mode (see 14.4.4). The CPU resources referred to are the accumulator (D), X index register ( X ), Y index register (Y), stack pointer (SP), and program counter (PC).

Hardware commands can be executed at any time and in any mode excluding a few exceptions as highlighted in $\mathbf{1 4 . 5}$ below. Firmware commands can only be executed when the system is in active background debug mode (BDM).

### 14.4.1 Security

If the user resets into special single chip mode with the system secured, a secured mode BDM firmware lookup table is brought into the map overlapping a portion of the standard BDM firmware lookup table. The secure BDM firmware verifies that the on-chip EEPROM and Flash EEPROM are erased. This being the case, the UNSEC bit will get set. The BDM program jumps to the start of the standard BDM firmware and the secured mode BDM firmware is turned off. If the EEPROM and FLASH do not verify as erased, the BDM firmware sets the ENBDM bit, without asserting UNSEC, and the firmware enters a loop. This User Guide - S12CPu 15 Eteqeqs.rale Semiconductor, Inc.
causes the BDM hardware commands to become enabled, but does not enable the software commands. This allows the BDM hardware to be used to erase the EEPROM and FLASH.

### 14.4.2 Enabling and Activating BDM

The system must be in active BDM to execute standard BDM firmware commands. BDM can be activated only after being enabled. BDM is enabled by setting the ENBDM bit in the BDM status (BDMSTS) register. The ENBDM bit is set by writing to the BDM status (BDMSTS) register, via the single-wire interface, using a hardware command such as WRITE_BD_BYTE.
After being enabled, BDM is activated by one of the following ${ }^{1}$ :

- Hardware BACKGROUND command
- BDM external instruction tagging mechanism
- CPU BGND instruction
- Breakpoint sub-block's force or tag mechanism ${ }^{2}$

When BDM is activated, the CPU finishes executing the current instruction and then begins executing the firmware in the standard BDM firmware lookup table. When BDM is activated by the breakpoint sub-block, the type of breakpoint used determines if BDM becomes active before or after execution of the next instruction.

NOTE: If an attempt is made to activate BDM before being enabled, the CPU resumes normal instruction execution after a brief delay. If BDM is not enabled, any hardware BACKGROUND commands issued are ignored by the BDM and the CPU is not delayed.

In active BDM, the BDM registers and standard BDM firmware lookup table are mapped to addresses $\$ F F 00$ to $\$$ FFFF. BDM registers are mapped to addresses $\$ F F 00$ to $\$ F F 07$. The BDM uses these registers which are readable anytime by the BDM. These registers are not, however, readable by user programs.

### 14.4.3 BDM Hardware Commands

Hardware commands are used to read and write target system memory locations and to enter active background debug mode. Target system memory includes all memory that is accessible by the CPU such as on-chip RAM, EEPROM, Flash EEPROM, I/O and control registers, and all external memory.

Hardware commands are executed with minimal or no CPU intervention and do not require the system to be in active BDM for execution, although, they can still be executed in this mode. When executing a hardware command, the BDM sub-block waits for a free CPU bus cycle so that the background access does not disturb the running application program. If a free cycle is not found within 128 clock cycles, the CPU is momentarily frozen so that the BDM can steal a cycle. When the BDM finds a free cycle, the operation does not intrude on normal CPU operation provided that it can be completed in a single cycle. However,

NOTES:

1. BDM is enabled and active immediately out of special single-chip reset (see 14.5.2).
2. This method is only available on systems that have a a Breakpoint sub-block.
if an operation requires multiple cycles, the CPU is frozen until the operation is complete, even though the BDM found a free cycle.

The BDM hardware commands are listed in Table 14-1.
Table 14-1 Hardware Commands

| Command | Opcode <br> (hex) | Data | Description |
| :--- | :---: | :---: | :--- |
| BACKGROUN | 90 | None | Enter background mode if firmware is enabled. |
| READ_BD_BYTE | E4 | 16 -bit address <br> 16 -bit data out | Read from memory with standard BDM firmware lookup table in map. <br> Odd address data on low byte; even address data on high byte |
| READ_BD_WORD | EC | 16 -bit address <br> 16 -bit data out | Read from memory with standard BDM firmware lookup table in map. <br> Must be aligned access. |
| READ_BYTE | E0 | 16 -bit address <br> 16 -bit data out | Read from memory with standard BDM firmware lookup table out of <br> map. Odd address data on low byte; even address data on high byte |
| READ_WORD | E8 | 16 -bit address <br> 16 -bit data out | Read from memory with standard BDM firmware lookup table out of <br> map. Must be aligned access. |
| WRITE_BD_BYTE | C4 | 16 -bit address <br> 16 -bit data in | Write to memory with standard BDM firmware lookup table in map. <br> Odd address data on low byte; even address data on high byte |
| WRITE_BD_WORD | CC | 16 -bit address <br> 16-bit data in | Write to memory with standard BDM firmware lookup table in map. <br> Must be aligned access |
| WRITE_BYTE | C0 | 16 -bit address <br> 16 -bit data in | Write to memory with standard BDM firmware lookup table out of <br> map. Odd address data on low byte; even address data on high byte |
| WRITE_WORD | C8 | 16-bit address <br> 16-bit data in | Write to memory with standard BDM firmware lookup table out of <br> map. Must be aligned access. |

The READ_BD and WRITE_BD commands allow access to the BDM register locations. These locations are not normally in the system memory map but share addresses with the application in memory. To distinguish between physical memory locations that share the same address, BDM memory resources are enabled just for the READ_BD and WRITE_BD access cycle. This allows the BDM to access BDM locations unobtrusively, even if the addresses conflict with the application memory map.

### 14.4.4 Standard BDM Firmware Commands

Firmware commands are used to access and manipulate CPU resources. The system must be in active BDM to execute standard BDM firmware commands (see 14.4.2). Normal instruction execution is suspended while the CPU executes the firmware located in the standard BDM firmware lookup table. The hardware command BACKGROUND is the usual way to activate BDM.

As the system enters active BDM, the standard BDM firmware lookup table and BDM registers become visible in the on-chip memory map at $\$ F F 00-\$ F F F F$, and the CPU begins executing the standard BDM User Guide - S12CPu15tuters.scale Semiconductor, Inc.
firmware. The standard BDM firmware watches for serial commands and executes them as they are received. The firmware commands are shown in Table 14-2.

Table 14-2 Firmware Commands

| Command | Opcode (hex) | Data | Description |
| :---: | :---: | :---: | :---: |
| READ_NEXT | 62 | 16-bit data out | Increment $X$ by $2(X=X+2)$, then read word $X$ points to. |
| READ_PC | 63 | 16-bit data out | Read program counter. |
| READ_D | 64 | 16-bit data out | Read D accumulator. |
| READ_X | 65 | 16-bit data out | Read X index register. |
| READ_Y | 66 | 16-bit data out | Read Y index register. |
| READ_SP | 67 | 16-bit data out | Read stack pointer. |
| WRITE_NEXT | 42 | 16-bit data in | Increment X by $2(\mathrm{X}=\mathrm{X}+2)$, then write word to location pointed to by X . |
| WRITE_PC | 43 | 16-bit data in | Write program counter. |
| WRITE_D | 44 | 16-bit data in | Write D accumulator. |
| WRITE_X | 45 | 16-bit data in | Write X index register. |
| WRITE_Y | 46 | 16-bit data in | Write Y index register. |
| WRITE_SP | 47 | 16-bit data in | Write stack pointer. |
| GO | 08 | none | Go to user program. |
| TRACE1 | 10 | none | Execute one user instruction then return to active BDM. |
| TAGGO | 18 | none | Enable tagging and go to user program. |

### 14.4.5 BDM Command Structure

Hardware and firmware BDM commands start with an 8-bit opcode followed by a 16 -bit address and/or a 16-bit data word depending on the command. All the read commands return 16 bits of data despite the byte or word implication in the command name.

NOTE: 8 -bit reads return 16-bits of data, of which, only one byte will contain valid data. If reading an even address, the valid data will appear in the MSB. If reading an odd address, the valid data will appear in the LSB.

NOTE: $\quad 16$-bit misaligned reads and writes are not allowed. If attempted, the BDM will ignore the least significant bit of the address and will assume an even address from the remaining bits.

For hardware data read commands, the external host must wait 150 target clock cycles ${ }^{1}$ after sending the address before attempting to obtain the read data. This is to be certain that valid data is available in the BDM shift register, ready to be shifted out. For hardware write commands, the external host must wait 150 target clock cycles after sending the data to be written before attempting to send a new command. This is to avoid disturbing the BDM shift register before the write has been completed. The 150 target clock cycle delay in both cases includes the maximum 128 cycle delay that can be incurred as the BDM waits for a free cycle before stealing a cycle.

For firmware read commands, the external host must wait 32 target clock cycles after sending the command opcode before attempting to obtain the read data. This allows enough time for the requested data to be made available in the BDM shift register, ready to be shifted out. For firmware write commands, the external host must wait 32 target clock cycles after sending the data to be written before attempting to send a new command. This is to avoid disturbing the BDM shift register before the write has been completed.

The external host should wait 64 target clock cycles after a TRACE1 or GO command before starting any new serial command. This is to allow the CPU to exit gracefully from the standard BDM firmware lookup table and resume execution of the user code. Disturbing the BDM shift register prematurely may adversely affect the exit from the standard BDM firmware lookup table.

Figure 14-6 represents the BDM command structure. The command blocks illustrate a series of eight bit times starting with a falling edge. The bar across the top of the blocks indicates that the BKGD line idles in the high state. The time for an 8 -bit command is $8 \times 16$ target clock cycles.


Figure 14-6 BDM Command Structure

NOTES:

1. Target clock cycles are cycles measured using the target system's serial clock rate. See 14.4.6 and 14.3.1 for information on how serial clock rate is selected.

### 14.4.6 BDM Serial Interface

The BDM communicates with external devices serially via the BKGD pin. During reset, this pin is a mode select input which selects between normal and special modes of operation. After reset, this pin becomes the dedicated serial interface pin for the BDM.

The BDM serial interface is timed using the clock selected by the CLKSW bit in the status register (see 14.3.1). This clock will be referred to as the target clock in the following explanation.

The BDM serial interface uses a clocking scheme in which the external host generates a falling edge on the BKGD pin to indicate the start of each bit time. This falling edge is sent for every bit whether data is transmitted or received. Data is transferred most significant bit (MSB) first at 16 target clock cycles per bit. The interface times out if 512 clock cycles occur between falling edges from the host.

The BKGD pin is a pseudo open-drain pin and has an weak on-chip active pull-up that is enabled at all times. It is assumed that there is an external pullup and that drivers connected to BKGD do not typically drive the high level. Since R-C rise time could be unacceptably long, the target system and host provide brief driven-high (speedup) pulses to drive BKGD to a logic 1. The source of this speedup pulse is the host for transmit cases and the target for receive cases.

The timing for host-to-target is shown in Figure 14-7 and that of target-to-host in Figure 14-8 and Figure 14-9 below. All four cases begin when the host drives the BKGD pin low to generate a falling edge. Since the host and target are operating from separate clocks, it can take the target system up to one full clock cycle to recognize this edge. The target measures delays from this perceived start of the bit time while the host measures delays from the point it actually drove BKGD low to start the bit up to one target clock cycle earlier. Synchronization between the host and target is established in this manner at the start of every bit time.

Figure 14-7 shows an external host transmitting a logic 1 and transmitting a logic 0 to the BKGD pin of a target system. The host is asynchronous to the target, so there is up to a one clock-cycle delay from the host-generated falling edge to where the target recognizes this edge as the beginning of the bit time. Ten target clock cycles later, the target senses the bit level on the BKGD pin. Internal glitch detect logic requires the pin be driven high no later that eight target clock cycles after the falling edge for a logic 1 transmission.

Since the host drives the high speedup pulses in these two cases, the rising edges look like digitally driven signals.


Figure 14-7 BDM Host-to-Target Serial Bit Timing

The receive cases are more complicated. Figure $\mathbf{1 4 - 8}$ shows the host receiving a logic 1 from the target system. Since the host is asynchronous to the target, there is up to one clock-cycle delay from the host-generated falling edge on BKGD to the perceived start of the bit time in the target. The host holds the BKGD pin low long enough for the target to recognize it (at least two target clock cycles). The host must release the low drive before the target drives a brief high speedup pulse seven target clock cycles after the perceived start of the bit time. The host should sample the bit level about 10 target clock cycles after it started the bit time.


Figure 14-8 BDM Target-to-Host Serial Bit Timing (Logic 1)

User Guide - S12CPu Fitueprscale Semiconductor, Inc.

Figure 14-9 shows the host receiving a logic 0 from the target. Since the host is asynchronous to the target, there is up to a one clock-cycle delay from the host-generated falling edge on BKGD to the start of the bit time as perceived by the target. The host initiates the bit time but the target finishes it. Since the target wants the host to receive a logic 0 , it drives the BKGD pin low for 13 target clock cycles then briefly drives it high to speed up the rising edge. The host samples the bit level about 10 target clock cycles after starting the bit time.


Figure 14-9 BDM Target-to-Host Serial Bit Timing (Logic 0)

### 14.4.7 Instruction Tracing

When a TRACE1 command is issued to the BDM in active BDM, the CPU exits the standard BDM firmware and executes a single instruction in the user code. Once this has occurred, the CPU is forced to return to the standard BDM firmware and the BDM is active and ready to receive a new command. If the TRACE1 command is issued again, the next user instruction will be executed. This facilitates stepping or tracing through the user code one instruction at a time.

If an interrupt is pending when a TRACE1 command is issued, the interrupt stacking operation occurs but no user instruction is executed. Once back in standard BDM firmware execution, the program counter points to the first instruction in the interrupt service routine.

### 14.4.8 Instruction Tagging

The instruction queue and cycle-by-cycle CPU activity are reconstructible in real time or from trace history that is captured by a logic analyzer. However, the reconstructed queue cannot be used to stop the CPU at a specific instruction, because execution already has begun by the time an operation is visible outside the system. A separate instruction tagging mechanism is provided for this purpose.

The tag follows program information as it advances through the instruction queue. When a tagged instruction reaches the head of the queue, the CPU enters active BDM rather than executing the instruction.

NOTE: Tagging is disabled when BDM becomes active and BDM serial commands are not processed while tagging is active.

Executing the BDM TAGGO command configures two system pins for tagging. The TAGLO signal shares a pin with the $\overline{\mathrm{LSTRB}}$ signal, and the $\overline{\text { TAGHI }}$ signal shares a pin with the BKGD signal.

Table $\mathbf{1 4 - 3}$ shows the functions of the two tagging pins. The pins operate independently, that is, the state of one pin does not affect the function of the other. The presence of logic level 0 on either pin at the fall of the external clock (ECLK) performs the indicated function. High tagging is allowed in all modes. Low tagging is allowed only when low strobe is enabled (LSTRB is allowed only in wide expanded modes and emulation expanded narrow mode).

Table 14-3 Tag Pin Function

| TAGHI | TAGLO | Tag |
| :---: | :---: | :---: |
| 1 | 1 | No tag |
| 1 | 0 | Low byte |
| 0 | 1 | High byte |
| 0 | 0 | Both bytes |

### 14.5 Modes of Operation

BDM is available in all operating modes but must be enabled before firmware commands are executed.
Some system peripherals may have a control bit which allows suspending the peripheral function during background debug mode.

In special single-chip mode, background operation is enabled and active out of reset. This allows programming a system with blank memory.

BDM is also active out of special peripheral mode reset and can be turned off by clearing the BDMACT bit in the BDM status (BDMSTS) register. This allows testing of the BDM memory space as well as the user's memory space.

NOTE: The BDM serial system should not be used in special peripheral mode since the CPU, which in other modes interfaces with the BDM to relinquish control of the bus during a free cycle or a steal operation, is not operating in this mode.

### 14.5.1 Normal Operation

BDM operates the same in all normal modes.

### 14.5.2 Special Operation

### 14.5.2.1 Special single-chip mode

BDM is enabled and active immediately out of reset. This allows programming a system with blank memory.

### 14.5.2.2 Special peripheral mode

BDM is enabled and active immediately out of reset. BDM can be disabled by clearing the BDMACT bit in the BDM status (BDMSTS) register. The BDM serial system should not be used in special peripheral mode.

### 14.5.3 Emulation Modes

In emulation modes, the BDM operates as in all normal modes.

### 14.6 Low-Power Options

### 14.6.1 Run Mode

The BDM does not include disable controls that would conserve power during run mode.

### 14.6.2 Wait Mode

The BDM cannot be used in wait mode if the system disables the clocks to the BDM.

### 14.6.3 Stop Mode

The BDM is completely shutdown in stop mode.

### 14.7 Interrupt Operation

The BDM does not generate interrupt requests.

### 14.8 Motorola Internal Information

This subsection details information about the BDM sub-block that is for Motorola use only and should not be published in any form outside of Motorola.

### 14.8.1 Registers

This section gives detailed descriptions of all internally accessible registers and bits that are either not available or not disclosed to users external to Motorola. These registers were highlighted as being reserved BDM registers previously in this section of the guide.

The BDM instruction (BDMIST) register is written by the BDM hardware as a result of a BDM command sent to the system via the BKGD pin. The individual bits decode into categories of BDM instruction. The two descriptions of the BDMIST below show the instruction decode when categorized as hardware or firmware instructions.

All of the BDM registers are readable and writable in special peripheral mode on the parallel bus until the BDMACT bit in the BDMSTS register is cleared at which time the BDM resources are no longer accessible via the peripheral bus and require a reset to be restored.

A full summary of the registers associated with the BDM is shown in Figure 14-10 below.

| Address | Name |  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$FF00 | BDMIST | read write | H/F | DATA | R/W | BKGND | W/B | BD/U | 0 | 0 |
|  |  |  |  |  |  |  |  |  |  |  |
| \$FF01 | BDMSTS | read write | ENBDM | BDMACT | ENTAG | SDV | TRACE | CLKSW | UNSEC | 0 |
| \$FF02 | BDMSHTH | read <br> write | S15 | S14 | S13 | S12 | S11 | S10 | S9 | S8 |
| \$FF03 | BDMSHTL | read write | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 |
| \$FF04 | BDMADDH | read write | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |
| \$FF05 | BDMADDL | read write | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |
| \$FF06 | BDMCCR | read write | CCR7 | CCR6 | CCR5 | CCR4 | CCR3 | CCR2 | CCR1 | CCRO |
| \$FF07 | BDMINR | read | REG15 | REG14 | REG13 | REG12 | REG11 | 0 | 0 | 0 |
|  |  | write |  |  |  |  |  |  |  |  |

Figure 14-10 BDM Register Map

### 14.8.2 BDM Instruction Register (Hardware)

Address: \$FF00


Figure 14-11 BDM Instruction Register (BDMIST)
Read: All modes
Write: All modes; BDM hardware writes this register when a BDM command is received.
Hardware clears the register if 512 BDM clock cycles occur between falling edges from the host. Firmware clears this register when exiting from BDM active mode.

H/F - Hardware/firmware flag
When the BDM is active, standard BDM firmware checks for this bit to be set by the BDM hardware as part of a BDM instruction load.
$1=$ Hardware command
$0=$ Firmware command
DATA - Data flag
Shows that data accompanies the command.
1 = Data follows the command
$0=$ No data
R/W - Read/write flag
$1=$ Read
$0=$ Write
BKGND - Enter active background mode
$1=$ Hardware background command
$0=$ Not a hardware background command
W/B - Word/byte transfer flag
$1=$ Word transfer
$0=$ Byte transfer
BD/U - BDM map/user map flag
Indicates whether BDM access is to BDM registers and standard BDM firmware lookup table mapped to addresses $\$$ FF00 to $\$$ FFFF or the user resources in this range. Used only by hardware read/write commands.
$1=$ standard BDM firmware lookup table and registers in map
$0=$ User resources in map.

### 14.8.3 BDM Instruction Register (Firmware)

Address: \$FF00


Figure 14-12 BDM Instruction Register (BDMIST)
Read: All modes
Write: All modes; BDM hardware writes this register when a BDM command is received.
Hardware clears the register if 512 BDM clock cycles occur between falling edges from the host. Firmware clears this register when exiting from BDM active mode.

H/F - Hardware/firmware flag
When the BDM is active, standard BDM firmware checks for this bit to be set by the BDM hardware as part of a BDM instruction load.

1 = Hardware command
$0=$ Firmware command
DATA - Data flag
This bit indicates that data accompanies the command.
1 = Data follows the command
$0=$ No data
R/W - Read/write flag
1 = Read
$0=$ Write
TTAGO - Trace, tag, go bits.
The decoding of TTAGO is shown in Table 14-4 below.
Table 14-4 TTAGO Decoding

| TTAGO value | Instruction |
| :---: | :---: |
| 00 | - |
| 01 | GO |
| 10 | TRACE1 |
| 11 | TAGGO |

RNEXT - Register/next bits

Indicates which register is being affected by a command. In the case of a READ_NEXT or WRITE_NEXT command, index register X is pre-incremented by 2 and the word pointed to by X is then read or written. The decoding of RNEXT is shown in Table 14-5 below.

Table 14-5 RNEXT Decoding

| RNEXT value | Instruction |
| :---: | :---: |
| 000 | - |
| 001 | - |
| 010 | READ/WRITE NEXT |
| 011 | PC |
| 100 | D |
| 101 | X |
| 110 | Y |
| 111 | SP |

### 14.8.4 BDM Status Register

The BDM status (BDMSTS) register is described in 14.3.1. In addition, it is readable and writable in special peripheral mode on the parallel bus.

BDMACT - BDM active status
BDMACT is set by the BDM and is cleared in the exit sequence of the standard BDM firmware.
BDMACT can be written to in special peripheral mode via the peripheral bus. It cannot be written to via BDM hardware commands in any mode, that is, it cannot be written to if the H/F bit in the BDMIST register is set.

Clearing BDMACT causes the standard BDM firmware lookup table and registers to be removed from the memory map and BDM to become inactive.

Setting BDMACT in special peripheral mode via the peripheral bus causes BDM to become active but does not put the standard BDM firmware lookup table and registers into the memory map; therefore, BDMACT should not be set in this manner but should instead be set by resetting the system.

### 14.8.5 BDM Shift Register

Address: \$FF02

|  | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write: | S15 | S14 | S13 | S12 | S11 | S10 | S9 | S8 |

Reset:
Figure 14-13 BDM Shift Register (BDMSHTH)
Address: \$FF03

| Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |  |
| ---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read: |  |  |  |  |  |  |  |  |
| Write: | S7 | S 6 | S 5 | S 4 | S 3 | S 2 | S 1 | S 0 |

Reset:
Figure 14-14 BDM Shift Register (BDMSHTL)
Read: All modes
Write: All modes
The 16-bit BDM shift register contains data being received or transmitted via the serial interface. It is also used by the standard BDM firmware for temporary storage.

### 14.8.6 BDM Address Register

Address: \$FF04

| Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 |
| ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read: | A15 | A14 | A13 | A12 | A11 | A10 | A9 |
| Write: | A8 |  |  |  |  |  |  |

Reset:
Figure 14-15 BDM Address Register (BDMADDH)
Address: \$FF05

| Bit 7 |
| :--- |
| Read: |
| Write: | |  | A7 | A6 | A5 | A4 | A3 | A2 | A1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Reset:
Figure 14-16 BDM Address Register (BDMADDL)
Read: All modes
Write: Can only be written by BDM hardware
In secure mode, if the BDM hardware commands have been enabled by the secure firmware, the upper 5 bits of the address register will always be forced to the value from the BDMINR register. This restricts access of the hardware commands to the register space only.

The 16-bit address register is loaded with the address to be accessed by BDM hardware commands.

### 14.8.7 Special Peripheral Mode

In Special Peripheral Mode the BDM is enabled and active immediately out of reset. BDM can be disabled by clearing the BDMACT bit in the BDM status (BDMSTS) register (see 14.8.4). This allows testing the BDM memory space as well as the user's program memory space. The BDM serial system should not be used in special peripheral mode since the CPU, which in other modes relinquishes control of the bus during a free cycle or a steal operation, is not operating in this mode.

### 14.8.8 Standard BDM Firmware Listing

```
;**************************************************************************************
; Copyright (C) }1997\mathrm{ by Motorola Inc.
                        6 5 0 1 \text { William Cannon Drive West}
                        Advanced MCU HC11 Group
    Austin, TX 78735-8598
; All rights reserved. No part of this software may be sold or distributed
```

```
; in any form or by any means without the prior written permission of
; Motorola, Inc.
;
;
;
;*******************************************************************************
;===================================================================================
;
;
; Started from UDR HC12 BDM ROM code
;
;
; Design Strategy:
;
;

\section*{:User Guide - S12CPU15Uteqes.2cale Semiconductor, Inc.}
```

;
;
;
;
;
;
;
;
;
;

```

```

; mem
; revw
; stop
; tbl
; wai
; execution of BDM ROM

* EQUATES
BDMVEC equ\$fff6 ;First BDM ROM vector.
org\$ff00 ; Start of BDM map (registers)
ffor INSTR rmb1 ; Instruction (command) register
* $\mathrm{s} / \mathrm{w}$ ! H/S ! DATA ! R/W ! TTAG : GO ! R2 ! R1 ! R0 !
* hdw ! H/S ! DATA ! R/W !BKGND : W/B ! BD/USR! NEXT ! - !
* Reg codes: R2:R1:R0
* 0:0:0 - Illegal, command $\$ 00$ is null command
* 0:0:1 - not used
* 0:1:0 - Next Word 2, +X pre inc $X$ by 2 and $r / w$ next word (, X)
* later $r / w$ next will work from ADDRESS reg value not $X$
* 0:1:1 - PC
* 1:0:0-D
* 1:0:1 - X
* 1:1:0 - Y
* 1:1:1 - SP
* TTAG:GO coding:
* 0:0 - No execution command
* 0:1 - Go to user program
* 1:0 - Trace one user instruction and return to BDM

```
\begin{tabular}{|c|c|}
\hline & * 1:1 - Tag Go command (reconfigure BKGD pin for tagging in) \\
\hline \multirow[t]{7}{*}{ff01} & STATUS rmb1 ; Status/Control register \\
\hline & * ! enBDM!BDACTV! TAG ! VALID: TRACE! - ! - ! \\
\hline & * Exit conditions vs value written to STATUS on exit \\
\hline & * BDM not allowed - \$00 \\
\hline & * Trace 1 - \$88 \\
\hline & * Go - \$80 \\
\hline & * Tag Go - \$A0 \\
\hline ff02 & SHIFTER rmb2 ;For serial data in/out \\
\hline \multirow[t]{2}{*}{ff04} & ADDRESS \(\quad\) rmb2 ; Address for some commands \\
\hline & \begin{tabular}{l}
* ADDRESS will be read-only on first parts but later it will \\
* be r/w so r/w next word doesn't need to use \(X\)
\end{tabular} \\
\hline \multirow[t]{2}{*}{ff06} & CCRSAVE rmb1 ; Save user CCR value while in BDM \\
\hline & \begin{tabular}{l}
* CCRSAVE also used briefly to hold exit value for status \\
* during exit sequence to return to user code
\end{tabular} \\
\hline
\end{tabular}
```

```
ff20
```

```
```

```
ff20
```

```
AFTER_RST


ff20 1c ff 0180








START
    ;*****CAUTION 2. \(\quad * * * * *\) CAUTION 9.
exgt3 d ; Save D without affecting CCR.
    ; This "exg t3 d" instruction MUST
    ; occur before the following
    ;"tfr ccr a" instruction.
    ;*****CAUTION 3.
tfrccr a
staaCCRSAVE; Save user CCR value
exgx t2 ;pc into \(x . \quad * * * * * C A U T I O N 4\).
cpx\#\$FFOO ; Check to see if user PC overlaps BDM
    ; ROM.
bhsROM_INC;If so, increment regardless.
tst0,x ;Test next opcode. This instruction
    ; affects CCR so it MUST occur AFTER
    ; saving the user's CCR.
ff34 2601
ff36 08 ROM_INC
RES_X_T2
ff41 79 ff 00
ff26 b7 20
ff28 7a ff 06
ff2b b7 d3
ff2d 8e ff 00
ff30 2404
ff32 e7 00
ff01
ff24 b7 b4
```

```
ff37 b7 d3
```

```
ff37 b7 d3
ff39 le ff 01 80 06
ff39 le ff 01 80 06
ff3e 87
ff3e 87
ff3f 20 1c
```

```
ff3f 20 1c
```

```
        STATUS rmb1 ; Status/Control register
    * ! enBDM!BDACTV! TAG ! VALID: TRACE! - ! - ! - !
    * Exit conditions vs value written to STATUS on exit
    * BDM not allowed - \$00
    * Trace 1 - \(\$ 88\)
* Go - \$80
* Tag Go - \$A0
SHIFTER \(\quad\) rmb2 For serial data in/out
    ADDRESS rmb2 ;Address for some commands
    * ADDRESS will be read-only on first parts but later it will
    * be r/w so r/w next word doesn't need to use \(X\)
    * CCRSAVE also used briefly to hold exit value for status
    * during exit sequence to return to user code
bneRES_X_T2;if not \(\$ 00\), restore
inx ;else inc, then restore. This
    ;instruction affects CCR so it MUST
    ; occur AFTER saving the user's CCR.
exgx t2 ;restore pc to temp 2
brsetSTATUS \(\$ 80\) INST_LOOP ; Check if BDM allowed
clra ;Exit if BDM not allowed
braEXIT_SEQ
* Above is 1 of 4 ways to exit BDM to user code.

INST_DONE
```

clrINSTR ;clear INSTR then wait for new inst

```
        * 1:1 - Tag Go command (reconfigure BKGD pin for tagging in)

\section*{User Guide - S12CPU15VGeesscale Semiconductor, Inc.}


NOT_EXE
```

ff7b b7 01
ff7d 84 07
ff7f 80 02
ff81 2b be
ff83 c5 20
ff85 26 37

```
```

tfra b ;Duplicate command in B
anda\#\$07 ;Strip all but 3-bit reg code
suba\#2 ;codes 0 \& 1 illegal or unused
bmiINST_DONE;branch if A now negative
bitb\#\$20 ;Check R/W bit
bne;COMP_GOTO;Go decode read command (was beq
;tp 3/30)

```

WAIT_DATA
```

ff87 f7 ff 00
ff8a 27 b8
ff8c 1f ff 01 10 f6
ff91 c6 07
ff93 12
ff94 05 fd

```
ff96 fc ff 02
ff99 6c 21
ff9b 20 a4 braINST_DONE; Intermediate branch to loop top
ff9d fc ff 02
ffa0 b7 c3
ffa2 20 9d
ffa4 fc ff 02
ffa7 b7 b4
ffag 2096
ffab fe ff 02
ffae 2091
ffb0 a7
ffb1 a7
ffb2 fd ff 02
ffb5 20 8a
ffb7 a7
ffb8 a7
WRITE_Y
WRITE_X
* Each write command corresponding to reg code 2-7 takes
* exactly 7 bytes. For command 2 (write next word) the jump will
* GOTO \(0, \mathrm{pc}\) or the location immediately after the jump
* For command 7 (write SP) the jump will go to (5*7), pc
* Each command ends with a branch to the main command loop
W_NXT_WRD
lddSHIFTER; Get data to write
std2, +x ;pre-inc x by 2 and store word
INST_DONE1
WRITE_PC
```

tstINSTR ; Check for new command
beqINST_LOOP;Need escape if old command aborted
brclrSTATUS \$10 WAIT_DATA ;Wait for data ready
ldab\#7
mul ; B = 7*(reg_code - 1)
jmpb,pc ;Calculated GOTO

```
* Each write command corresponding to reg code 2-7 takes
* exactly 7 bytes. For command 2 (write next word) the jump will
* GOTO 0,pc or the location immediately after the jump
* For command 7 (write SP) the jump will go to (5*7), pc
* Each command ends with a branch to the main command loop W_NXT_WRD
lddSHIFTER; Get data to write
std2, \(+x\) pre-inc \(x\) by 2 and store word
braINST_DONE; Intermediate branch to loop top
WRITE_PC
lddSHIFTER; Get data to write
exgd t2 ;User PC in Temp2 reg
braINST_DONE;Branch to loop top
WRITE_D
braINST_DONE;Branch to loop top
```

```
lddSHIFTER;Get data to write
```

lddSHIFTER;Get data to write
exgt3 d ;User D in Temp3 reg (was exg d t2
exgt3 d ;User D in Temp3 reg (was exg d t2
;tp 3/28)
;tp 3/28)
braINST_DONE;Branch to loop top

```
braINST_DONE;Branch to loop top
```

WRITE_X

```
ldxSHIFTER;Update X register
braINST_DONE;Branch to loop top
nop ;Pad to make command take 7 bytes
nop
ldySHIFTER; Update Y register
braINST_DONE;Branch to loop top
nop \(\quad\);Pad to make command take 7 bytes
nop
```

WRITE_SP
ffb9 ff ff 02
ffbc 2083
ffbe 48
ffbe 48
ffco 05 fc

## : User Guide - S12CPU15UGEe.scale Semiconductor, Inc.



```
fffa ff 24 COPV fdbSTART ;COP watchdog error vector
fffc ff 24 CMONV fdbSTART ;Clock monitor error vector
fffe ff 20 RESETV
    fdbAFTER_RST;Reset vector (Sgl chip special)
;*********** end **************************************************************
```


### 14.8.9 Secured Mode BDM Firmware Listing



```
File: secure_firm.s
Target: HCS12 Version 1.5
; Author: John_Langan-RMAG10@email.sps.mot.com
; Creation date: June 28, 1999
; Comments: This code is contained in the secure ROM
    of the BDM.
                                    VERSION HISTORY
Ver 000 John Langan orig July 02, 1999
; update bug found by Lloyd, EERPOM size
                                spec changes Aug. 27, 1999
    Ver 001George Grimmer 26 July 2000
    Enable BDM hardware commands when NVM erase verify fails,
    BDM commands will remain disabled if Flash security bits = 01
```

    ; Design Strategy:
    ; This code determines if the FLASH and EEPROM are erased
    ; If they are both erased, the program releases security,
    ; else it hangs (branches to self).
    Equates here
    
## User Guide - S12CPU15ƯGêscale Semiconductor, Inc.

; Code starts here.


: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Section 15 Secured Mode of Operation

This section provides a brief description of the secured mode of operation of the Core. Detailed information relating to integration issues is provided in the HCS12 V1.5 Core Integration Guide.

### 15.1 Overview

The implementation of the secured mode of operation for the Core provides for protecting the contents of internal (on-chip) memory arrays. While in secured mode the system can execute in single-chip mode or from an external memory block but the contents of the internal memory will not be accessible and all normal BDM functions will be blocked from execution. A mechanism is provided to release the system from the secured mode at which time normal operation will resume allowing the system to be reconfigured for unsecured mode.

### 15.1.1 Features

The secured mode of operation provides:

- Protection of internal (on-chip) Flash EEPROM contents
- Protection of internal (on-chip) EEPROM contents
- Operation in single-chip mode while secured
- Operation from external memory with internal Flash and EEPROM disabled while secured


### 15.1.2 Block Diagram

A block diagram of the Core security implementation is given in Figure 15-1.


Figure 15-1 Security Implementation Block Diagram

This figure includes one example system implementation of the Core security feature. In this implementation, the Flash EEPROM block contains a security register that is programmed to the proper secured/un-secured state which generates a security request to the Core. See $\mathbf{1 5 . 4}$ for a complete description of the operation of the secured mode.

### 15.2 Interface Signals

The Core interface signals associated with the secured mode of operation are shown in Table 15-1 below. The functional descriptions of the signals are provided below for completeness.

Table 15-1 Security Interface Signal Definitions

| Signal Name | Type | Functional Description |
| :--- | :---: | :--- |
| core_secure_t2 | O | Core secure mode signal |
| secreq | I | Security mode request from applicable memory |

### 15.2.0.1 Core Secure Mode indicator (core_secure_t2)

This single bit Core output indicates that the Core is operating in secured mode.

### 15.2.0.2 Core Security Request (secreq)

This single bit input indicates to the Core that the system memory is in a secured state and that the Core should operate in secured mode.

### 15.3 Registers

There are no registers in the Core associated with the secured mode of operation. Typically, a non-volatile memory block in the system will contain a register for programming the state of system security. Please refer to the chip-level and/or memory block documentation for implementation details.

### 15.4 Operation

When the system is configured for secured mode of operation, it will normally operate in either normal single-chip mode or in an expanded mode executing from external memory. The conditions imposed by secured mode for each of these operating modes is discussed in the subsections that follow as well as a description of the method to unsecure the system.

### 15.4.1 Normal Single-Chip Mode

Normal single-chip mode will be the most common operation of a system configured for secured mode. The system functionality will appear just as an unsecured system with the exception imposed that the BDM operation will not be allowed and will be blocked. This will prevent any access to the internal non-volatile memory block contents.

### 15.4.2 Expanded Mode

To operate in secured mode and execute from external memory space, the system should be correctly configured for secured mode and then reset into expanded mode. The internal (on-chip) Flash EEPROM and EEPROM blocks (if applicable) will be disabled and unavailable. All BDM operation will be blocked. In addition, while in secured mode all internal visibility (IVIS) and CPU pipe (IPIPE) information will be blocked from output.

### 15.4.3 Unsecuring The System

To unsecure a system that is configured for secured mode, the internal (on-chip) Flash EEPROM and EEPROM must be fully erased. This can be performed using one of the following methods:

1. Reset the microcontroller into SPECIAL TEST mode, execute a program which writes the Mass Erase command sequence into the Flash and EEPROM Command registers.
2. Reset the microcontroller into SPECIAL SINGLE CHIP mode, delay while the erase test is performed by the BDM secure ROM. Send BDM commands to write the Mass Erase command sequence into the Flash and EEPROM Command registers.
3. Reset the microcontroller into SPECIAL PERIPHERAL mode, using SPM commands write the Mass Erase command sequence into the Flash and EEPROM Command registers.
:User Guide - S12CPU15UtGeqs.2cale Semiconductor, Inc.

In all modes the mass erase command sequence must have the following steps:
a. Write FCLKDIV register to set the Flash clock for proper timing.
b. Write $\$ 00$ to FCNFG register to select Flash block 0.
c. Write $\$ 10$ to FTSTMOD register to set WRALL bit.
(with WRALL set, all of the following writes to banked Flash registers will affect all Flash blocks.)
d. Disable Flash protection by writing the FPROT register.
e. Write any data to Flash memory space $\$$ C000-\$FFFF
f. Write Mass Erase command(\$41) to FCMD register.
g. Clear CBIEF (bit 7) it FSTAT register.
h. Write ECLKDIV register to set the EEPROM clock for proper timing.
i. Disable protection in EEPROM by writing the EPROT register.
j. Write any data to EEPROM memory space.
k. Write Mass Erase command (\$41) to ECMD register.

1. Clear CBIEF (bit 7) it ESTAT register.
m . Wait until all CCIF flags are set to 1 again.
After all the CCIF flags are set to 1 again, the Flash and EEPROM have been erased. Reset the microcontroller into SPECIAL SINGLE CHIP mode. The BDM secure ROM will verify that the nonvolatile memories are erased, and then it will assert the UNSEC bit in the BDM Status register. This will cause the core_secure_t2 signal to de-assert, and the microcontroller will be unsecure. All BDM commands will be enabled and the Flash security byte may be programmed to the unsecure state by any of the following methods:
2. Send BDM commands to write to the MODE register and change to SPECIAL TEST mode, send a BDM WRITE_PC, followed by a BDM GO command to jump to a program at an external address. This external program can then program the Flash security byte to the unsecure state.
3. .Send BDM commands to directly program the Flash security byte.

In all modes programming the security byte must have the following steps:
a. Write FCLKDIV register to set the Flash clock for proper timing.
b. Write $\$ 00$ to FCNFG register to select Flash block 0.
c. Disable Flash protection by writing the FPROT register.
d. Write \$FFFE to address \$FF0E
e. Write Program command $(\$ 20)$ to FCMD register.
f. Clear CBIEF (bit 7) it FSTAT register.
g. Wait until Flash CCIF flag is set to 1 again.

After this Flash programming sequence is complete, the microcontroller can be reset into any mode, the Flash has been unsecured.

In normal modes, either SINGLE CHIP or EXPANDED, the microcontroller may only be unsecured by using the backdoor key access feature. This requires knowledge of the contents of the backdoor keys, which must be written to the Flash memory space at the appropriate addresses, in the correct order. In addition, in SINGLE CHIP mode the user code stored in the Flash must have a method of receiving the backdoor key from an external stimulus. This external stimulus would typically be through one of the on-chip serial ports. After the backdoor sequence has been correctly matched, the microcontroller will be
unsecured, and all Flash commands will be enabled and the Flash security byte can be programmed to the unsecure state, if desired.

Please note that if the system goes through a reset condition prior to successful configuration of unsecured mode the system will reset back into secured mode operation.

### 15.5 Motorola Internal Information

This subsection details information about the Core secured mode of operation that is for Motorola use only and should not be published in any form outside of Motorola.

### 15.5.1 BDM Secured Mode Firmware

When the Core is operating in secured mode and the system is reset into special single-chip mode, alternate BDM firmware is invoked in place of the standard BDM firmware. A listing of this secured mode firmware is given in 14.8.9 of this guide.
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Appendix A Instruction Set and Commands

## A. 1 General

This glossary contains entries for all assembler mnemonics in alphabetical order. Each entry describes the operation of the instruction, its effect on the condition code register, and its syntax.

## A. 2 Glossary Notation

## A.2.1 Condition Code State Notation

## Table A-1 Condition Code State Notation

| - | Not changed by operation |
| :---: | :--- |
| 0 | Cleared by operation |
| 1 | Set by operation |
| $\Delta$ | Set or cleared by operation |
| $\Downarrow$ | May be cleared or remain set, but not set by operation |
| $\Uparrow$ | May be set or remain cleared, but not cleared by operation |
| $?$ | May be changed by operation but final state not defined |
| $!$ | Used for a special purpose |

## A.2.2 Register and Memory Notation

Table A-2 Register and Memory Notation

| A or a | Accumulator A |
| :---: | :---: |
| An | Bit n of accumulator A |
| $B$ or $b$ | Accumulator B |
| Bn | Bit n of accumulator B |
| D ord | Accumulator D |
| Dn | Bit n of accumulator D |
| X or $x$ | Index register X |
| $\mathrm{X}_{\mathrm{H}}$ | High byte of index register X |
| XL | Low byte of index register X |
| Xn | Bit n of index register X |
| Y or $y$ | Index register Y |
| $\mathrm{Y}_{\mathrm{H}}$ | High byte of index register $Y$ |
| $Y_{\text {L }}$ | Low byte of index register Y |
| Yn | Bit n of index register Y |
| SP or $s p$ | Stack pointer |
| SPn | Bit n of stack pointer |
| PC or $p c$ | Program counter |
| $\mathrm{PC}_{\mathrm{H}}$ | High byte of program counter |
| $\mathrm{PC}_{\mathrm{L}}$ | Low byte of program counter |
| CCR or C | Condition code register |
| M | Address of 8-bit memory location |
| Mn | Bit n of byte at memory location M |
| Rn | Bit n of the result of an arithmetic or logical operation |
| In | Bit n of the intermediate result of an arithmetic or logical operation |
| $\mathrm{RTN}_{\mathrm{H}}$ | High byte of return address |
| $\mathrm{RTN}_{\mathrm{L}}$ | Low byte of return address |
| () | Contents of |

## A.2.3 Address Mode Notation

Table A-3 Address Mode Notation

| INH | Inherent; no operands in instruction stream |
| ---: | :--- |
| IMM | Immediate; operand immediate value in instruction stream |
| DIR | Direct; operand is lower byte of address from \$0000 to \$00FF |
| EXT | Operand is a 16-bit address |
| REL | Two's complement relative offset; for branch instructions |
| IDX | Indexed (no extension bytes); includes: <br> 5-bit constant offset from X, Y, SP or PC <br> Pre/post increment/decrement by 1-8 <br> Accumulator A, B, or D offset |
| IDX1 | 9-bit signed offset from X, Y, SP, or PC; 1 extension byte |
| IDX2 | 16-bit signed offset from X, Y, SP, or PC; 2 extension bytes |
| [IDX2] | Indexed-indirect; 16-bit offset from X, Y, SP, or PC |
| [D, IDX] | Indexed-indirect; accumulator D offset from X, Y, SP, or PC |

## A.2.4 Operator Notation

Table A-4 Operator Notation

| + | Add |
| :---: | :--- |
| - | Subtract |
| $\bullet$ | AND |
| $\dot{1}$ | OR |
| $\oplus$ | Exclusive OR |
| $\times$ | Multiply |
| $\div$ | Divide |
| $:$ | Concatenate |
| $\Rightarrow$ | Transfer |
| $\Leftrightarrow$ | Exchange |

## A.2.5 Machine Code Notation

In the Machine Code (Hex) column on the glossary pages, digits 0-9 and upper case letters A-F represent hexadecimal values. Pairs of lower-case letters represent 8-bit values as shown in Table A-5.

Table A-5 Machine Code Notation

| dd | 8-bit direct address from $\$ 0000$ to $\$ 00 F F ;$ high byte is $\$ 00$ |
| :--- | :--- |
| ee | High byte of a 16-bit constant offset for indexed addressing |
| eb | Exchange/transfer postbyte |
| ff | Low eight bits of a 9-bit signed constant offset in indexed addressing, or low byte of a 16-bit <br> constant offset in indexed addressing |
| hh | High byte of a 16-bit extended address |
| ii | 8-bit immediate data value |
| jj | High byte of a 16-bit immediate data value |
| kk | Low byte of a 16-bit immediate data value |
| lb | Loop primitive (DBNE) postbyte |
| ll | Low byte of a 16-bit extended address |
| mm | 8-bit immediate mask value for bit manipulation instructions; bits that are set indicate bits to be <br> affected |
| pg | Program page or bank number used in CALL instruction |
| qq | High byte of a 16-bit relative offset for long branches |
| tn | Trap number from $\$ 30$ to $\$ 39$ or from $\$ 40$ to $\$ F F$ |
| rr | Signed relative offset $\$ 80(-128)$ to $\$ 7 F$ <br> or low byte of a 16 -bit relative offset for long branches |
| xb | Indexed addressing postbyte |

## A.2.6 Source Form Notation

The Source Form column on the glossary pages gives essential information about assembler source forms. For complete information about writing source files for a particular assembler, refer to the documentation provided by the assembler vendor.

Everything in the Source Form column, except expressions in italic characters, is literal information which must appear in the assembly source file exactly as shown. The initial 3- to 5-letter mnemonic is always a literal expression. All commas, pound signs (\#), parentheses, square brackets ( [ or ] ), plus signs $(+)$, minus signs ( - ), and the register designation (A, B, D), are literal characters.

The groups of italic characters shown in Table A-6 represent variable information to be supplied by the programmer. These groups can include any alphanumeric character or the underscore character, but cannot include a space or comma. For example, the groups xysppc and oprx0_xysppc are both valid, but the two groups oprx0 xysppc are not valid because there is a space between them.

Table A-6 Source Form Notation

| $a b c$ | Register designator for A, B, or CCR |
| :---: | :---: |
| abcdxysp | Register designator for A, B, CCR, D, X, Y, or SP |
| abd | Register designator for A, B, or D |
| abdxysp | Register designator for A, B, D, X, Y, or SP |
| dxysp | Register designator for D, X, Y, or SP |
| msk8 | 8-bit mask value Some assemblers require the \# symbol before the mask value. |
| opr8i | 8-bit immediate value |
| opr16i | 16-bit immediate value |
| opr8a | 8-bit address value used with direct address mode |
| opr16a | 16-bit address value |
| oprx0_xysp | Indexed addressing postbyte code: <br> oprx3,-xysp - Predecrement X , Y, or SP by 1-8 <br> oprx3,+xysp - Preincrement X, Y, or SP by 1-8 <br> oprx3,xysp- - Postdecrement X, Y, or SP by 1-8 <br> oprx3,xysp+ - Postincrement X, Y, or SP by 1-8 <br> oprx5,xysppc - 5-bit constant offset from X, Y, SP, or PC <br> abd,xysppc - Accumulator A, B, or D offset from X, Y, SP, or PC |
| oprx3 | Any positive integer from 1 to 8 for pre/post increment/decrement |
| oprx5 | Any integer from -16 to +15 |
| oprx9 | Any integer from -256 to +255 |
| oprx16 | Any integer from $-32,768$ to $+65,535$ |
| page | 8-bit value for PPAGE register <br> Some assemblers require the \# symbol before this value. |
| rel8 | Label of branch destination within -256 to +255 locations |
| rel9 | Label of branch destination within -512 to +511 locations |
| rel16 | Any label within the 64-Kbyte memory space |
| trapnum | Any 8-bit integer from \$30 to \$39 or from \$40 to \$FF |
| xysp | Register designator for X or Y or SP |
| xysppc | Register designator for X or Y or SP or PC |

## A.2.7 CPU Cycles Notation

The CPU Cycles column on the glossary pages shows how many bytes of information the CPU accesses while executing an instruction. With this information and knowledge of the type and speed of memory in the system, you can determine the execution time for any instruction in any system. Simply count the code letters to determine the execution time of an instruction in a best-case system. An example of a best-case system is a single-chip 16-bit system with no 16-bit off-boundary data accesses to any locations other than on-chip RAM.

A single-letter code in represents a single CPU access cycle. An upper-case letter indicates a 16-bit access.

## Table A-7 CPU Cycle Notation

| f | Free cycle. During an $f$ cycle, the CPU does not use the bus. An $f$ cycle is always one cycle of the system bus clock. An f cycle can be used by a queue controller or the background debug system to perform a single-cycle access without disturbing the CPU. |
| :---: | :---: |
| 9 | Read PPAGE register. A g cycle is used only in CALL instructions and is not visible on the external bus. Since PPAGE is an internal 8 -bit register, a g cycle is never stretched. |
|  | Read indirect pointer. Indexed-indirect instructions use the 16-bit indirect pointer from memory to address the instruction operand. An I cycle is a 16 -bit read that can be aligned or misaligned. An I cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An I cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
|  | Read indirect PPAGE value. An i cycle is used only in indexed-indirect CALL instructions. The 8 -bit PPAGE value for the CALL destination is fetched from an indirect memory location. An i cycle is stretched only when controlled by a chip-select circuit that is programmed for slow memory. |
|  | Write PPAGE register. An n cycle is used only in CALL and RTC instructions to write the destination value of the PPAGE register and is not visible on the external bus. Since the PPAGE register is an internal 8 -bit register, an $n$ cycle is never stretched. |
| $\bigcirc$ | Optional cycle. An o cycle adjusts instruction alignment in the instruction queue. An o cycle can be a free cycle (f) or a program word access cycle (P). When the first byte of an instruction with an odd number of bytes is misaligned, the o cycle becomes a P cycle to maintain queue order. If the first byte is aligned, the o cycle is an f cycle. <br> The $\$ 18$ prebyte for a page-two opcode is treated as a special one-byte instruction. If the prebyte is misaligned, the o cycle at the beginning of the instruction becomes a P cycle to maintain queue order. If the prebyte is aligned, the o cycle is an f cycle. If the instruction has an odd number of bytes, it has a second o cycle at the end. If the first o cycle is a P cycle (prebyte misaligned), the second o cycle is an f cycle. If the first o cycle is an f cycle (prebyte aligned), the second o cycle is a P cycle. <br> An o cycle that becomes a P cycle can be extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An o cycle that becomes an $f$ cycle is never stretched. |
|  | Program word access. Program information is fetched as aligned 16-bit words. A P cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the program is stored externally. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. |
|  | 8 -bit data read. An r cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| R | 16 -bit data read. An R cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. An R cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
|  | Stack 8-bit data. An s cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| S | Stack 16 -bit data. An s cycle is extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the SP is pointing to external memory. There can be additional stretching if the address space is assigned to a chip-select circuit programmed for slow memory. An scycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. The internal RAM is designed to allow single cycle misaligned word access. |

## Table A-7 CPU Cycle Notation (Continued)

| w | 8-bit data write. A w cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| :---: | :---: |
| W | 16-bit data write. A w cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A w cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
| u | Unstack 8-bit data. A w cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| U | Unstack 16-bit data. A u cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the SP is pointing to external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A u cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. The internal RAM is designed to allow single-cycle misaligned word access. |
| V | 16 -bit vector fetch. Vectors are always aligned 16 -bit words. A v cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. |
| t | 8-bit conditional read. A t cycle is either a data read cycle or a free cycle, depending on the data and flow of the REVW instruction. A t cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| T | 16-bit conditional read. A т cycle is either a data read cycle or a free cycle, depending on the data and flow of the REV or REVW instruction. A t cycle is extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. A T cycle is also stretched if it corresponds to a misaligned access to a memory that is not designed for single-cycle misaligned access. |
| x | 8-bit conditional write. An x cycle is either a data write cycle or a free cycle, depending on the data and flow of the REV or REVW instruction. An x cycle is stretched only when controlled by a chip-select circuit programmed for slow memory. |
| Special Notation for Branch Taken/Not Taken |  |
| PPP/P | A short branch requires three cycles if taken, one cycle if not taken. Since the instruction consists of a single word containing both an opcode and an 8-bit offset, the not-taken case is simple - the queue advances, another program word fetch is made, and execution continues with the next instruction. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address. |
| OPPP / OPO | A long branch requires four cycles if taken, three cycles if not taken. An o cycle is required because all long branches are page two opcodes and thus include the $\$ 18$ prebyte. The prebyte is treated as a one-byte instruction. If the prebyte is misaligned, the o cycle is a P cycle; if the prebyte is aligned, the o cycle is an $f$ cycle. As a result, both the taken and not-taken cases use one o cycle for the prebyte. In the not-taken case, the queue must advance so that execution can continue with the next instruction, and another o cycle is required to maintain the queue. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address. |

## A. 3 Glossary

## Add B to A

Operation $\quad(\mathrm{A})+(\mathrm{B}) \Rightarrow \mathrm{A}$
Adds the value in B to the value in A and places the result in A . The value in B does not change. This instruction affects the H bit so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

$\mathrm{H}: \mathrm{A} 3 \bullet \mathrm{~B} 3|\mathrm{~B} 3 \cdot \overline{\mathrm{R}}| \overline{\mathrm{R} 3} \cdot \mathrm{~A} 3$; set if there is a carry from bit 3 ; cleared otherwise
N : Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{A} 7 \bullet \mathrm{B7} \bullet \overline{\mathrm{R}} \mid \overline{\mathrm{A} 7} \bullet \overline{\mathrm{B7}} \bullet \mathrm{R7}$; set if the operation produces a two's complement overflow; cleared otherwise
$C: A 7 \bullet B 7|B 7 \bullet R 7| R 7 \bullet A 7$; set if there is a carry from the MSB of the result; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ABA | INH | 1806 | 00 |

Operation $\quad(X)+(B) \Rightarrow X$
Adds the 8 -bit unsigned value in $B$ to the value in $X$ considering the possible carry out of the low byte of X and places the result in X . The value in B does not change.

ABX assembles as LEAX B,X. The LEAX instruction allows A, B, D, or a constant to be added to X .


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ABX | IDX | 1A E 5 | Pf |

Operation $\quad(\mathrm{Y})+(\mathrm{B}) \Rightarrow \mathrm{Y}$
Adds the 8 -bit unsigned value in B to the value in Y considering the possible carry out of the low byte of Y and places the result in Y. The value in B does not change.

ABY assembles as LEAY B, Y. The LEAY instruction allows A, B, D, or a constant to be added to Y .


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ABY | IDX | 19 ED | Pf |

$(\mathrm{A})+(\mathrm{M})+\mathrm{C} \Rightarrow \mathrm{A}$
or
(A) $+\mathrm{imm}+\mathrm{C} \Rightarrow \mathrm{A}$

Adds either the value in M and the C bit or an immediate value and the C bit to the value in A. Puts the result in A. This instruction affects the H bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

H: A3 • M3 | M3 • $\overline{R 3} \mid \overline{R 3} \bullet A 3$; set if there is a carry from bit 3; cleared otherwise
N : Set if MSB of result is set; cleared otherwise
Z: Set if result is \$00; cleared otherwise
V : A7 •M7 • $\overline{\mathrm{R7}} \mid \overline{\mathrm{A} 7} \bullet \overline{\mathrm{M} 7} \bullet \mathrm{R} 7$; set if the operation produces a two's complement overflow; cleared otherwise
$C: A 7 \bullet M 7|M 7 \bullet \overline{R 7}| \overline{R 7} \bullet A 7$; set if there is a carry from the MSB of the result; cleared otherwise
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ADCA \#opr8i | IMM | 89 ii | P |
| ADCA opr8a | DIR | 99 dd | rPf |
| ADCA opr16a | EXT | B9 hh 11 | rPO |
| ADCA oprxO_xysppc | IDX | A9 xb | rPf |
| ADCA oprx9,xysppc | IDX1 | A9 xb ff | rPO |
| ADCA oprx16,xysppc | IDX2 | A9 xb ee ff | frPP |
| ADCA [D,xysppc] | [D,IDX] | A9 xb | fifrP |
| ADCA [oprx16,xysppc] | [IDX2] | A9 xb ee ff | fIPrPf |

$(\mathrm{B})+(\mathrm{M})+\mathrm{C} \Rightarrow \mathrm{B}$
or
(B) $+\mathrm{imm}+\mathrm{C} \Rightarrow \mathrm{B}$

Adds either the value in M and the C bit or an immediate value and the C bit to the value in B. Puts the result in B. This instruction affects the H bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

## CCR

## Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

$\mathrm{H}: \mathrm{B} 3 \bullet \mathrm{M} 3|\mathrm{M} 3 \cdot \overline{\mathrm{R}}| \overline{\mathrm{R} 3} \bullet \mathrm{B3}$; set if there is a carry from bit 3 ; cleared otherwise
N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{B7} \bullet \mathrm{M} 7 \bullet \overline{\mathrm{R7}} \mid \overline{\mathrm{B7}} \bullet \overline{\mathrm{M} 7} \bullet \mathrm{R7}$; set if the operation produces a two's complement overflow; cleared otherwise
$\mathrm{C}: \mathrm{B7} \bullet \mathrm{M} 7|M 7 \bullet \overline{\mathrm{R7}}| \overline{\mathrm{R7}} \bullet \mathrm{B7}$; set if there is a carry from the MSB of the result; cleared otherwise
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ADCB \#opr8i | IMM | C9 ii | P |
| ADCB opr8a | DIR | D9 dd | rPf |
| ADCB opr16a | EXT | F9 hh 11 | rPO |
| ADCB oprxO_xysppc | IDX | E9 xb | rPf |
| ADCB oprx9,xysppc | IDX1 | E9 xb ff | rPO |
| ADCB oprx16,xysppc | IDX2 | E9 xb ee ff | frPP |
| ADCB [D,xysppc] | [D,IDX] | E9 xb | fifrPf |
| ADCB [oprx16,xysppc] | [IDX2] | E9 xb ee ff | fIPrPf |

$(\mathrm{A})+(\mathrm{M}) \Rightarrow \mathrm{A}$
or
(A) $+\mathrm{imm} \Rightarrow \mathrm{A}$

Adds either the value in M or an immediate value to the value in A and places the result in A . This instruction affects the H bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

## CCR

## Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

$\mathrm{H}: \mathrm{A} 3 \bullet \mathrm{M} 3|\mathrm{M} 3 \bullet \overline{\mathrm{R} 3}| \overline{\mathrm{R} 3} \bullet \mathrm{~A} 3$; set if there is a carry from bit 3; cleared otherwise
N : Set if MSB of result is set; cleared otherwise
Z: Set if result is \$00; cleared otherwise
V : A7 •M7 • $\overline{\mathrm{R7}} \mid \overline{\mathrm{A} 7} \bullet \overline{\mathrm{M} 7} \bullet \mathrm{R} 7$; set if the operation produces a two's complement overflow; cleared otherwise
$C: A 7 \bullet M 7|M 7 \bullet \overline{R 7}| \overline{R 7} \bullet A 7$; set if there is a carry from the MSB of the result; cleared otherwise
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ADDA \#opr8i | IMM | 8B ii | P |
| ADDA opr8a | DIR | 9B dd | rPf |
| ADDA opr16a | EXT | BB hh 11 | rPO |
| ADDA oprx0_xysppc | IDX | AB xb | rPf |
| ADDA oprx9,xysppc | IDX1 | AB xb ff | rPO |
| ADDA oprx16,xysppc | IDX2 | AB xb ee ff | frPP |
| ADDA [D,xysppc] | [D,IDX] | $A B \times b$ | fifrP |
| ADDA [oprx16,xysppc] | [IDX2] | AB xb ee ff | fIPrPf |

$(\mathrm{B})+(\mathrm{M}) \Rightarrow \mathrm{B}$
or
(B) $+\mathrm{imm} \Rightarrow \mathrm{B}$

Adds either the value in M or an immediate value to the value in B and places the result in B. This instruction affects the H bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

## CCR

## Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

$\mathrm{H}: \mathrm{B} 3 \bullet \mathrm{M} 3|\mathrm{M} 3 \bullet \overline{\mathrm{R} 3}| \overline{\mathrm{R} 3} \bullet \mathrm{~B} 3$; set if there is a carry from bit 3; cleared otherwise
N : Set if MSB of result is set; cleared otherwise
Z: Set if result is \$00; cleared otherwise
V : B7 •M7 • $\overline{\mathrm{R7}} \mid \overline{\mathrm{B7}} \bullet \overline{\mathrm{M} 7} \bullet \mathrm{R7}$; set if the operation produces a two's complement overflow; cleared otherwise
$C: B 7 \bullet M 7|M 7 \bullet \overline{R 7}| \overline{R 7} \bullet B 7$; set if there is a carry from the MSB of the result; cleared otherwise
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ADDB \#opr8i | IMM | CB ii | P |
| ADDB opr8a | DIR | DB dd | rPf |
| ADDB opr16a | EXT | FB hh 11 | rPO |
| ADDB oprx0 xysppc | IDX | EB xb | rPf |
| ADDB oprx9,xysppc | IDX1 | EB xb ff | rPO |
| ADDB oprx16,xysppo | IDX2 | EB xb eeff | frpp |
| ADDB [D,xysppc] | [D,IDX] | EB xb | fIfrPf |
| ADDB [oprx16,xysppc] | [IDX2] | EB xb ee ff | fIPrPf |

$(\mathrm{A}):(\mathrm{B})+(\mathrm{M}):(\mathrm{M}+1) \Rightarrow \mathrm{A}: \mathrm{B}$
or
(A):(B) $+\mathrm{imm} \Rightarrow \mathrm{A}: \mathrm{B}$

Adds either the value in M concatenated with the value in $\mathrm{M}+1$ or an immediate value to the value in D . Puts the result in D . A is the high byte of D ; B is the low byte.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: D15 • M15 • R15 | $\overline{\mathrm{D} 15} \bullet \overline{\mathrm{M} 15} \bullet \mathrm{R} 15$; set if the operation produces a two's complement overflow; cleared otherwise
C: D15 • M15 | M15 • $\overline{\mathrm{R} 15 \mid ~} \overline{\mathrm{R} 15} \bullet \mathrm{D} 15$; set if there is a carry from the MSB of the result; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ADDD \#opr16i | IMM | C3 jj kk | PO |
| ADDD opr8a | DIR | D3 dd | RPf |
| ADDD opr16a | EXT | F3 hh 11 | RPO |
| ADDD oprx0_xysppc | IDX | E3 xb | RPf |
| ADDD oprx9,xysppc | IDX1 | E3 xb ff | RPo |
| ADDD oprx16,xysppc | IDX2 | E3 xb ee ff | fRPP |
| ADDD [D, xysppc] | [D,IDX] | E3 3 xb | fIfRPf |
| ADDD [oprx16,xysppc] | [IDX2] | E3 xb ee ff | fIPRPf |

## AND with A

$(\mathrm{A}) \bullet(\mathrm{M}) \Rightarrow \mathrm{A}$
or
(A) $\bullet \mathrm{imm} \Rightarrow \mathrm{A}$

Performs a logical AND of either the value in M or an immediate value with the value in A. Puts the result in A.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
v : Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ANDA \#opr8i | IMM | 84 ii | P |
| ANDA opr8a | DIR | 94 dd | rPf |
| ANDA opr16a | EXT | B4 hh ll | rPo |
| ANDA oprx0_xysppc | IDX | A 4 xb | rPf |
| ANDA oprx9,xysppc | IDX1 | A4 xb ff | rPo |
| ANDA oprx $16, x y$ sppc | IDX2 | A4 xb ee ff | frpp |
| ANDA [D, xysppc] | [D,IDX] | A4 xb | fIfrPf |
| ANDA [oprx16,xysppc] | [IDX2] | A4 xb ee ff | fIPrPf |

## AND with B

Operation
(B) $\bullet(\mathrm{M}) \Rightarrow \mathrm{B}$
or
(B) $\bullet \mathrm{imm} \Rightarrow \mathrm{B}$

Performs a logical AND of either the value in M or an immediate value with the value in B. Puts the result in B.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ANDB \#opr8i | IMM | C4 ii | P |
| ANDB opr8a | DIR | D4 dd | rPf |
| ANDB opr16a | EXT | F4 hh ll | rPO |
| ANDB oprx0_xysppc | IDX | E4 xb | rPf |
| ANDB oprx9,xysppc | IDX1 | E4 xb ff | rPO |
| ANDB oprx16,xysppc | IDX2 | E4 xb ee ff | frPP |
| ANDB [D,xysppc] | [D,IDX] | E4 xb | fIfrPf |
| ANDB [oprx16,xysppc] | [IDX2] | E4 xb ee ff | fIPrPf |

Operation $\quad(\mathrm{CCR}) \bullet \mathrm{imm} \Rightarrow \mathrm{CCR}$
Performs a logical AND of an immediate value and the value in the CCR. Puts the result in the CCR.

If the I mask bit is cleared, there is a one-cycle delay before the system allows interrupt requests. This prevents interrupts from occurring between instructions in the sequences CLI, WAI and CLI, SEI (CLI is equivalent to ANDCC \#\$EF).

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ |

All CCR bits: Clear if 0 before operation or if corresponding bit in mask is 0
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ANDCC \#opr8i | IMM | 10 ii | P |

## Arithmetic Shift Left M

(same as LSL)
ASL

Operation


Shifts all bits of M one bit position to the left. Bit 0 is loaded with a 0 . The C bit is loaded from the most significant bit of M .

## CCR

Effects


N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: $N \oplus C$; set if:
$N$ is set and C is cleared after the shift, or
N is cleared and C is set after the shift; cleared otherwise
C: M7; set if the MSB of M was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ASL opr16a | EXT | 78 hh 11 | rPwO |
| ASL oprx0_xysppc | IDX | 68 xb | rPw |
| ASL oprx9,xysppc | IDX1 | 68 xb ff | rPwO |
| ASL oprx16,xysppc | IDX2 | 68 xb ee ff | frPwP |
| ASL [D,xysppc] | [D,IDX] | 68 xb |  |
| ASL [oprx16,xysppc] | [IDX2] | 68 xb ee ff | fIfrPw |
| fIPrPw |  |  |  |

## Operation



Shifts all bits of A one bit position to the left. Bit 0 is loaded with a 0 . The C bit is loaded from the most significant bit of A.

CCR
Effects


N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : $\mathrm{N} \oplus \mathrm{C}$; set if:
$N$ is set and C is cleared after the shift, or
N is cleared and C is set after the shift; cleared otherwise
C: A7; set if the MSB of A was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ASLA | INH | 48 | 0 |

(same as LSLB)

## Operation



Shifts all bits of B one bit position to the left. Bit 0 is loaded with a 0 . The C bit is loaded from the most significant bit of B.

CCR
Effects


N : Set if MSB of result is set; cleared otherwise
Z: Set if result is \$00; cleared otherwise
V : $\mathrm{N} \oplus \mathrm{C}$; set if:
$N$ is set and $C$ is cleared after the shift, or
N is cleared and C is set after the shift; cleared otherwise
C: B7; set if the MSB of B was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ASLB | INH | 58 | 0 |

Operation


Shifts all bits of D one bit position to the left. Bit 0 is loaded with a 0 . The C bit is loaded from the most significant bit of $D$.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V : $\mathrm{N} \oplus \mathrm{C}$; set if:
$N$ is set and $C$ is cleared after the shift, or
N is cleared and C is set after the shift; cleared otherwise
C: D15; set if the MSB of D was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ASLD | INH | 59 | 0 |



Shifts all bits of M one place to the right. Bit 7 is held constant. Bit 0 is loaded into the C bit. This operation effectively divides a two's complement value by two without changing its sign. The carry bit can be used to round the result.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}$; set if:
N is set and C is cleared after the shift, or
$N$ is cleared and $C$ is set after the shift; cleared otherwise
C: MO; set if the LSB of M was set before the shift; cleared otherwise
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ASR opr16a | EXT | 77 hh 11 | rPwo |
| ASR oprx0_xysppc | IDX | 67 xb | rPw |
| ASR oprx9, xysppc | IDX1 | 67 xb ff | rPwo |
| ASR oprx16,xysppc | IDX2 | 67 xb ee ff | frPwP |
| ASR [D,xysppc] | [D,IDX] | 67 xb | fIfrPw |
| ASR [oprx16,xysppc] | [IDX2] | 67 xb ee ff | fIPrPw |

## Operation



Shifts all bits of A one place to the right. Bit 7 is held constant. Bit 0 is loaded into the C bit. This operation effectively divides a two's complement value by two without changing its sign. The carry bit can be used to round the result.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : $\mathrm{N} \oplus \mathrm{C}$; set if:
$N$ is set and C is cleared after the shift, or
$N$ is cleared and $C$ is set after the shift; cleared otherwise
C: A0; set if the LSB of A was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ASRA | INH | 47 | 0 |

## Operation



Shifts all bits of $B$ one place to the right. Bit 7 is held constant. Bit 0 is loaded into the $C$ bit. This operation effectively divides a two's complement value by two without changing its sign. The carry bit can be used to round the result.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 00$; cleared otherwise
V : $\mathrm{N} \oplus \mathrm{C}$; set if:
$N$ is set and C is cleared after the shift, or
N is cleared and C is set after the shift; cleared otherwise
$C$ : BO; set if the LSB of $B$ was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ASRB | INH | 57 | 0 |

## Branch if C Clear

(same as BHS)

Operation If $\mathrm{C}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the C bit and branches if $\mathrm{C}=0$.
Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BCC rel8 | REL | 24 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BCC/BHS | 24 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | BCS/BLO | 25 | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})<(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=0$ |  |  | $\mathrm{C}=1$ |  |
| BGE | 2 C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | BLT | 2D | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=0$ |  |  | $N \oplus \mathrm{~V}=1$ |  |

Operation $\quad(\mathrm{M}) \bullet(\overline{\text { mask byte }}) \Rightarrow \mathrm{M}$
Performs a logical AND of the value in M and the complement of a mask byte contained in the instruction. Puts the result in M . Bits in M that correspond to 1 s in the mask byte are cleared. No other bits in M change.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : Cleared
Code and

| Source Form | Address Mode ${ }^{1}$ | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| BCLR opr8a, msk8 BCLR opr16a, msk8 BCLR oprx0_xysppc, msk8 BCLR oprx9, xysppc, msk8 BCLR oprx16,xysppc, msk8 | $\begin{array}{\|l\|} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \end{array}$ | 4D dd mm <br> 1D hh 11 mm <br> OD xb mm <br> OD xb ff mm <br> OD xb ee ff mm | rPwo <br> rPwP <br> rPwO <br> rPwP <br> frPwPo |

NOTES:

1. Indirect forms of indexed addressing cannot be used with this instruction.

Operation If $\mathrm{C}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the C bit and branches if $\mathrm{C}=1$.
Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BCS re/8 | REL | 25 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BCS/BLO | 25 | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | BCC/BHS | 24 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \geq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=1$ |  |  | $\mathrm{C}=0$ |  |
| BLT | 2D | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})<(\mathrm{A}) \end{aligned}$ | BGE | 2 C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=1$ |  |  | $N \oplus \mathrm{~V}=0$ |  |

Operation If $\mathrm{Z}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the Z bit and branches if $\mathrm{Z}=1$.
Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BEQ rel8 | REL | 27 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BEQ | 27 | $\begin{aligned} & (\mathrm{R})=(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{R})=\text { zero } \end{aligned}$ | BNE | 26 | $\begin{aligned} & (\mathrm{R}) \neq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{R}) \neq \text { zero } \end{aligned}$ | Signed, unsigned or simple |
|  |  | $\mathrm{Z}=1$ |  |  | $\mathrm{Z}=0$ |  |

# : User Guide - S12CPU15ƯGê.scale Semiconductor, Inc. 

If $\mathrm{N} \oplus \mathrm{V}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BGE can be used to branch after comparing or subtracting signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than or equal to the value in M. After CBA or SBA, the branch occurs if the value in B is greater than or equal to the value in A .

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

## CCR

## Effects



Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BGE re/8 | REL | 2 Crr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BGE | 2 C | $\begin{aligned} & (R) \geq(M) \\ & \text { or } \\ & (B) \geq(A) \end{aligned}$ | BLT | 2D | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & \text { (B) }<(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=0$ |  |  | $N \oplus \mathrm{~V}=1$ |  |
| BHS/BCC | 24 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | BLO/BCS | 25 | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & \text { (B) }<\text { (A) } \end{aligned}$ | Unsigned |
|  |  | $C=0$ |  |  | $\mathrm{C}=1$ |  |

BDM vector $\Rightarrow \mathrm{PC}$
BGND operates like a software interrupt, except that no registers are stacked. First, the current PC value is stored in internal CPU register TMP2. Next, the BDM ROM and background register block become active. The BDM ROM contains a substitute vector, mapped to the address of the software interrupt vector, which points to routines in the BDM ROM that control background operation. The substitute vector is fetched, and execution continues from the address that it points to. Finally, the CPU checks the location that TMP2 points to. If the value stored in that location is $\$ 00$ (the BGND opcode), TMP2 is incremented, so that the instruction that follows the BGND instruction is the first instruction executed when normal program execution resumes.

For all other types of BDM entry, the CPU performs the same sequence of operations as for a BGND instruction, but the value stored in TMP2 already points to the instruction that would have executed next had BDM not become active. If active BDM is triggered just as a BGND instruction is about to execute, the BDM firmware does increment TMP2, but the change does not affect resumption of normal execution.

While BDM is active, the CPU executes debugging commands received via a special single-wire serial interface. BDM is terminated by the execution of specific debugging commands. Upon exit from BDM, the background/boot ROM and registers are disabled, the instruction queue is refilled starting with the return address pointed to by TMP2, and normal processing resumes.

BDM is normally disabled to avoid accidental entry. While BDM is disabled, BGND executes as described, but the firmware causes execution to return to the user program.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BGND | INH | 00 | VfPPP |

# : User Guide - S12CPU15ƯGêt.scale Semiconductor, Inc. 

BGT

## Branch if Greater Than Zero

If $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BGT can be used to branch after comparing or subtracting signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than the value in M. After CBA or SBA, the branch occurs if the value in $B$ is greater than the value in $A$.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BGT rel8 | REL | 2 Err | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BGT | 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | BLE | 2F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \leq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$ |  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$ |  |
| BHI | 22 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})>(\mathrm{A}) \end{aligned}$ | BLS | 23 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | C $\mid$ Z $=0$ |  |  | C $\mid$ Z $=1$ |  |

If $\mathrm{C} \mid \mathrm{Z}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BHI can be used to branch after comparing or subtracting unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than the value in M. After CBA or SBA, the branch occurs if the value in B is greater than the value in A . BHI is not for branching after instructions that do not affect the C bit, such as increment, decrement, load, store, test, clear, or complement.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BHI rel8 | REL | 22 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BHI | 22 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | BLS | 23 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C} \mid \mathrm{Z}=0$ |  |  | C $\mid$ Z $=1$ |  |
| BGT | 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})>(\mathrm{A}) \end{aligned}$ | BLE | 2 F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$ |  |  | $Z \mid(N \oplus V)=1$ |  |

# : User Guide - S12CPU15Uterestcale Semiconductor, Inc. 

## Branch if Higher or Same

(same as BCC)

If $\mathrm{C}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BHS can be used to branch after subtracting or comparing unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than or equal to the value in M. After CBA or SBA, the branch occurs if the value in B is greater than or equal to the value in A. BHS is not for branching after instructions that do not affect the C bit, such as increment, decrement, load, store, test, clear, or complement.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BHS rel8 | REL | 24 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BHS/BCC | 24 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | BLO/BCS | 25 | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=0$ |  |  | $\mathrm{C}=1$ |  |
| BGE | 2 C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | BLT | 2D | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{N} \oplus \mathrm{V}=0$ |  |  | $N \oplus \mathrm{~V}=1$ |  |

Operation (A) • (M)
or
(A) • imm

Performs a logical AND of either the value in M or an immediate value with the value in A. CCR bits reflect the result. The values in A and M do not change.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| BITA \#opr8i | IMM | 85 ii | P |
| BITA opr8a | DIR | 95 dd | rPf |
| BITA opr16a | EXT | B5 hh 11 | rPO |
| BITA oprx0_xysppc | IDX | A5 xb | rPf |
| BITA oprx9,xysppc | IDX1 | A5 xb ff | rPO |
| BITA oprx16,xysppc | IDX2 | A5 xb ee ff | frPP |
| BITA [D, xysppc] | [D,IDX] | A5 xb | fifrpf |
| BITA [oprx16,xysppc] | [IDX2] | A5 xb ee ff | fIPrPf |

(B) • (M)
or
(B) $\bullet \mathrm{imm}$

Performs a logical AND of either the value in M or an immediate value with the value in B. CCR bits reflect the result. The values in $B$ and $M$ do not change.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| BITB \#opr8i | IMM | C5 ii | P |
| BITB opr8a | DIR | D5 dd | rPf |
| BITB opr16a | EXT | F5 hh 11 | rPO |
| BITB oprx0_xysppc | IDX | E5 xb | rPf |
| BITB oprx9,xysppc | IDX1 | E5 xb ff | rPO |
| BITB oprx16,xysppc | IDX2 | E5 xb ee ff | frPP |
| BITB [D,xysppc] | [D,IDX] | E5 xb | fifrpf |
| BITB [oprx16,xysppc] | [IDX2] | E5 xb ee ff | fIPrPf |

## Branch if Less Than or Equal to Zero

Operation
If $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BLE can be used to branch after subtracting or comparing signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than or equal to the value in M. After CBA or SBA, the branch occurs if the value in B is less than or equal to the value in $A$.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.


Code and
CPU Cycles

| Source Form | Address <br> Mode | Object Code | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BLE rel8 | REL | 2 Frr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BLE | 2F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | BGT | 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$ |  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$ |  |
| BLS | 23 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | BHI | 22 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})>(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | C $\mid$ Z $=1$ |  |  | $C \mid Z=0$ |  |

# : User Guide - S12CPU15ƯGê.scale Semiconductor, Inc. 

## Branch if Lower

(same as BCS)

If $\mathrm{C}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BLO can be used to branch after subtracting or comparing unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than the value in M. After CBA or SBA, the branch occurs if the value in B is less than the value in A . BLO is not for branching after instructions that do not affect the C bit, such as increment, decrement, load, store, test, clear, or complement.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BLO rel8 | REL | 25 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BLO/BCS | 25 | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | BHS/BCC | 24 | $\begin{aligned} & (R) \geq(M) \\ & o r \\ & (B) \geq(A) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=1$ |  |  | $C=0$ |  |
| BLT | 2D | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | BGE | 2 C | $\begin{aligned} & (R) \geq(M) \\ & o r \\ & (B) \geq(A) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=1$ |  |  | $\mathrm{N} \oplus \mathrm{V}=0$ |  |

## Branch if Lower or Same

If $\mathrm{C} \mid \mathrm{Z}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BLS can be used to branch after subtracting or comparing unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than or equal to the value in M. After CBA or SBA, the branch occurs if the value in B is less than or equal to the value in A. BLS is not for branching after instructions that do not affect the C bit, such as increment, decrement, load, store, test, clear, or complement.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BLS rel8 | REL | 23 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BLS | 23 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | BHI | 22 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})>(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | C \| $\mathrm{Z}=1$ |  |  | $\mathrm{C} \mid \mathrm{Z}=0$ |  |
| BLE | 2 F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | BGT | 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$ |  |  | $Z \mid(N \oplus V)=0$ |  |

# : User Guide - S12CPU15Uṫersscale Semiconductor, Inc. 

BLT
Branch if Less Than Zero

Operation If $\mathrm{N} \oplus \mathrm{V}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
BLT can be used to branch after subtracting or comparing signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than the value in M. After CBA or SBA, the branch occurs if the value in B is less than the value in A .

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BLT rel8 | REL | 2D rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BLT | 2D | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & \text { (B) }<(\mathrm{A}) \end{aligned}$ | BGE | 2 C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=1$ |  |  | $\mathrm{N} \oplus \mathrm{V}=0$ |  |
| BLO/BCS | 25 | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & \text { (B) }<(\mathrm{A}) \end{aligned}$ | BHS/BCC | 24 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=1$ |  |  | $\mathrm{C}=0$ |  |

## Branch if Minus

Operation If $\mathrm{N}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the N bit and branches if $\mathrm{N}=1$.
Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BMI rel8 | REL | 2B rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BMI | $2 B$ | Negative | BPL | 2 A | Positive | Simple |
|  |  |  |  |  |  |  |

Operation If $\mathrm{Z}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the Z bit and branches if $\mathrm{Z}=0$.
Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

## Effects



Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BNE rel8 | REL | 26 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BNE | 26 | $\begin{aligned} & (\mathrm{R}) \neq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{R}) \neq \text { zero } \end{aligned}$ | BEQ | 27 | $\begin{aligned} & (\mathrm{R})=(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{R})=\text { zero } \end{aligned}$ | Signed, unsigned, or simple |
|  |  | $\mathrm{Z}=0$ |  |  | $\mathrm{Z}=1$ |  |

Operation If $\mathrm{N}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the N bit and branches if $\mathrm{N}=0$.
Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | Source Form |
| :--- | :--- | :--- | :--- |
| BPL rel8 | REL | 2A rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BPL | $2 A$ | Positive | BMI | 2 B | Negative | Simple |
|  |  | $N=0$ |  |  |  |  |

## Branch Always

Operation
$(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Branches unconditionally.
Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

Execution time is longer when a conditional branch is taken than when it is not taken, because the instruction queue must be refilled before execution resumes at the new address. Since the BRA branch condition is always satisfied, the branch is always taken, and the instruction queue must always be refilled.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BRA rel8 | REL | 20 rr | PPP |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BRA | 20 | Always | BRN | 21 | Never | Simple |

Operation If $(\mathrm{M}) \bullet($ mask byte $)=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Performs a logical AND of the value in M and the mask value supplied with the instruction. Branches if all the 0s in M correspond to 1s in the mask byte.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

CCR
Effects


Code and

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| BRCLR opr8a, msk8, rel8 BRCLR opr16a, msk8, rel8 BRCLR oprx0_xysppc, msk8, rel8 BRCLR oprx9,xysppc, msk8, rel8 BRCLR oprx16,xysppc, msk8, rel8 | DIR EXT IDX IDX1 IDX2 | 4 F dd mm rr <br> 1 Fhh 11 mm rr <br> 0 Fxbmmr <br> OF xb ff mm rr <br> OF xb ee ff mmrr | $\begin{aligned} & \mathrm{rPPPP} \\ & \text { rfPPP } \\ & \text { rPPP } \\ & \text { rfPPP } \\ & \text { PrfPPP } \end{aligned}$ |

## Branch Never

Operation $\quad(\mathrm{PC})+\$ 0002 \Rightarrow \mathrm{PC}$
Never branches. BRN is effectively a 2-byte NOP that requires one cycle. BRN is included in the instruction set to provide a complement to the BRA instruction. BRN is useful during program debug to negate the effect of another branch instruction without disturbing the offset byte. A complement for BRA is also useful in compiler implementations.

Execution time is longer when a conditional branch is taken than when it is not, because the instruction queue must be refilled before execution resumes at the new address. Since the BRN branch condition is never satisfied, the branch is never taken, and only a single program fetch is needed to update the instruction queue.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BRN rel8 | REL | 21 rr | P |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BRN | 21 | Never | BRA | 20 | Always | Simple |

Operation If $(\overline{\mathrm{M}}) \bullet($ mask byte $)=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Performs a logical AND of the value of $\overline{\mathrm{M}}$ and the mask value supplied with the instruction. Branches if all the ones in $\bar{M}$ correspond to ones in the mask byte.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127 ) from the address following the last byte of object code in the instruction.

## CCR

## Effects



Code and

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| BRSET opr8a, msk8, rel8 | DIR | 4 E dd mm rr | rPPP |
| BRSET opr16a, msk8, rel8 | EXT | 1 E hh 11 mm rr | rfPPP |
| BRSET oprx0_xysppc, msk8, rel8 | IDX | OE xb mm rr | rPPP |
| BRSET oprx9,xysppc, msk8, rel8 | IDX1 | OE xb ff mm rr | rffpp |
| BRSET oprx16,xysppc, msk8, rel8 | IDX2 | OE xb ee ff mm rr | PrfPpp |

Operation $\quad(\mathrm{M}) \mid$ (mask byte) $\Rightarrow \mathrm{M}$
Performs a logical OR of the value in M and a mask byte contained in the instruction. Puts the result in M. Bits in M that correspond to 1s in the mask are set. No other bits in M change.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
v: Cleared
Code and

| Source Form | Address Mode | Machine <br> Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| BSET opr8a, msk8 | DIR | 4C dd mm | rPwo |
| BSET opr16a, msk8 | EXT | 1 Chh 11 mm | rPwP |
| BSET oprx0_xysppc, msk8 | IDX | 0c xb mm | rPwo |
| BSET oprx9,xysppc, msk8 | IDX1 | OC xb ff mm | rPwP |
| BSET oprx16,xysppc, msk8 | IDX2 | OC xb ee ff mm | frPwPo |

$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}$
$\mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Sets up conditions to return to normal program flow, then transfers control to a subroutine.
Uses the address of the instruction after the BSR as a return address.
Decrements the SP by two, to allow the two bytes of the return address to be stacked.
Stacks the return address (the SP points to the high byte of the return address).
Branches to a location determined by the branch offset.
Subroutines are normally terminated with an RTS instruction, which restores the return address from the stack.

CCR
Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BSR re/8 | REL | 07 rr | SPPP |

## Branch if V Clear

Operation If V $=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the V bit and branches if $\mathrm{V}=0$. BVC causes a branch when a previous operation on two's complement binary values does not cause an overflow. That is, when BVC follows a two's complement operation, a branch occurs when the result of the operation is valid.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127) from the address following the last byte of object code in the instruction.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BVC rel8 | REL | 28 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BRN | 21 | Never | BRA | 20 | Always | Simple |

If $\mathrm{V}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the V bit and branches if $\mathrm{V}=1$. BVS causes a branch when a previous operation on two's complement values causes an overflow. That is, when BVS follows a two's complement operation, a branch occurs when the result of the operation is invalid.

Rel is an 8-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 80$ to $\$ 7 \mathrm{~F}$ ( -128 to 127) from the address following the last byte of object code in the instruction.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| BVS rel8 | REL | 29 rr | PPP (branch) <br> P (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| BVS | 29 | No overflow | BVC | 28 | Overflow | Simple |
|  |  | V $=1$ |  |  |  |  |

## Call Subroutine in Expanded Memory

Operation
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}$
$\mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
(SP) - $\$ 0001 \Rightarrow$ SP
(PPAGE) $\Rightarrow \mathrm{M}_{\mathrm{SP}}$
new page value $\Rightarrow$ PPAGE
Subroutine address $\Rightarrow$ PC
Sets up conditions to return to normal program flow, then transfers control to a subroutine in expanded memory. Uses the address of the instruction following the CALL as a return address. For code compatibility, CALL also executes correctly in devices that do not have expanded memory capability.

Decrements SP by two, allowing the two return address bytes to be stacked.
Stacks the return address; SP points to the high byte of the return address.
Decrements SP by one, allowing the current PPAGE value to be stacked.
Stacks the value in PPAGE.
Writes a new page value supplied by the instruction to PPAGE.
Transfers control to the subroutine.
In indexed-indirect modes, the subroutine address and PPAGE value are fetched in the order M high byte, M low byte, and new PPAGE value.

Expanded-memory subroutines must be terminated by an RTC instruction, which restores the return address and PPAGE value from the stack.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

Code and CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CALL opr16a, page | EXT | 4A hh 11 pg | gnSsPPP |
| CALL oprx0_xysppc, page | IDX | 4 B xb pg | gnSspPr |
| CALL oprx9,xysppc, page | IDX1 | 4 Brb ff pg | gnSsPPP |
| CALL oprx16,xysppc, page | IDX2 | 4 B xb ee ff pg | fgnssprp |
| CALL [D,xysppc] | [D,IDX] | 4 B xb | fIignSsPPP |
| CALL [oprx16,xysppc] | [IDX2] | 4 Brb ee ff | fIignSsPPP |

## Compare B to A

Operation (A) - (B)
Compares the value in A with the value in B . Condition code bits affected by the comparison can be used for conditional branches. The values in A and B do not change.

CCR
Effects


N : Set if MSB of result is set; cleared otherwise
Z: Set if result is \$00; cleared otherwise
$\mathrm{V}: \mathrm{A} 7 \bullet \overline{\mathrm{~B} 7} \bullet \overline{\mathrm{R} 7} \mid \overline{\mathrm{A} 7} \bullet \mathrm{~B} 7 \bullet \mathrm{R} 7$; set if the operation produces a two's complement overflow; cleared otherwise
$C: \overline{A 7} \bullet B 7|B 7 \bullet R 7| R 7 \mid \overline{A 7}$; set if there is a borrow from the MSB of the result; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| CBA | INH | 1817 | 00 |

Operation $0 \Rightarrow \mathrm{C}$ bit
Clears the C bit. CLC assembles as ANDCC \#\$FE.
CLC can be used to initialize the C bit prior to a shift or rotate instruction affecting the C bit.
CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | 0 |

C: Cleared
Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| CLC | IMM | 10 FE | P |

Clear I
(same as ANDCC \#\$EF)

Operation $0 \Rightarrow$ I bit
Clears the I bit. CLI assembles as ANDCC \#\$EF.
Clearing the I bit enables interrupts. There is a one-cycle bus clock delay in the clearing mechanism. If interrupts were previously disabled, the next instruction after a CLI is always executed, even if there was an interrupt pending prior to execution of the CLI instruction.

CCR

## Effects



I: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| CLI | IMM | 10 EF | P |

Operation $\$ 00 \Rightarrow \mathrm{M}$
Clears all bits in M .

## CCR

## Effects



N: Cleared
Z: Set
V: Cleared
C: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CLR opr16a | EXT | 79 hh 11 | Pwo |
| CLR oprx0 xysppc | IDX | 69 xb | Pw |
| CLR oprx9,xysppc | IDX1 | 69 xb ff | Pwo |
| CLR oprx16,xysppc | IDX2 | 69 xb ee ff | PwP |
| CLR [D,xysppc] | [D,IDX] | 69 xb | PIfw |
| CLR [oprx16,xysppc] | [IDX2] | 69 xb ee ff | PIPw |

Clear A

Operation $\quad \$ 00 \Rightarrow \mathrm{~A}$
Clears all bits in A.

| S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | 1 | 0 | 0 |

N: Cleared
Z: Set
V: Cleared
C: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| CLRA | INH | 87 | 0 |

User Guide - S12CPu15tuters.scale Semiconductor, Inc.

Clear B
CLRB
Operation $\$ 00 \Rightarrow B$
Clears all bits in B .

| S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | 1 | 0 | 0 |

N: Cleared
Z: Set
V: Cleared
C: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| CLRB | INH | C7 | 0 |

Clear V
(same as ANDCC \#\$FD)
Operation $0 \Rightarrow \mathrm{~V}$ bit
Clears the V bit. CLV assembles as ANDCC \#\$FD.
CCR
Effects


V: Cleared
Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| CLV | IMM | 10 FD | P |

## Compare A

(A) - (M)
or
(A) - imm

Compares the value in A to either the value in M or an immediate value. CCR bits reflect the result. The values in A and M do not change.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: A7•M7• $\overline{R 7} \mid \overline{A 7} \bullet M 7 \bullet R 7$; set if the operation produces a two's complement overflow; cleared otherwise
$C: \overline{A 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if there is a borrow from the MSB of the result; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CMPA \#opr8i | IMM | 81 ii | P |
| CMPA opr8a | DIR | 91 dd | rPf |
| CMPA opr16a | EXT | B1 hh 11 | rPo |
| CMPA oprx0_xysppc | IDX | A1 xb | rPf |
| CMPA oprx9,xysppc | IDX1 | A1 xb ff | rPo |
| CMPA oprx $16, x y$ sppc | IDX2 | A1 xb ee ff | frpp |
| CMPA [D, xysppc] | [D,IDX] | A1 xb | fifrPf |
| CMPA [oprx16,xysppc] | [IDX2] | A1 xb ee ff | fIPrPf |

## Compare B

(B) - (M)
or
(B) -imm

Compares the value in B to either the value in M or an immediate value. CCR bits reflect the result. The values in $B$ and $M$ do not change.

CCR

## Effects

| S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{B7} \bullet \overline{\mathrm{M7}} \bullet \overline{\mathrm{R7}} \mid \overline{\mathrm{B7}} \bullet \mathrm{M} 7 \bullet \mathrm{R}$; set if the operation produces a two's complement overflow; cleared otherwise
$C: \overline{B 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{B 7}$; set if there is a borrow from the MSB of the result; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CMPB \#opr8i | IMM | C1 ii | P |
| CMPB opr8a | DIR | D1 dd | rPf |
| CMPB opr16a | EXT | F1 hh 11 | rPO |
| CMPB oprxO_xysppc | IDX | E1 xb | rPf |
| CMPB oprx9,xysppc | IDX1 | E1 xb ff | rPo |
| CMPB oprx16,xysppc | IDX2 | E1 xb ee ff | frPP |
| CMPB [D,xysppc] | [D,IDX] | E1 xb | fifrPf |
| CMPB [oprx16,xysppc] | [IDX2] | E1 xb ee ff | fiprPf |

## Complement M

Operation $\quad(\overline{\mathrm{M}})=\$ \mathrm{FF}-(\mathrm{M}) \Rightarrow \mathrm{M}$
Replaces the value in $M$ with its one's complement. Immediately after a COM operation on unsigned values, only the BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. After operation on two's complement values, all signed branches are available.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
C: Set for M6800 compatibility
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| COM opr16a | EXT | 71 hh 11 | rPwo |
| COM oprx0_xysppc | IDX | 61 xb | rPw |
| COM oprx9,xysppc | IDX1 | 61 xb ff | rPwo |
| COM oprx16,xysppc | IDX2 | 61 xb ee ff | frPwP |
| COM [D,xysppc] | [D,IDX] | $61 \times \mathrm{xb}$ | fIfrPw |
| COM [oprx16,xysppc] | [IDX2] | 61 xb ee ff | fIPrPw |

Operation $\quad(\overline{\mathrm{A}})=\$ \mathrm{FF}-(\mathrm{A}) \Rightarrow \mathrm{A}$
Replaces the value in A with its one's complement. Immediately after a COM operation on unsigned values, only the BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. After operation on two's complement values, all signed branches are available.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
C: Set for M6800 compatibility
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| COMA | INH | 41 | 0 |

$$
(\overline{\mathrm{B}})=\$ \mathrm{FF}-(\mathrm{B}) \Rightarrow \mathrm{B}
$$

Replaces the value in B with its one's complement. Each bit of B is complemented. Immediately after a COM operation on unsigned values, only the BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. After operation on two's complement values, all signed branches are available.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
C: Set for M6800 compatibility
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| COMB | INH | 51 | 0 |

Compare D
(A):(B) - (M):(M + 1)
or
(A:B) - imm
Compares the value in D to either the value in $\mathrm{M}: \mathrm{M}+1$ or an immediate value. CCR bits reflect the result. The values in D and $\mathrm{M}: \mathrm{M}+1$ do not change.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: D15 • M15 • R15 | $\overline{\mathrm{D} 15} \bullet$ M15 •R15; set if the operation produces a two's complement overflow; cleared otherwise
C: $\overline{\mathrm{D} 15} \bullet \mathrm{M} 15|\mathrm{M} 15 \bullet R 15| R 15 \bullet \overline{D 15}$; set if the absolute value of $(\mathrm{M}: \mathrm{M}+1)$ is larger than the absolute value of (D); cleared otherwise

Code and CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CPD \#opr16i | IMM | 8C jj kk | PO |
| CPD opr8a | DIR | 9 Cdd | RPf |
| CPD opr16a | EXT | BC hh 11 | RPO |
| CPD oprx0_xysppc | IDX | AC xb | RPf |
| CPD oprx9,xysppc | IDX1 | AC xb ff | RPO |
| CPD oprx16,xysppc | IDX2 | AC xb ee ff | fRPP |
| CPD [D,xysppc] | [D,IDX] | AC xb | fifRPf |
| CPD [oprx16,xysppc] | [IDX2] | AC xb ee ff | fIPRPf |

Operation (SP) - (M): $(\mathrm{M}+1)$
or
(SP) - imm
Compares the value in SP to either the value in $\mathrm{M}: \mathrm{M}+1$ or an immediate value. CCR bits reflect the result. The values in SP and $\mathrm{M}: \mathrm{M}+1$ do not change.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: SP15 • M15 • R15 | SP15 • M15 • R15; set if the operation produces a two's complement overflow; cleared otherwise
C: $\overline{\mathrm{SP} 15} \bullet \mathrm{M} 15|\mathrm{M} 15 \bullet \mathrm{R} 15| \mathrm{R} 15 \bullet \overline{\mathrm{SP} 15}$; set if the absolute value of $(\mathrm{M}: \mathrm{M}+1)$ is larger than the absolute value of (SP); cleared otherwise

Code and CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CPS \#opr16i | IMM | 8F jj kk | PO |
| CPS opr8a | DIR | 9F dd | RPf |
| CPS opr16a | EXT | BF hh ll | RPO |
| CPS oprx0_xysppc | IDX | AF xb | RPf |
| CPS oprx9,xysppc | IDX1 | AF xb ff | RPO |
| CPS oprx16,xysppc | IDX2 | AF xb ee ff | fRPP |
| CPS [D,xysppc] | [D,IDX] | AF xb | fIfRPf |
| CPS [oprx16,xysppc] | [IDX2] | AF xb ee ff | fIPRPf |

Compare X

Operation
$(\mathrm{X})-(\mathrm{M}):(\mathrm{M}+1)$
or
(X) - imm

Compares the value in X to either the value in $\mathrm{M}: \mathrm{M}+1$ or an immediate value. CCR bits reflect the result. The values in X and $\mathrm{M}: \mathrm{M}+1$ do not change.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: X15 • $\overline{\mathrm{M} 15} \bullet \overline{\mathrm{R} 15 \mid \overline{\mathrm{X}} 5}$ • M15 •R15; set if the operation produces a two's complement overflow; cleared otherwise
C: $\overline{X 15} \bullet \mathrm{M} 15|M 15 \bullet R 15| R 15 \bullet \overline{X 15}$; set if the absolute value of $(M: M+1)$ is larger than the absolute value of (X); cleared otherwise

Code and CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CPX \#opr16i | IMM | 8E j j kk | PO |
| CPX opr8a | DIR | 9 Edd | RPf |
| CPX opr16a | EXT | BE hh 11 | RPO |
| CPX oprx0_xysppc | IDX | AE xb | RPf |
| CPX oprx9,xysppc | IDX1 | AE xb ff | RPO |
| CPX oprx16,xysppc | IDX2 | AE xb ee ff | fRPP |
| CPX [D, xysppc] | [D,IDX] | AE xb | fifRPf |
| CPX [oprx16,xysppc] | [IDX2] | AE xb ee ff | fIPRPf |

## Compare Y

Operation (Y) - (M):(M+1)
or
(Y) - imm

Compares the value in Y to either the value in $\mathrm{M}: \mathrm{M}+1$ or an immediate value. CCR bits reflect the result. The values in Y and $\mathrm{M}: \mathrm{M}+1$ do not change.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 0000$; cleared otherwise
V: Y15 • $\overline{\mathrm{M} 15} \bullet \overline{\mathrm{R} 15} \mid \overline{\mathrm{Y} 15} \bullet \mathrm{M} 15 \bullet \mathrm{R} 15$; set if the operation produces a two's complement overflow; cleared otherwise
$\mathrm{C}: \overline{\mathrm{Y} 15} \bullet \mathrm{M} 15|\mathrm{M} 15 \bullet \mathrm{R} 15| \mathrm{R} 15 \bullet \overline{\mathrm{Y} 15}$; set if the absolute value of $(\mathrm{M}: \mathrm{M}+1)$ is larger than the absolute value of $(\mathrm{Y})$; cleared otherwise

Code and CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| CPY \#opr16i | IMM | 8D jj kk | PO |
| CPY opr8a | DIR | 9D dd | RPf |
| CPY opr16a | EXT | BD hh 11 | Rpo |
| CPY oprx0_xysppc | IDX | AD xb | RPf |
| CPY oprx9,xysppc | IDX1 | AD xb ff | RPO |
| CPY oprx16,xysppc | IDX2 | AD xb ee ff | fRPP |
| CPY [D, xysppc] | [D,IDX] | AD xb | fIfRPf |
| CPY [oprx16,xysppc] | [IDX2] | AD xb ee ff | fIPRPf |

DAA adjusts the value in A and the state of the C bit to represent the correct binary-coded-decimal (BCD) sum and the associated carry when a BCD calculation is performed. To execute DAA, the value in A, the state of the C bit, and the state of the H bit must all be the result of performing an $\mathrm{ABA}, \mathrm{ADD}$, or ADC on BCD operands, with or without an initial carry.

The table below shows DAA operation for all legal combinations of input operands. The first four columns represent the results of $\mathrm{ABA}, \mathrm{ADC}$, or ADD operations on BCD operands. The correction factor in the fifth column is added to the accumulator to restore the result of an operation on two BCD operands to a valid BCD value and to set or clear the C bit. All values are in hexadecimal.

| C Value | A[7:6:5:4] Value | H Value | A[3:2:1:0] Value | Correction | Corrected C bit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $0-9$ | 0 | $0-9$ | 00 | 0 |
| 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 |

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 00$; cleared otherwise
C: Represents BCD carry
Code and

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DAA | INH | 1807 | Ofo |

(counter) - $1 \Rightarrow$ counter
If $($ counter $)=0$, then $(P C)+\$ 0003+$ rel $\Rightarrow \mathrm{PC}$
Subtracts one from the counter register A, B, D, X, Y, or SP. Branches to a relative destination if the counter register reaches zero. Rel is a 9-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 100$ to $\$ 0 \mathrm{FF}$ ( -256 to +255 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DBEQ abdxysp, re/9 | REL <br> (9-bit) | 04 lb rr | PPP (branch) <br> PPO (no branch) |


| Loop Primitive Postbyte (1b) Coding |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte ${ }^{1}$ | Object Code | Counter Register | Offset |
| DBEQ A, rel9 DBEQ B, rel9 DBEQ D, rel9 DBEQ X, rel9 DBEQ Y, rel9 DBEQ SP, rel9 | $0000 \times 000$ <br> $0000 \times 001$ <br> $0000 \times 100$ <br> $0000 \times 101$ <br> $0000 \times 110$ <br> $0000 \times 111$ | $\begin{aligned} & 0400 \mathrm{rr} \\ & 04001 \mathrm{rr} \\ & 04004 r \\ & 0405 \mathrm{rr} \\ & 04006 \mathrm{rr} \\ & 0407 \mathrm{rr} \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { B } \\ & \text { D } \\ & \text { X } \\ & \text { Y } \\ & \text { SP } \end{aligned}$ | Positive |
| DBEQ A, re/9 DBEQ B, rel9 DBEQ D, rel9 DBEQ X, rel9 DBEQ Y, rel9 DBEQ SP, rel9 | $\begin{aligned} & \text { O001 X000 } \\ & 0001 \text { X001 } \\ & 0001 \text { X100 } \\ & 0001 \text { X101 } \\ & 0001 \text { X110 } \\ & 0001 \text { X111 } \end{aligned}$ |  | $\begin{aligned} & \text { A } \\ & \text { B } \\ & D \\ & \text { X } \\ & \text { Y } \\ & \text { SP } \end{aligned}$ | Negative |

NOTES:

1. Bits 7:6:5 select DBEQ or DBNE; bit 4 is the offset sign bit: bit 3 is not used; bits 2:1:0 select the counter register.

Operation (counter) - $1 \Rightarrow$ counter
If (counter) not $=0$, then $(\mathrm{PC})+\$ 0003+\mathrm{rel} \Rightarrow \mathrm{PC}$
Subtracts one from the counter register A, B, D, X, Y, or SP. Branches to a relative destination if the counter register does not reach zero. Rel is a 9-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 100$ to $\$ 0 \mathrm{FF}$ $(-256$ to +255$)$ from the address following the last byte of object code in the instruction.

## CCR

## Effects



Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DBNE abdxysp, rel9 | REL <br> (9-bit) | 04 lb rr | PPP (branch) <br> PPO (no branch) |


| Loop Primitive Postbyte (1b) Coding |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte ${ }^{1}$ | Object Code | Counter Register | Offset |
| DBNE A, rel9 DBNE B, rel9 DBNE D, rel9 DBNE X, rel9 DBNE Y, rel9 DBNE SP, rel9 | 0010 X000 0010 X001 0010 X100 0010 X101 0010 X110 0010 X111 | $\begin{array}{lll} 04 & 20 r r \\ 04 & 21 & r r \\ 04 & 24 & r r \\ 04 & 25 r r \\ 04 & 26 r r \\ 04 & 27 r r \end{array}$ | $\begin{aligned} & \text { A } \\ & \text { B } \\ & \text { D } \\ & \text { X } \\ & \text { Y } \\ & \text { SP } \end{aligned}$ | Positive |
| DBNE A, rel9 DBNE B, rel9 DBNE D, rel9 DBNE X, rel9 DBNE Y, rel9 DBNE SP, rel9 | 0011 X000 <br> 0011 X001 <br> 0011 X100 <br> 0011 X101 <br> 0011 X110 <br> 0011 X111 | $\begin{array}{lll} 04 & 30 \mathrm{rr} \\ 04 & 31 & \mathrm{rr} \\ 04 & 34 \mathrm{rr} \\ 04 & 35 \mathrm{rr} \\ 04 & 36 \mathrm{rr} \\ 04 & 37 \mathrm{rr} \end{array}$ | $\begin{aligned} & A \\ & B \\ & D \\ & X \\ & Y \\ & \text { YP } \end{aligned}$ | Negative |

NOTES:

1. Bits $7: 6: 5$ select DBEQ or DBNE; bit 4 is the offset sign bit: bit 3 is not used; bits 2:1:0 select the counter register.

## Decrement M

Operation $\quad(\mathrm{M})-\$ 01 \Rightarrow \mathrm{M}$
Subtracts one from the value in M. The N, Z, and V bits are set or cleared by the operation. The C bit is not affected by the operation, allowing the DEC instruction to be used as a loop counter in multiple-precision computations.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{l}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Set if operation produces a two's complement overflow (if and only if ( $M$ ) was $\$ 80$ before the operation); cleared otherwise

Code and CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| DEC opr16a | EXT | 73 hh 11 | rPwo |
| DEC oprxo_xysppc | IDX | 63 xb | rPw |
| DEC oprx9,xysppc | IDX1 | 63 xb ff | rPwo |
| DEC oprx16,xysppc | IDX2 | 63 xb ee ff | frPwP |
| DEC [D, xysppc] | [D,IDX] | 63 xb | fIfrPw |
| DEC [oprx16,xysppc] | [IDX2] | 63 xb ee ff | fIPrPw |

## Decrement A

Operation (A) - $\$ 01 \Rightarrow \mathrm{~A}$
Subtracts one from the value in A. The N, Z, and V bits are set or cleared by the operation. The C bit is not affected by the operation, allowing the DEC instruction to be used as a loop counter in multiple-precision computations.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Set if operation produces a two's complement overflow (if and only if (A) was $\$ 80$ before the operation); cleared otherwise

Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DECA | INH | 43 | 0 |

## Decrement B

(B) $-\$ 01 \Rightarrow B$

Subtracts one from the value in B. The N, Z, and V bits are set or cleared by the operation. The C bit is not affected by the operation, allowing the DEC instruction to be used as a loop counter in multiple-precision computations.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Set if operation produces a two's complement overflow (if and only if (B) was $\$ 80$ before the operation); cleared otherwise

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DECB | INH | 53 | 0 |

Operation (SP) - \$0001 $\Rightarrow$ SP
Subtracts one from SP. DES assembles as LEAS -1,SP. DES does not affect condition code bits as DEX and DEY do.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DES | IDX | 1B 9F | Pf |

## Decrement X

Operation $\quad(X)-\$ 0001 \Rightarrow X$
Subtracts one from $X$. The $Z$ bit reflects the result. The LEAX $-1, X$ instruction does the same thing as DEX, but without affecting the Z bit.

CCR
Effects


Z: Set if result is $\$ 0000$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DEX | INH | 09 | 0 |

## Decrement $Y$

Operation $\quad(\mathrm{Y})-\$ 0001 \Rightarrow \mathrm{Y}$
Subtracts one from Y. The Z bit reflects the result. The LEAY $-1, \mathrm{Y}$ instruction does the same thing as DEY, but without affecting the Z bit.

CCR
Effects


Z: Set if result is $\$ 0000$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| DEY | INH | 03 | 0 |

Operation $\quad(\mathrm{Y}):(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{Y}$; remainder $\Rightarrow \mathrm{D}$
Divides a 32-bit unsigned dividend by a 16-bit divisor, producing a 16-bit unsigned quotient and an unsigned 16-bit remainder. All operands and results are located in CPU registers. Division by zero has no effect, except that the states of the N, Z, and V bits are undefined.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise; undefined after overflow or division by 0
Z: Set if result is $\$ 0000$; cleared otherwise; undefined after overflow or division by 0
V: Set if the result is greater than \$FFFF; cleared otherwise; undefined after division by 0
C: Set if divisor is $\$ 0000$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| EDIV | INH | 11 | fffffffffffo |

Operation $\quad(\mathrm{Y}):(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{Y}$; remainder $\Rightarrow \mathrm{D}$
Divides a signed 32 -bit dividend by a 16-bit signed divisor, producing a signed 16 -bit quotient and a signed 16-bit remainder. All operands and results are located in CPU registers. Division by zero has no effect, except that the C bit is set and the states of the N , Z , and V bits are undefined.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{l}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

N: Set if MSB of result is set; cleared otherwise; undefined after overflow or division by 0
Z: Set if result is $\$ 0000$; cleared otherwise; undefined after overflow or division by 0
V : Set if the result is greater than $\$ 7$ FFF or less than $\$ 8000$; cleared otherwise; undefined after division by 0
C: Set if divisor is $\$ 0000$; cleared otherwise; indicates division by 0
Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| EDIVS | INH | 1814 | Offffffffffo |

Operation
$\left(\mathrm{M}_{\mathrm{X}}\right):\left(\mathrm{M}_{\mathrm{X}+1}\right) \times\left(\mathrm{M}_{\mathrm{Y}}\right):\left(\mathrm{M}_{\mathrm{Y}+1}\right)+(\mathrm{M}):(\mathrm{M}+1):(\mathrm{M}+2):(\mathrm{M}+3) \Rightarrow \mathrm{M}+1: \mathrm{M}+2: \mathrm{M}+3$
Multiplies two 16 -bit values. Adds the 32 -bit product to the value in a 32 -bit accumulator in memory. EMACS is a signed integer operation. All operands and results are located in memory. X must point to the high byte of the first source operand, and Y must point to the high byte of the second source operand. An extended address supplied with the instruction must point to the most significant byte of the 32-bit result.

## CCR

Effects


N: Set if MSB of result, R31, is set; cleared otherwise
Z: Set if result is \$00000000; cleared otherwise
V: M31 •I31 • R31 | $\overline{\text { M31 }} \bullet \overline{131} \bullet$ R31; set if result is greater than \$7FFFFFFF (+ overflow) or less than \$80000000 (- underflow); indicates two's complement overflow
C: M15 • I15 | I15 • $\overline{\mathrm{R} 15} \mid \overline{\mathrm{R} 15} \cdot \mathrm{M} 15$; set if there is a carry from bit 15 of the result, R15; cleared otherwise; indicates a carry from low word to high word of the result

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :---: |
| EMACS opr16a | Special | 1812 hh 11 | ORROfffRRfWWP |

NOTES:

1. opr16a is an extended address specification. Both $X$ and $Y$ point to source operands.

MAX [(D), $(\mathrm{M}):(\mathrm{M}+1)] \Rightarrow \mathrm{D}$
Subtracts an unsigned 16-bit value in $\mathrm{M}: \mathrm{M}+1$ from an unsigned 16-bit value in D to determine which is larger. Puts the larger value in D . If the values are equal, the Z bit is set. If the value in $M: M+1$ is larger, the $C$ bit is set when the value in $M: M+1$ replaces the value in D . If the value in D is larger, the C bit is cleared.

EMAXD accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate finding the largest value in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: D15 • M15 • $\mathrm{R} 15 \mid \overline{\mathrm{D} 15} \bullet \mathrm{M} 15 \bullet$ R15; set if the operation produces a two's complement overflow; cleared otherwise
C: $\overline{\mathrm{D} 15} \bullet \mathrm{M} 15|\mathrm{M15} \bullet \mathrm{R} 15| \mathrm{R} 15 \bullet \overline{\mathrm{D} 15}$; set if $(\mathrm{M}):(\mathrm{M}+1)$ is larger than (D); cleared otherwise
Condition code bits reflect internal subtraction: $R=(D)-(M):(M+1)$.
Code and
CPU Cycles


MAX [(D), (M):(M + 1)] $\Rightarrow \mathrm{M}: \mathrm{M}+1$
Subtracts an unsigned 16-bit value in M:M+1 from an unsigned 16-bit value in D to determine which is larger. Puts the larger value in $\mathrm{M}: \mathrm{M}+1$. If the values are equal, the Z bit is set. If the value in $\mathrm{M}: \mathrm{M}+1$ is larger, the C bit is set. If the value in D is larger, the C bit is cleared when the value in D replaces the value in $\mathrm{M}: \mathrm{M}+1$.

EMAXM accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate controlling the values in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: D15 $\bullet \overline{\mathrm{M} 15} \bullet \overline{\mathrm{R} 15} \mid \overline{\mathrm{D} 15} \bullet \mathrm{M} 15 \bullet$ R15; set if the operation produces a two's complement overflow; cleared otherwise
C: $\overline{\mathrm{D} 15} \bullet \mathrm{M15}|\mathrm{M} 15 \bullet R 15| R 15 \bullet \overline{\mathrm{D} 15}$; set if $(\mathrm{M}):(\mathrm{M}+1)$ is larger than (D); cleared otherwise
Condition code bits reflect internal subtraction: $R=(D)-(M):(M+1)$.
Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| EMAXM oprx0_xysppc | IDX | 181 E xb | ORPW |
| EMAXM oprx9,xysppc | IDX1 | 18 <br> IE xb ff <br> EMAXM oprx16,xysppc <br> IDX2 <br> EMAXM [D,xysppc] <br> EMAXM [oprx16,xysppc] | ID, IDX] <br> [IDX2] |

MIN [(D), (M):(M + 1)] $\Rightarrow \mathrm{D}$
Subtracts an unsigned 16-bit value in $\mathrm{M}: \mathrm{M}+1$ from an unsigned 16-bit value in D to determine which is larger. Puts the smaller value in D . If the values are equal, the Z bit is set. If the value in $M: M+1$ is larger, the $C$ bit is set. If the value in $D$ is larger, the $C$ bit is cleared when the value in $M: M+1$ replaces the value in $D$.

EMIND accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate finding the smallest value in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: D15 • M15 • $\overline{\mathrm{R} 15 \mid \overline{\mathrm{D} 15} \bullet \mathrm{M} 15 \cdot R 15 \text {; set if the operation produces a two's complement overflow; cleared }}$ otherwise
C: $\overline{\mathrm{D} 15} \bullet \mathrm{M15}|\mathrm{M} 15 \bullet R 15| R 15 \bullet \overline{\mathrm{D} 15}$; set if $(\mathrm{M}):(\mathrm{M}+1)$ is larger than (D); cleared otherwise
Condition code bits reflect internal subtraction: $R=(D)-(M):(M+1)$.
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| EMIND oprxo_xysppc | IDX | 18 1B xb | ORPf |
| EMIND oprx9,xysppc | IDX1 | 181 Bxb ff | ORPO |
| EMIND oprx16,xysppc | IDX2 | 181 Bxb ee ff | OfRPP |
| EMIND [D, xysppc] | [D,IDX] | 18 1B xb | OfIfRPf |
| EMIND [oprx16,xysppc] | [IDX2] | 181 Brb ee ff | OfIPRPf |

$\operatorname{MIN}[(\mathrm{D}),(\mathrm{M}):(\mathrm{M}+1)] \Rightarrow \mathrm{M}: \mathrm{M}+1$
Subtracts an unsigned 16-bit value in $\mathrm{M}: \mathrm{M}+1$ from an unsigned 16-bit value in D to determine which is larger. Puts the smaller value in $\mathrm{M}: \mathrm{M}+1$. If the values are equal, the Z bit is set. If the value in $\mathrm{M}: \mathrm{M}+1$ is larger, the C bit is set when the value in D replaces the value in $\mathrm{M}: \mathrm{M}+1$. If the value in D is larger, the C bit is cleared.

EMINM accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate finding the smallest value in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: D15 • M15 • $\mathrm{R} 15 \mid \overline{\mathrm{D} 15} \bullet \mathrm{M} 15 \bullet$ R15; set if the operation produces a two's complement overflow; cleared otherwise
C: $\overline{\mathrm{D} 15} \bullet \mathrm{M} 15|\mathrm{M15} \bullet \mathrm{R} 15| \mathrm{R} 15 \bullet \overline{\mathrm{D} 15}$; set if $(\mathrm{M}):(\mathrm{M}+1)$ is larger than (D); cleared otherwise
Condition code bits reflect internal subtraction: $R=(D)-(M):(M+1)$.
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| EMINM oprxo_xysppc | IDX | 181 Fxb | ORPW |
| EMINM oprx9,xysppc | IDX1 | 181 Fxb ff | ORPWO |
| EMINM oprx16,xysppc | IDX2 | 181 Fxb ee ff | OfRPWP |
| EMINM [D, xysppc] | [D,IDX] | 181 Fxb | OfIfRPW |
| EMINM [oprx16,xysppc] | [IDX2] | 181 Fxb ee ff | OfIPRPW |

## Extended Multiply, Unsigned

$(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D}$
Multiplies an unsigned 16-bit value in D by an unsigned 16-bit value in Y . Puts the high 16-bits of the unsigned 32 -bit result in Y and the low 16 -bits of the result in D.

The C bit can be used to round the low 16 bits of the result.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  |  |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |  |  |  |  |
| - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |

N: Set if the MSB of the result is set; cleared otherwise
Z: Set if result is $\$ 00000000$; cleared otherwise
C: Set if bit 15 of the result is set; cleared otherwise
Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| EMUL | INH | 13 | ffO |

$(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D}$
Multiplies a signed 16-bit value in D by a signed 16-bit value in Y. Puts the high 16 bits of the 32-bit signed result in Y and the low 16 bits of the result in D.

The C bit can be used to round the low 16 bits of the result.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |

N: Set if the MSB of the result is set; cleared otherwise
Z: Set if result is $\$ 00000000$; cleared otherwise
C: Set if bit 15 of the result is set; cleared otherwise
Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| EMULS | INH | 1813 | OfO <br> OffO |

NOTES:

1. EMULS has an extra free cycle if it is followed by another page two instruction.

## Exclusive OR A

$(\mathrm{A}) \oplus(\mathrm{M}) \Rightarrow \mathrm{A}$
or
(A) $\oplus \mathrm{imm} \Rightarrow \mathrm{A}$

Performs a logical exclusive OR of the value in A and either the value in M or an immediate value. Puts the result in A.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| EORA \#opr8i | IMM | 88 ii | P |
| EORA opr8a | DIR | 98 dd | rPf |
| EORA opr16a | EXT | B8 hh 11 | rPO |
| EORA oprx0_xysppc | IDX | A8 xb | rPf |
| EORA oprx9,xysppc | IDX1 | A8 xb ff | rPo |
| EORA oprx16,xysppc | IDX2 | A8 xb ee ff | frPP |
| EORA [D, xysppc] | [D,IDX] | A8 xb | fifrpf |
| EORA [oprx16,xysppc] | [IDX2] | A8 xb ee ff | fIPrPf |

## Exclusive OR B with M

$(\mathrm{B}) \oplus(\mathrm{M}) \Rightarrow \mathrm{B}$
or
(B) $\oplus \mathrm{imm} \Rightarrow \mathrm{B}$

Performs a logical exclusive OR of the value in B and either the value in M or an immediate value. Puts the result in $B$.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| EORB \#opr8i | IMM | C8 ii | P |
| EORB opr8a | DIR | D8 dd | rPf |
| EORB opr16a | EXT | F8 hh 11 | rPo |
| EORB oprx0_xysppc | IDX | E8 xb | rPf |
| EORB oprx9,xysppc | IDX1 | E8 xb ff | rPo |
| EORB oprx16,xysppc | IDX2 | E8 xb ee ff | frPP |
| EORB [D,xysppc] | [D,IDX] | E8 xb | fifrPf |
| EORB [oprx16,xysppc] | [IDX2] | E8 xb ee ff | fiprPf |

$(M):(M+1)+[(B) \times((M+2):(M+3)-(M):(M+1))] \Rightarrow D$
Linearly interpolates and stores in D one of 256 values between a pair of data entries, Y1 and Y2, in a lookup table. Data entries represent y coordinates of line segment endpoints. Table entries and the interpolated results are 16-bit values.

Before executing ETBL, point an indexing register at the Y1 value closest to but less than or equal to the Y value to interpolate. Point to Y1 using any indexed addressing mode except indirect, 9-bit offset, and 16-bit offset. The next table entry after Y1 is Y2. Load B with a
binary fraction (radix point to the left of the MSB) representing the and 16-bit offset. The next table entry after Y1 is Y2. Load B with a
binary fraction (radix point to the left of the MSB) representing the ratio:

$(\mathrm{XL}-\mathrm{X} 1) \div(\mathrm{X} 2-\mathrm{X} 1)$
where
$\mathrm{X} 1=\mathrm{Y} 1$ and $\mathrm{X} 2=\mathrm{Y} 2$
XL is the x coordinate of the value to interpolate
The 16-bit unrounded result, YL, is calculated using the expression:
$\mathrm{YL}=\mathrm{Y} 1+[(\mathrm{B}) \times(\mathrm{Y} 2-\mathrm{Y} 1)]$
where
$\mathrm{Y} 1=16$-bit data entry pointed to by effective address
Y2 $=16$-bit data entry pointed to by the effective address plus two
The 24 -bit intermediate value $(\mathrm{B}) \times(\mathrm{Y} 2-\mathrm{Y} 1)$ has a radix point between bits 7 and 8 .
CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
C: Set if result can be rounded up; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ETBL oprx0_xysppc | IDX | 183 Fxb | ORRffffffp |

## Exchange Register Contents

Operation $\quad(\mathrm{r} 1) \Leftrightarrow(\mathrm{r} 2)$ when r 1 and r 2 are the same size
$\$ 00:(\mathrm{r} 1) \Rightarrow(\mathrm{r} 2)$ when r 1 is 8 bits and r 2 is 16 bits
$\left(\mathrm{rl}_{\mathrm{L}}\right) \Leftrightarrow(\mathrm{r} 2)$ when r 1 is 16 bits and r 2 is 8 bits
See the table on the next page.
Exchanges the values between a source register A, B, CCR, D, X, Y, or SP and a destination register A, B, CCR, D, X, Y, or SP. Exchanges involving TMP2 and TMP3 are reserved for Motorola use.

CCR
Effects


CCR bits affected only when the CCR is the destination register. The $X$ bit cannot change from 0 to 1 .
Software can leave the $X$ bit set, leave it cleared, or change it from 1 to 0 , but $X$ can only be set by a reset or by recognition of an XIRQ interrupt.

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| EXG $a b c d x y s p, a b c d x y s p$ | INH | B7 eb | P |

Exchange Register Contents
(continued)

| Exchange Postbyte (eb) Coding |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte | Object Code | Exchange | Source Form | Postbyte | Object Code | Exchange |
| EXG A,A <br> EXG A,B <br> EXG A,CCR <br> EXG A,TMP2 <br> EXG A,D <br> EXG A, X <br> EXG A,Y <br> EXG A,SP | $\begin{aligned} & 1000 \times 000 \\ & 1000 \times 001 \\ & 1000 \times 010 \\ & 1000 \times 011 \\ & 1000 \times 100 \\ & 1000 \times 101 \\ & 1000 \times 110 \\ & 1000 \times 111 \end{aligned}$ | $\begin{array}{ll} \text { B7 } & 80 \\ \text { B7 } & 81 \\ \text { B7 } & 82 \\ \text { B7 } & 83 \\ \text { B7 } & 84 \\ \text { B7 } & 85 \\ \text { B7 } & 86 \\ \text { B7 } & 87 \end{array}$ | $\begin{aligned} & A \Leftrightarrow A \\ & A \Leftrightarrow B \\ & A \Leftrightarrow C C R \\ & \$ 00: A \Rightarrow T M P 2, T M P 2_{L} \Rightarrow A \\ & \$ 00: A \Rightarrow D \\ & \$ 00: A \Rightarrow X, X_{L} \Rightarrow A \\ & \$ 00: A \Rightarrow Y, Y_{L} \Rightarrow A \\ & \$ 00: A \Rightarrow S P, S P_{L} \Rightarrow A \end{aligned}$ | EXG B,A <br> EXG B,B <br> EXG B,CCR <br> EXG D,TMP2 <br> EXG D,D <br> EXG D, X <br> EXG D,Y <br> EXG D,SP | $\begin{aligned} & 1100 \text { X000 } \\ & 1100 \text { X001 } \\ & 1100 \text { X010 } \\ & 1100 \text { X011 } \\ & 1100 \text { X100 } \\ & 1100 \text { X101 } \\ & 1100 \text { X110 } \\ & 1100 \text { X111 } \end{aligned}$ | B7 C0 <br> B7 C1 <br> B7 C2 <br> B7 C3 <br> B7 C4 <br> B7 C5 <br> B7 C6 <br> B7 C7 | $\begin{aligned} & B \Rightarrow A, A \Rightarrow B \\ & B \Rightarrow B, \$ F F \Rightarrow A \\ & B \Rightarrow C C R, \$ F F: C C R \Rightarrow D \\ & D \Leftrightarrow T M P 2 \\ & D \Leftrightarrow D \\ & D \Leftrightarrow X \\ & D \Leftrightarrow Y \\ & D \Leftrightarrow S P \end{aligned}$ |
| EXG B,A <br> EXG B,B <br> EXG B,CCR <br> EXG B,TMP2 <br> EXG B,D <br> EXG B,X <br> EXG B,Y <br> EXG B,SP | $\begin{array}{\|l\|} 1001 \text { X000 } \\ 1001 \text { X001 } \\ 1001 \text { X010 } \\ 1001 \text { X011 } \\ 1001 \text { X100 } \\ 1001 \text { X101 } \\ 1001 \text { X110 } \\ 1001 \text { X111 } \end{array}$ | $\left\lvert\, \begin{array}{ll} \text { B7 } & 90 \\ \text { B7 } & 91 \\ \text { B7 } & 92 \\ \text { B7 } & 93 \\ \text { B7 } & 94 \\ \text { B7 } & 95 \\ \text { B7 } & 96 \\ \text { B7 } & 97 \end{array}\right.$ | $\begin{array}{\|l\|} \hline B \Leftrightarrow A \\ B \Leftrightarrow B \\ B \Leftrightarrow C C R \\ \$ 00: B \Rightarrow T M P 2, T M P 2_{L} \Rightarrow B \\ \$ 00: B \Rightarrow D \\ \$ 00: B \Rightarrow X, X_{L} \Rightarrow B \\ \$ 00: B \Rightarrow Y, Y_{L} \Rightarrow B \\ \$ 00: B \Rightarrow S P, S P_{L} \Rightarrow B \end{array}$ | EXG X,A <br> EXG X,B <br> EXG X,CCR <br> EXG X,TMP2 <br> EXG X,D <br> EXG X,X <br> EXG X,Y <br> EXG X,SP | $\begin{aligned} & \text { 1101 X000 } \\ & 1101 \text { X001 } \\ & 1101 \text { X010 } \\ & 1101 \text { X011 } \\ & 1101 \times 100 \\ & 1101 \times 101 \\ & 1101 \times 110 \\ & 1101 \text { X111 } \end{aligned}$ | B7 D0 <br> B7 D1 <br> B7 D2 <br> B7 D3 <br> B7 D4 <br> B7 D5 <br> B7 D6 <br> B7 D7 | $\begin{aligned} & X_{L} \Rightarrow A, \$ 00: A \Rightarrow X \\ & X_{L} \Rightarrow B, \$ F F: B \Rightarrow X \\ & X_{L} \Rightarrow C C R, \$ F F: C C R \Rightarrow X \\ & X \Leftrightarrow T M P 2 \\ & X \Leftrightarrow D \\ & X \Leftrightarrow X \\ & X \Leftrightarrow Y \\ & X \Leftrightarrow S P \end{aligned}$ |
| EXG CCR,A <br> EXG CCR,B <br> EXG CCR,CCR <br> EXG CCR,TMP2 <br> EXG CCR,D <br> EXG CCR,X <br> EXG CCR,Y <br> EXG CCR,SP | $\begin{array}{\|l} 1010 \text { X000 } \\ 1010 \times 001 \\ 1010 \times 010 \\ 1010 \times 011 \\ 1010 \times 100 \\ 1010 \times 101 \\ 1010 \times 110 \\ 1010 \times 111 \end{array}$ | $\begin{array}{ll} \text { B7 } & \text { A0 } \\ \text { B7 } & \text { A1 } \\ \text { B7 } & \text { A2 } \\ \text { B7 } & \text { A3 } \\ \text { B7 } & \text { A4 } \\ \text { B7 } & \text { A5 } \\ \text { B7 } & \text { A6 } \\ \text { B7 } & \text { A7 } \end{array}$ | $\begin{aligned} & \text { CCR } \Leftrightarrow A \\ & \text { CCR } \Leftrightarrow B \\ & \text { CCR } \Leftrightarrow C C R \\ & \$ 00: C C R \Rightarrow T M P 2, T M P 2_{L} \Rightarrow C C R \\ & \$ 00: C C R \Rightarrow D \\ & \$ 00: C C R \Rightarrow X, X_{L} \Rightarrow C C R \\ & \$ 00: C C R \Rightarrow Y, Y_{L} \Rightarrow C C R \\ & \$ 00: C C R \Rightarrow S P, S P_{L} \Rightarrow C C R \end{aligned}$ | EXG Y,A <br> EXG Y,B <br> EXG Y,CCR <br> EXG Y,TMP2 <br> EXG Y,D <br> EXG Y,X <br> EXG Y,Y <br> EXG Y,SP | $\begin{aligned} & 1110 \text { X000 } \\ & 1110 \times 001 \\ & 1110 \times 010 \\ & 1110 \times 011 \\ & 1110 \times 100 \\ & 1110 \times 101 \\ & 1110 \times 110 \\ & 1110 \times 111 \end{aligned}$ | B7 E0 <br> B7 E1 <br> B7 E2 <br> B7 E3 <br> B7 E4 <br> B7 E5 <br> B7 E6 <br> B7 E7 | $\begin{aligned} & Y_{L} \Rightarrow A, \$ 00: A \Rightarrow Y \\ & Y_{L} \Rightarrow B, \$ F F: B \Rightarrow Y \\ & Y_{L} \Rightarrow C C R, \$ F F: C C R \Rightarrow Y \\ & Y \Leftrightarrow T M P 2 \\ & Y \Leftrightarrow D \\ & Y \Leftrightarrow X \\ & Y \Leftrightarrow Y \\ & Y \Leftrightarrow S P \end{aligned}$ |
| EXG TMP3,A EXG TMP3,B EXG TMP3,CCR EXG TMP3,TMP2 EXG TMP3,D EXG TMP3,X EXG TMP3,Y EXG TMP3,SP | $1011 \times 000$ <br> 1011 X001 <br> 1011 X010 <br> 1011 X011 <br> 1011 X100 <br> 1011 X101 <br> 1011 X110 <br> 1011 X111 | $\begin{array}{ll} \text { B7 } & \text { B0 } \\ \text { B7 } & \text { B1 } \\ \text { B7 } & \text { B2 } \\ \text { B7 } & \text { B3 } \\ \text { B7 } & \text { B4 } \\ \text { B7 } & \text { B5 } \\ \text { B7 } & \text { B6 } \\ \text { B7 } & \text { B7 } \end{array}$ |  | EXG SP,A <br> EXG SP,B <br> EXG SP,CCR <br> EXG SP,TMP2 <br> EXG SP,D <br> EXG SP,X <br> EXG SP,Y <br> EXG SP,SP | $\begin{aligned} & \text { 1111 X000 } \\ & 1111 \mathrm{X} 001 \\ & 1111 \mathrm{X} 010 \\ & 1111 \mathrm{X} 011 \\ & 1111 \mathrm{X} 100 \\ & 1111 \times 101 \\ & 1111 \mathrm{X} 110 \\ & 1111 \mathrm{X} 111 \end{aligned}$ | B7 F0 <br> B7 F1 <br> B7 F2 <br> B7 F3 <br> B7 F4 <br> B7 F5 <br> B7 F6 <br> B7 F7 | $\begin{aligned} & \hline \mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{~A}, \$ 00: A \Rightarrow \mathrm{SP} \\ & \mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{~B}, \$ \mathrm{SF}: \mathrm{B} \Rightarrow \mathrm{SP} \\ & \mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{CCR}, \$ \mathrm{FF}: C \mathrm{CR} \Rightarrow \mathrm{SP} \\ & \mathrm{SP} \Leftrightarrow \mathrm{TMP2} \\ & \mathrm{SP} \Leftrightarrow \mathrm{D} \\ & \mathrm{SP} \Leftrightarrow X \\ & \mathrm{SP} \Leftrightarrow \mathrm{Y} \\ & \mathrm{SP} \Leftrightarrow \mathrm{SP} \end{aligned}$ |

$(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X}$, remainder $\Rightarrow \mathrm{D}$
Divides an unsigned 16-bit numerator in D by an unsigned 16-bit denominator in X . Puts the unsigned 16-bit quotient in X and the unsigned 16 -bit remainder in D . If both the numerator and the denominator are assumed to have radix points in the same positions, the radix point of the quotient is to the left of bit 15 . The numerator must be less than the denominator. In the case of overflow (denominator is less than or equal to the numerator) or division by 0 , the quotient is set to $\$ F F F F$ and the remainder is indeterminate.

FDIV is equivalent to multiplying the numerator by $2^{16}$ and then performing $32 \times 16$-bit integer division. The result is interpreted as a binary-weighted fraction, which resulted from the division of a $16-$ bit integer by a larger 16-bit integer. A result of $\$ 0001$ corresponds to 0.000015 , and $\$ F F F F$ corresponds to 0.9998 . The remainder of an IDIV instruction can be resolved into a binary-weighted fraction by an FDIV instruction. The remainder of an FDIV instruction can be resolved into the next 16 bits of binary-weighted fraction by another FDIV instruction.

CCR

## Effects



Z: Set if quotient is $\$ 0000$; cleared otherwise
V : Set if the denominator X is less than or equal to the numerator D ; cleared otherwise
$\mathrm{C}: \overline{\mathrm{X} 15} \bullet \overline{\mathrm{X} 14} \bullet \overline{\mathrm{X} 13} \bullet \overline{\mathrm{X} 12} \bullet \ldots \bullet \overline{\mathrm{X} 3} \bullet \overline{\mathrm{X} 2} \bullet \overline{\mathrm{X} 1} \bullet \overline{\mathrm{X} 0}$; set if denominator is $\$ 0000$; cleared otherwise
Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| FDIV | INH | 1811 | Offffffffffo |

Operation (counter) $+1 \Rightarrow$ counter
If $($ counter $)=0$, then $(P C)+\$ 0003+$ rel $\Rightarrow \mathrm{PC}$
Adds one to the counter register A, B, D, X, Y, or SP. Branches to a relative destination if the counter register reaches zero. Rel is a 9-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 100$ to $\$ 0 \mathrm{FF}(-256$ to +255$)$ from the address following the last byte of object code in the instruction.


Code and

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| IBEQ abdxysp, rel9 | REL | 04 lb rr | PPP (branch) <br> PPO (no branch) |


| Loop Primitive Postbyte (1b) Coding |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte ${ }^{1}$ | Object Code | Counter Register | Offset |
| IBEQ A, rel9 IBEQ B, rel9 IBEQ D, rel9 IBEQ X, rel9 IBEQ Y, rel9 IBEQ SP, rel9 | $\begin{aligned} & 1000 \text { X000 } \\ & 1000 \text { X001 } \\ & 1000 \text { X100 } \\ & 1000 \text { X101 } \\ & 1000 \text { X110 } \\ & 1000 \text { X111 } \end{aligned}$ |  | $\begin{aligned} & A \\ & B \\ & D \\ & X \\ & Y \\ & Y \\ & S P \end{aligned}$ | Positive |
| IBEQ A, rel9 IBEQ B, rel9 IBEQ D, rel9 IBEQ X, rel9 IBEQ Y, rel9 IBEQ SP, rel9 | $\begin{aligned} & 1001 \text { X000 } \\ & 1001 \text { X001 } \\ & 1001 \\ & \text { X100 } \\ & 1001 \\ & \text { X101 } \\ & 1001 \\ & 1001 \text { X110 } \end{aligned}$ | $\begin{aligned} & 0490 \mathrm{rr} \\ & 0491 \mathrm{rr} \\ & 0499 \mathrm{rr} \\ & 0495 \mathrm{rr} \\ & 0496 \mathrm{rr} \\ & 0497 \mathrm{rr} \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { B } \\ & D \\ & \text { X } \\ & \text { Y } \\ & \text { SP } \end{aligned}$ | Negative |

NOTES:

1. Bits $7: 6: 5$ select IBEQ or IBNE; bit 4 is the offset sign bit: bit 3 is not used; bits 2:1:0 select the counter register.
(counter) $+1 \Rightarrow$ counter
If (counter) $\neq 0$, then $(\mathrm{PC})+\$ 0003+$ rel $\Rightarrow \mathrm{PC}$
Adds one to the counter register A, B, D, X, Y, or SP. Branches to a relative destination if the counter register does not reach zero.Rel is a 9-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 100$ to $\$ 0 \mathrm{FF}$ ( -256 to +255 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| IBNE abdxysp, rel9 | REL | 04 lb rr | PPP (branch) <br> PPO (no branch) |


| Loop Primitive Postbyte (1b) Coding |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte ${ }^{1}$ | Object Code | Counter Register | Offset |
| IBNE A, rel9 IBNE B, rel9 IBNE D, rel9 IBNE X, rel9 IBNE Y, rel9 IBNE SP, rel9 | 1010 X000 <br> 1010 X001 <br> $1010 \times 100$ <br> $1010 \times 101$ <br> $1010 \times 110$ <br> 1010 X111 | 04 A0 rr 04 A1 rr 04 A4 rr 04 A5 rr 04 A6 rr 04 A7rr | $\begin{aligned} & \text { A } \\ & \text { B } \\ & \text { D } \\ & \text { X } \\ & \text { Y } \\ & \text { } \end{aligned}$ | Positive |
| IBNE A, rel9 IBNE B, rel9 IBNE D, rel9 IBNE X, rel9 IBNE Y, rel9 IBNE SP, rel9 | $\begin{aligned} & \text { 1011 X000 } \\ & 1011 \text { X001 } \\ & 1011 \text { X100 } \\ & 1011 \text { X101 } \\ & 1011 \text { X110 } \\ & 1011 \text { X111 } \end{aligned}$ |  | $\begin{aligned} & A \\ & B \\ & D \\ & X \\ & Y \\ & \text { YP } \end{aligned}$ | Negative |

NOTES:

1. Bits 7:6:5 select IBEQ or IBNE; bit 4 is the offset sign bit: bit 3 is not used; bits 2:1:0 select the counter register.

Integer Divide, Unsigned
$(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X}$; remainder $\Rightarrow \mathrm{D}$
Divides an unsigned 16-bit dividend in D by an unsigned 16-bit divisor in X . Puts the unsigned 16-bit quotient in X and the unsigned 16-bit remainder in D . If both the divisor and the dividend are assumed to have radix points in the same positions, the radix point of the quotient is to the right of bit 0 . In the case of division by 0 , the quotient is set to $\$ F F F F$, and the remainder is indeterminate.

## CCR

## Effects



Z: Set if quotient is $\$ 0000$; cleared otherwise
V: Cleared
C: $\overline{\mathrm{X} 15} \cdot \overline{\mathrm{X} 14} \cdot \overline{\mathrm{X} 13} \cdot \overline{\mathrm{X} 12} \ldots \bullet \overline{\mathrm{X} 3} \cdot \overline{\mathrm{X} 2} \cdot \overline{\mathrm{X} 1} \cdot \overline{\mathrm{X} 0}$; set if denominator is $\$ 0000$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :---: |
| IDIV | INH | 1810 | Offffffffffo |

## Integer Divide, Signed

$(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X}$; remainder $\Rightarrow \mathrm{D}$
Divides a signed 16-bit dividend in D by a signed 16-bit divisor in X. Puts the signed 16-bit quotient in X and the signed 16 -bit remainder in D . If division by 0 is attempted, the values in D and X do not change, but the $\mathrm{N}, \mathrm{Z}$, and V bits are undefined.

Other than division by 0 , which is not legal and sets the C bit, the only overflow case is:

$$
\frac{\$ 8000}{\$ F F F F}=\frac{-32,768}{-1}=+32,768
$$

But the highest positive value that can be represented in a 16-bit two's complement number is 32,767 ( $\$ 7 \mathrm{FFFF}$ ).

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{l}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\mathbf{C}$ |  |  |

N: Set if MSB of quotient is set; cleared otherwise; undefined after overflow or division by 0
Z: Set if quotient is $\$ 0000$; cleared otherwise; undefined after overflow or division by 0
V: Set if the quotient is greater than $\$ 7$ FFF or less than $\$ 8000$; cleared otherwise; undefined after division by 0
$\mathrm{C}: \overline{\mathrm{X} 15} \bullet \overline{\mathrm{X} 14} \bullet \overline{\mathrm{X} 13} \bullet \overline{\mathrm{X} 12} \cdot \ldots \bullet \overline{\mathrm{X} 3} \cdot \overline{\mathrm{X} 2} \cdot \overline{\mathrm{X} 1} \bullet \overline{\mathrm{X0}}$; set if denominator is $\$ 0000$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :---: |
| IDIVS | INH | 1815 | Offffffffffo |

Increment M

Operation $\quad(\mathrm{M})+\$ 01 \Rightarrow \mathrm{M}$
Adds one to the value in M . The $\mathrm{N}, \mathrm{Z}$, and V bits reflect the result of the operation. The C bit is not affected by the operation, thus allowing the INC instruction to be used as a loop counter in multiple-precision computations.

When operating on unsigned values, only BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. When operating on two's complement values, all signed branches are available.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\mathbf{C}$ |  |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Set if the operation produces a two's complement overflow (if and only if (M) was $\$ 7 \mathrm{~F}$ before the operation); cleared otherwise

Code and CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| INC opr16a | EXT | 72 hh 11 | rPwo |
| INC oprxo_xysppe | IDX | 62 xb | rPw |
| INC oprx9,xysppc | IDX1 | 62 xb ff | rPwo |
| INC oprx16,xysppc | IDX2 | 62 xb ee ff | frPwP |
| INC [D, xysppc] | [D,IDX] | 62 xb | fIfrPw |
| INC [oprx16,xysppc] | [IDX2] | 62 xb ee ff | fIPrPw |

Operation $\quad(\mathrm{A})+\$ 01 \Rightarrow \mathrm{~A}$
Adds one to the value in A . The $\mathrm{N}, \mathrm{Z}$ and V bits reflect the result of the operation. The C bit is not affected by the operation, thus allowing the INC instruction to be used as a loop counter in multiple-precision computations.

When operating on unsigned values, only BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. When operating on two's complement values, all signed branches are available.

CCR
Effects

| $\mathbf{S}$ |  | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\mathbf{D}$ | $\mathbf{C}$ |  |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Set if the operation produces a two's complement overflow (if and only if (A) was $\$ 7 \mathrm{~F}$ before the operation); cleared otherwise

Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| INCA | INH | 42 | 0 |

Increment B
(B) $+\$ 01 \Rightarrow B$

Adds one to the value in B . The $\mathrm{N}, \mathrm{Z}$ and V bits reflect the result of the operation. The C bit is not affected by the operation, thus allowing the INC instruction to be used as a loop counter in multiple-precision computations.

When operating on unsigned values, only BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. When operating on two's complement values, all signed branches are available.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\mathbf{C}$ |  |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Set if the operation produces a two's complement overflow (if and only if (B) was $\$ 7 \mathrm{~F}$ before the operation); cleared otherwise

Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| INCB | INH | 52 | 0 |

: User Guide - S12CPU15Ư̇Gestscale Semiconductor, Inc.

Increment SP
(same as LEAS 1,SP)

Operation $\quad(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$
Adds one to SP. INS assembles as LEAS 1,SP. INS does not affect condition code bits as INX and INY instructions do.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| INS | IDX | 1B 81 | Pf |

Operation $\quad(X)+\$ 0001 \Rightarrow X$
Adds one to X . LEAX 1, X can produce the same result but LEAX does not affect the Z bit.
Although the LEAX instruction is more flexible, INX requires only one byte of object code.
CCR
Effects


Z: Set if result is $\$ 0000$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| INX | INH | 08 | 0 |

Increment $Y$

Operation $\quad(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y}$
Adds one to Y. LEAY 1, Y can produce the same result but LEAY does not affect the Z bit.
Although the LEAY instruction is more flexible, INY requires only one byte of object code.
CCR
Effects


Z: Set if result is $\$ 0000$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| INY | INH | 02 | 0 |

Jump

Operation $\quad$ Subroutine address $\Rightarrow \mathrm{PC}$
Jumps to the instruction stored at the effective address. The effective address is obtained according to the rules for extended or indexed addressing.

CCR
Effects


Code and

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| JMP opr16a | EXT | 06 hh 11 | PPP |
| JMP oprx0_xysppc | IDX | 05 xb | PPP |
| JMP oprx9,xysppc | IDX1 | 05 xb ff | PPP |
| JMP oprx16,xysppc | IDX2 | 05 xb ee ff | fPPP |
| JMP [D,xysppc] | [D,IDX] | 05 xb | fIfPPP |
| JMP [oprx16,xysppc] | [IDX2] | 05 xb ee ff | fIfPPP |

## Jump to Subroutine

$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}$
$\mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right)$
Subroutine address $\Rightarrow \mathrm{PC}$
Sets up conditions to return to normal program flow, then transfers control to a subroutine.
Uses the address of the instruction following the JSR as a return address.
Decrements SP by two, to allow the two bytes of the return address to be stacked.
Stacks the return address (SP points to the high byte of the return address).
Calculates an effective address according to the rules for extended, direct, or indexed addressing.

Jumps to the location determined by the effective address.
Subroutines are normally terminated with an RTS instruction, which restores the return address from the stack.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| JSR opr8a | DIR | 17 dd | SPPP |
| JSR opr16a | EXT | 16 hh ll | SPPP |
| JSR oprx0 xysppc | IDX | 15 xb | PPPS |
| JSR oprx9,xysppc | IDX1 | 15 xb ff | PPPS |
| JSR oprx16,xysppc | IDX2 | 15 xb ee ff | fPPPS |
| JSR [D,xysppc] | [D,IDX] | 15 xb | fIfPPPS |
| JSR [oprx16,xysppc] | [IDX2] | 15 xb ee ff | fIfPPPS |

Operation If $\mathrm{C}=0$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the C bit and branches if $\mathrm{C}=0$.
CCR
Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBCC rel16 | REL | 1824 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBCC/LBHS | 1824 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \geq(\mathrm{A}) \end{aligned}$ | LBCS/LBLO | 1825 | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $C=0$ |  |  | $C=1$ |  |
| LBGE | 2 C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \geq(\mathrm{A}) \end{aligned}$ | LBLT | 18 2D | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=0$ |  |  | $\mathrm{N} \oplus \mathrm{V}=1$ |  |

(same as LBLO)

Operation If $\mathrm{C}=1$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the C bit and branches if $\mathrm{C}=1$.
CCR

## Effects



Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBCS rel16 | REL | 1825 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBCS/LBLO | 1825 | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | LBCC/LBHS | 1824 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \geq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=1$ |  |  | $\mathrm{C}=0$ |  |
| LBLT | 18 2D | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})<(\mathrm{A}) \end{aligned}$ | LBGE | 18 2C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=1$ |  |  | $N \oplus \mathrm{~V}=0$ |  |

Operation If $\mathrm{Z}=1,(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the Z bit and branches if $\mathrm{Z}=1$.
Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBEQ rel16 | REL | 1827 qq rr | OPPP (no branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBEQ | 1827 | $\begin{aligned} & (\mathrm{R})=(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{R})=\text { zero } \end{aligned}$ | LBNE | 1826 | $\begin{aligned} & (\mathrm{R}) \neq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{R}) \neq \text { zero } \end{aligned}$ | Signed, unsigned or simple |
|  |  | $\mathrm{Z}=1$ |  |  | $\mathrm{Z}=0$ |  |

Operation $\quad$ If $\mathrm{N} \oplus \mathrm{V}=0,(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
LBGE can be used to branch after subtracting or comparing signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than or equal to the value in M. After CBA or SBA, the branch occurs if the value in B is greater than or equal to the value in A .

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBGE rel16 | REL | 182 C qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBGE | 18 2C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | LBLT | 18 2D | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=0$ |  |  | $\mathrm{N} \oplus \mathrm{V}=1$ |  |
| LBHS/LBCC | 1824 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | LBLO/LBCS | 1825 | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})<(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=0$ |  |  | $\mathrm{C}=1$ |  |

Operation If $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
LBGT can be used to branch after subtracting or comparing signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than the value in M. After CBA or SBA, the branch occurs if the value in B is greater than the value in A .

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBGT rel16 | REL | 182 E qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBGT | 18 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | LBLE | 18 2F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \leq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$ |  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$ |  |
| LBHI | 1822 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | LBLS | 1823 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \leq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | C $\mid$ Z $=0$ |  |  | C $\mid ~ Z=1$ |  |

If $\mathrm{C} \mid \mathrm{Z}=0$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
LBHI can be used to branch after subtracting or comparing unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than the value in M. After CBA or SBA, the branch occurs if the value in $B$ is greater than the value in $A$.

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBHI rel16 | REL | 1822 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBHI | 1822 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | LBLS | 1823 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \leq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C} \mid \mathrm{Z}=0$ |  |  | C\| $\mathrm{Z}=1$ |  |
| LBGT | 18 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | LBLE | 18 2F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \leq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$ |  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$ |  |

Operation If $\mathrm{C}=0$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
LBHS can be used to branch after subtracting or comparing unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is greater than or equal to the value in M. After CBA or SBA, the branch occurs if the value in $B$ is greater than or equal to the value in $A$.

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBHS rel16 | REL | 1824 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBHS/LBCC | 1824 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | LBLO/LBCS | 1825 | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=0$ |  |  | $\mathrm{C}=1$ |  |
| LBGE | 18 2C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | LBLT | 182 D | $\begin{aligned} & (\mathrm{R})<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $N \oplus \mathrm{~V}=0$ |  |  | $\mathrm{N} \oplus \mathrm{V}=1$ |  |

LBLE
Long Branch if Less Than or Equal to Zero

Operation If $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$, then $(\mathrm{PC})+\$ 0004+$ rel $\Rightarrow \mathrm{PC}$
LBLE can be used to branch after subtracting or comparing signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than or equal to the value in M . After CBA or SBA, the branch occurs if the value in $B$ is less than or equal to the value in $A$.

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :---: | :--- | :--- |
| LBLE rel16 | REL | 182 F qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBLE | 18 2F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | LBGT | 18 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})>(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$ |  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$ |  |
| LBLS | 1823 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \leq(\mathrm{A}) \end{aligned}$ | LBHI | 1822 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B})>(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $C \mid Z=1$ |  |  | $\mathrm{C} \mid \mathrm{Z}=0$ |  |

Operation If $\mathrm{C}=1$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
LBLO can be used to branch after subtracting or comparing unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than the value in M. After CBA or SBA, the branch occurs if the value in $B$ is less than the value in $A$.

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBLO rel16 | REL | 1825 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBLO/LBCS | 1825 | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & \text { (B) }<(\mathrm{A}) \end{aligned}$ | LBHS/LBCC | 1824 | $\begin{aligned} & (R) \geq(M) \\ & \text { or } \\ & (B) \geq(A) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C}=1$ |  |  | $\mathrm{C}=0$ |  |
| LBLT | 18 2D | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & \text { (B) }<(\mathrm{A}) \end{aligned}$ | LBGE | 182 C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \geq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{N} \oplus \mathrm{V}=1$ |  |  | $N \oplus \mathrm{~V}=0$ |  |

# : User Guide - S12CPU15ƯGY̧.şale Semiconductor, Inc. 

## LBLS

Long Branch if Lower or Same

Operation If $\mathrm{C} \mid \mathrm{Z}=1$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
LBLS can be used to branch after subtracting or comparing unsigned values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than or equal to the value in M . After CBA or SBA, the branch occurs if the value in B is less than or equal to the value in A .

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBLS rel16 | REL | 1823 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBLS | 1823 | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \leq(\mathrm{A}) \end{aligned}$ | LBHI | 1822 | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $\mathrm{C} \mid \mathrm{Z}=1$ |  |  | $\mathrm{C} \mid \mathrm{Z}=0$ |  |
| LBLE | 182 F | $\begin{aligned} & (\mathrm{R}) \leq(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B}) \leq(\mathrm{A}) \end{aligned}$ | LBGT | 18 2E | $\begin{aligned} & (\mathrm{R})>(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})>(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=1$ |  |  | $\mathrm{Z} \mid(\mathrm{N} \oplus \mathrm{V})=0$ |  |

Operation $\quad$ If $\mathrm{N} \oplus \mathrm{V}=1,(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
LBLT can be used to branch after subtracting or comparing signed two's complement values. After CMPA, CMPB, CPD, CPS, CPX, CPY, SBCA, SBCB, SUBA, SUBB, or SUBD, the branch occurs if the CPU register value is less than the value in M. After CBA or SBA, the branch occurs if the value in B is less than the value in $A$.

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBLT rel16 | REL | 18 2D qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBLT | 182 D | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & \text { (B) }<(\mathrm{A}) \end{aligned}$ | LBGE | 182 C | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | Signed |
|  |  | $\mathrm{N} \oplus \mathrm{V}=1$ |  |  | $N \oplus \mathrm{~V}=0$ |  |
| LBLO/LBCS | 1825 | $\begin{aligned} & \text { (R) }<(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{B})<(\mathrm{A}) \end{aligned}$ | LBHS/LBCC | 1824 | $\begin{aligned} & (\mathrm{R}) \geq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{~B}) \geq(\mathrm{A}) \end{aligned}$ | Unsigned |
|  |  | $C=1$ |  |  | $\mathrm{C}=0$ |  |

Operation If $\mathrm{N}=1$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the N bit and branches if $\mathrm{N}=1$.
Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBMI rel16 | REL | 18 2B qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBMI | $182 B$ | Negative | LBPL | 182 A | Positive | Simple |
|  |  |  |  |  |  |  |

Operation If $\mathrm{Z}=0$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the Z bit and branches if $\mathrm{Z}=0$.
Rel is a 16-bit two's complement offset for branching forward or backward in memory.
Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBNE rel16 | REL | 1826 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBNE | 1826 | $\begin{aligned} & (\mathrm{R}) \neq(\mathrm{M}) \\ & \mathrm{or} \\ & (\mathrm{R}) \neq \text { zero } \end{aligned}$ | LBEQ | 1827 | $\begin{aligned} & (\mathrm{R})=(\mathrm{M}) \\ & \text { or } \\ & (\mathrm{R})=\text { zero } \end{aligned}$ | Signed, unsigned, or simple |
|  |  | $\mathrm{Z}=0$ |  |  | $\mathrm{Z}=1$ |  |

## Long Branch if Plus

Operation If $\mathrm{N}=0$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the N bit and branches if $\mathrm{N}=0$.
Rel is a 16-bit two's complement offset for branching forward or backward in memory.
Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBPL rel16 | REL | 18 2A qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBPL | $182 A$ | Positive | LBMI | $182 B$ | Negative | Simple |
|  |  |  |  |  |  |  |

Operation $\quad(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Branches unconditionally.
Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

Execution time is longer when a conditional branch is taken than when it is not, because the instruction queue must be refilled before execution resumes at the new address. Since the LBRA branch condition is always satisfied, the branch is always taken, and the instruction queue must always be refilled.

## CCR

Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBRA rel16 | REL | 1820 qq rr | OPPP |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBRA | 1820 | Always | LBRN | 1821 | Never | Simple |

Operation $\quad(\mathrm{PC})+\$ 0004 \Rightarrow \mathrm{PC}$
Never branches. LBRN is effectively a 4-byte NOP that requires three cycles. LBRN is included in the instruction set to provide a complement to the LBRA instruction. LBRN is useful during program debug to negate the effect of another branch instruction without disturbing the offset byte. A complement for LBRA is also useful in compiler implementations.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBRN rel16 | REL | 1821 qq rr | OPO |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBRN | 1821 | Never | LBRA | 1820 | Always | Simple |

Operation If V $=0$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the V bit and branches if $\mathrm{V}=0$. LBVC causes a branch when a previous operation on two's complement binary values does not cause an overflow. That is, when LBVC follows a two's complement operation, a branch occurs when the result of the operation is valid.

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBVC rel16 | REL | 1828 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBVC | 1828 | No overflow | LBVS | 1829 | Overflow | Simple |
|  |  | $\mathrm{V}=0$ |  |  |  |  |

# : User Guide - S12CPU15ƯGY̧.şale Semiconductor, Inc. 

LBVS

Long Branch if V Set

Operation If $\mathrm{V}=1$, then $(\mathrm{PC})+\$ 0004+\mathrm{rel} \Rightarrow \mathrm{PC}$
Tests the V bit and branches if $\mathrm{V}=1$. LBVS causes a branch when a previous operation on two's complement values causes an overflow. That is, when LBVS follows a two's complement operation, a branch occurs when the result of the operation is invalid.

Rel is a 16-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 8000$ to $\$ 7 \mathrm{FFF}$ ( -32768 to 32767 ) from the address following the last byte of object code in the instruction.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LBVS rel16 | REL | 1829 qq rr | OPPP (branch) <br> OPO (no branch) |


| Branch |  |  | Complementary Branch |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Opcode | Test | Mnemonic | Opcode | Test |  |
| LBVS | 1829 | Overflow | LBVC | 1828 | No overflow | Simple |
|  |  |  |  |  |  |  |

Operation $\quad(\mathrm{M}) \Rightarrow \mathrm{A}$
or
$\mathrm{imm} \Rightarrow \mathrm{A}$
Loads A with either the value in M or an immediate value.
CCR
Effects

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
v: Cleared
Code and

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| LDAA \#opr8i | IMM | 86 ii | P |
| LDAA opr8a | DIR | 96 dd | rPf |
| LDAA opr16a | EXT | B6 hh ll | rPO |
| LDAA oprx0_xysppc | IDX | A6 xb | rPf |
| LDAA oprx9,xysppc | IDX1 | A6 xb ff | rPO |
| LDAA oprx16,xysppc | IDX2 | A 6 xb ee ff | frPP |
| LDAA [D, xysppc] | [D,IDX] | A 6 xb | fIfrPf |
| LDAA [oprx16,xysppc | [IDX2] | A 6 xb ee ff | fIPrPf |

## Load B

Operation $\quad(\mathrm{M}) \Rightarrow \mathrm{B}$
or
$\mathrm{imm} \Rightarrow \mathrm{B}$
Loads B with either the value in M or an immediate value.
CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : Cleared
Code and

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| LDAB \#opr8i | IMM | C6 ii | P |
| LDAB opr8a | DIR | D6 dd | rPf |
| LDAB opr16a | EXT | F6 hh 11 | rPo |
| LDAB oprx0_xysppc | IDX | E6 xb | rPf |
| LDAB oprx9,xysppc | IDX1 | E6 xb ff | rPO |
| LDAB oprx16,xysppc | IDX2 | E6 xb ee ff | frpp |
| LDAB [D,xysppc] | [D,IDX] | E6 xb | fIfrPf |
| LDAB [oprx16,xysppc] | [IDX2] | E6 xb ee ff | fIPrPf |

Load D

Operation $\quad(\mathrm{M}):(\mathrm{M}+1) \Rightarrow \mathrm{A}: \mathrm{B}$
or
$\mathrm{imm} \Rightarrow \mathrm{A}: \mathrm{B}$
Loads A with the value in M and loads B with the value in $\mathrm{M}: \mathrm{M}+1$ or loads $\mathrm{A}: \mathrm{B}$ with an immediate value.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{S}$ | $\mathbf{C}$ |  |  |  |  |  |  |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LDD \#opr16i | IMM | CC jj kk | PO |
| LDD opr8a | DIR | DC dd | RPf |
| LDD opr16a | EXT | FC hh ll | RPO |
| LDD oprx0_xysppc | IDX | EC xb | RPf |
| LDD oprx9,xysppc |  |  |  |
| LDD oprx16,xysppc |  |  |  |
| LDD [D,xysppc] |  |  |  |
| LDD [oprx16,xysppc] | IDX1 | EC xb ff | RPO |
| IDX2 | EC xb ee ff | fRPP |  |
| [DDX] | EC xb <br> EC xb ee ff | fIfRPf |  |
| fIPRPf |  |  |  |

## Load SP

Operation $\quad(\mathrm{M}):(\mathrm{M}+1) \Rightarrow \mathrm{SP}$
or
$\mathrm{imm} \Rightarrow \mathrm{SP}$
Loads the high byte of SP with the value in M and the low byte with the value in $\mathrm{M}+1$ or loads SP with an immediate value.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LDS \#opr16i | IMM | CF jj kk | PO |
| LDS opr8a | DIR | DF dd | RPf |
| LDS opr16a | EXT | FF hh ll | RPO |
| LDS oprx0_xysppc | IDX | EF xb | RPf |
| LDS oprx9,xysppc |  |  |  |
| LDS oprx16,xysppc | IDX1 | EF xb ff | RPO |
| LDS [D,xysppc] |  |  |  |
| LDS [oprx16,xysppc] | IDX2 | EF xb ee ff | fRPP |
| [IDX2] | EF xb <br> EF xb ee ff | fIfRPf |  |
| fIPRPf |  |  |  |

Operation

$$
\begin{aligned}
& (\mathrm{M}):(\mathrm{M}+1) \Rightarrow \mathrm{X} \\
& \text { or } \\
& \text { imm } \Rightarrow \mathrm{X}
\end{aligned}
$$

Loads the high byte of X with value in M and low byte with the value in $\mathrm{M}+1$ or loads X with an immediate value.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LDX \#opr16i | IMM | CE jj kk | Po |
| LDX opr8a | DIR | DE dd | RPf |
| LDX opr16a | EXT | FE hh ll | RPO |
| LDX oprx0_xysppc | IDX | EE xb | RPf |
| LDX oprx9,xysppc | IDX1 | EE xb ff | RPO |
| LDX oprx16,xysppc | IDX2 $[D, x y s p p c]$ | EE xb ee ff | fRPP |
| LDX [oprx16,xysppc] | [D,IDX] | EE xb | fIfRPf |
| [IDX2] | EE xb ee ff | fIPRPf |  |

## Load Y

Operation $\quad(\mathrm{M}):(\mathrm{M}+1) \Rightarrow \mathrm{Y}$
or
$\mathrm{imm} \Rightarrow \mathrm{Y}$
Loads the high byte of Y with the value in M and the low byte with the value in $\mathrm{M}+1$ or loads Y with an immediate value.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{S}$ | $\mathbf{C}$ |  |  |  |  |  |  |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
v: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LDY \#opr16i | IMM | CD jj kk | PO |
| LDY opr8a | DIR | DD dd | RPf |
| LDY opr16a | EXT | FD hh ll | RPO |
| LDY oprx0_xysppc | IDX | ED xb | RPf |
| LDY oprx9,xysppc |  |  |  |
| LDY oprx16,xysppc | IDX1 | ED xb ff | RPO |
| LDY [D,xysppc] |  |  |  |
| LDY [oprx16,xysppc] | IDX2 | ED xb ee ff | fRPP |
| [DDX] | ED xb <br> ED xb ee ff | fIfRPf |  |
| fIPRPf |  |  |  |

Operation $\quad$ Effective address $\Rightarrow \mathrm{SP}$
Loads the stack pointer with an effective address specified by the program. The effective address can be any indexed addressing mode operand address except an indirect address. Indexed addressing mode operand addresses are formed by adding an optional constant supplied by the program or an accumulator value to the current value in $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC.

LEAS does not alter condition code bits. This allows stack modification without disturbing CCR bits changed by recent arithmetic operations.

When SP is the indexing register, a predecrement or preincrement LEAS loads SP with the changed value. A postdecrement or postincrement LEAS does not affect the value in SP.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LEAS oprx0_xysppc | IDX | 1 Bxb | Pf |
| LEAS oprx9,xysppc |  |  |  |
| LEAS oprx16,xysppc | IDX1 | 1 B xb ff <br> IDX 2 | PO |

Operation Effective address $\Rightarrow \mathrm{X}$
Loads X with an effective address specified by the program. The effective address can be any indexed addressing mode operand address except an indirect address. Indexed addressing mode operand addresses are formed by adding an optional constant supplied by the program or an accumulator value to the current value in $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC.

When X is the indexing register, a predecrement or preincrement LEAX loads X with the changed value. A postdecrement or postincrement LEAX does not affect the value in X .

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LEAX oprx0_xysppc | IDX | $1 \mathrm{~A} \times \mathrm{x}$ | Pf |
| LEAX oprx9,xysppc |  |  |  |
| LEAX oprx16,xysppc | IDX1 | $1 \mathrm{~A} \times \mathrm{ff} \mathrm{ff}$ <br> IA xb ee ff | PO |

## Load Effective Address into Y

Operation Effective address $\Rightarrow \mathrm{Y}$
Loads Y with an effective address specified by the program. The effective address can be any indexed addressing mode operand address except an indirect address. Indexed addressing mode operand addresses are formed by adding an optional constant supplied by the program or an accumulator value to the current value in $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC.

When Y is the indexing register, a predecrement or preincrement LEAY loads Y with the changed value. A postdecrement or postincrement LEAY does not affect the value in Y.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LEAY oprx0_xysppc | IDX | 19 xb | Pf |
| LEAY oprx9,xysppc | IDX1 | 19 xb ff <br> LEAY oprx16,xysppc | IDX 2 |

## Operation



Shifts all bits of the $M$ one place to the left. Loads bit 0 with 0 . Loads the C bit from the most significant bit of M .

## CCR

Effects


N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\bar{N} \bullet \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift)
C: M7; set if the LSB of M was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| LSL opr16a | EXT | 78 hh 11 | rPwo |
| LSL oprxO_xysppc | IDX | 68 xb | rPw |
| LSL oprx9,xysppc | IDX1 | 68 xb ff | rPwo |
| LSL oprx16,xysppc | IDX2 | 68 xb ee ff | frPPw |
| LSL [D, xysppc] | [D,IDX] | 68 xb | fifrPw |
| LSL [oprx16,xysppc] | [IDX2] | 68 xb ee ff | fIPrPw |



Shifts all bits of A one place to the left. Loads bit 0 with 0 . Loads the C bit is from the most significant bit of A .

## CCR

Effects


N: Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\bar{N} \cdot \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift)
C: A7; set if the LSB of A was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LSLA | INH | 48 | 0 |

# LSLB 

## Logical Shift Left B

(same as ASLB)

## Operation



Shifts all bits of B one place to the left. Loads bit 0 with 0 . Loads the C bit from the most significant bit of $B$.

CCR
Effects


N: Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\bar{N} \bullet \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift)
C: B7; set if the LSB of B was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LSLB | INH | 58 | 0 |

Operation


Shifts all bits of D one place to the left. Loads bit 0 with 0 . Loads the C bit from the most significant bit of A.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\overline{\mathrm{N}} \cdot \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and $C$ is set); cleared otherwise (for values of $N$ and $C$ after the shift)
C: D15; set if the MSB of D was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LSLD | INH | 59 | 0 |



Shifts all bits of $M$ one place to the right. Loads bit 7 with 0 . Loads the C bit from the least significant bit of M .

CCR
Effects


N : Cleared
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and $C$ is set); cleared otherwise (for values of $N$ and $C$ after the shift)
C: MO; set if the LSB of M was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| LSR opr16a | EXT | 74 hh 11 | rPwo |
| LSR oprx0_xysppc | IDX | 64 xb | rPw |
| LSR oprx9,xysppc | IDX1 | 64 xb ff | rPwO |
| LSR oprx16,xysppc | IDX2 | 64 xb ee ff | frPwp |
| LSR [D, xysppc] | [D,IDX] | 64 xb | fIfrPw |
| LSR [oprx16,xysppc] | [IDX2] | 64 xb ee ff | fIPrPw |



Shifts all bits of A one place to the right. Loads bit 7 with 0 . Loads the C bit from the least significant bit of A .

CCR
Effects


N : Cleared
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift)
C : A0; set if the LSB of A was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LSRA | INH | 44 | 0 |

## LSRB

## Logical Shift Right B

Operation

$$
\begin{array}{cc|c|c|c|c|c|c|}
\hline 0 \rightarrow & \text { b7 } & \text { b6 } & \text { b5 } & \text { b4 } & \text { b3 } & \text { b2 } & \text { b1 } \\
& \text { b0 } \\
\hline
\end{array}
$$

Shifts all bits of $B$ one place to the right. Loads bit 7 with 0 . Loads the $C$ bit from the least significant bit of $B$.

CCR
Effects


N : Cleared
Z: Set if result is $\$ 00$; cleared otherwise
V: $N \oplus C=[N \bullet \bar{C}] \mid[\bar{N} \bullet C]$ (for $N$ and $C$ after the shift); set if ( $N$ is set and $C$ is cleared) or ( $N$ is cleared and C is set); cleared otherwise (for values of N and C after the shift)
C: B0; set if the LSB of B was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LSRB | INH | 54 | 0 |

## LSRD

## Logical Shift Right D

Operation

Shifts all bits of D one place to the right. Loads D15 (A7) with 0. Loads the C bit from D0 (B0).

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |

$N$ : Cleared
Z: Set if result is $\$ 0000$; cleared otherwise
V: DO; set if, after the shift operation, C is set; cleared otherwise
C: D0; set if the LSB of D was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| LSRD | INH | 49 | 0 |

## Maximum in A

$\operatorname{MAX}[(\mathrm{A}),(\mathrm{M})] \Rightarrow \mathrm{A}$
Subtracts an unsigned 8-bit value in M from an unsigned 8-bit value in A to determine which is larger. Puts the larger value in A . If the values are equal, the Z bit is set. If the value in M is larger, the C bit is set when the value in M replaces the value in A . If the value in A is larger, the C bit is cleared.

MAXA accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate finding the largest value in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: A7 • M7 • $\overline{\mathrm{R} 7} \mid \overline{\mathrm{A} 7} \bullet \mathrm{M} 7 \bullet R 7$; set if the operation produces a two's complement overflow; cleared otherwise
$C: \overline{A 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if $(M)$ is larger than (A); cleared otherwise
Condition code bits reflect internal subtraction: $R=(A)-(M)$.
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| MAXA oprx0_xysppc | IDX | 1818 xb | OrPf |
| MAXA oprx9, xysppc | IDX1 | 1818 xb ff | Orpo |
| MAXA oprx16,xysppc | IDX2 | 1818 xb ee ff | OfrPP |
| MAXA [D, xysppc] | [D,IDX] | 1818 xb | OfIfrPf |
| MAXA [oprx16,xysppc] | [IDX2] | 1818 xb ee ff | OfIPrPf |

## Maximum in M

MAX [(A), (M)] $\Rightarrow$ M
Subtracts an unsigned 8-bit value in M from an unsigned 8-bit value in A to determine which is larger. Puts the larger value in M . If the values are equal, the Z bit is set. If the value in M is larger, the C bit is set. If the value in A is larger, the C bit is cleared when the value in A replaces the value in M .

MAXM accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate controlling the values in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: A7 • M7 • R7 | $\overline{\mathrm{A} 7} \bullet \mathrm{M} 7 \bullet R 7$; set if the operation produces a two's complement overflow; cleared otherwise
$C: \overline{A 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if $(M)$ is larger than (A); cleared otherwise
Condition code bits reflect internal subtraction: $R=(A)-(M)$.
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| MAXM oprx0_xysppc MAXM oprx9,xysppc MAXM oprx16,xysppc MAXM [D,xysppc] MAXM [oprx16,xysppc] | IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | $\begin{aligned} & 181 \mathrm{Cxb} \\ & 18 \mathrm{Cxb} \mathrm{cf} \\ & 18 \mathrm{Cxb} \text { ee ff } \\ & 18 \mathrm{Clxb} \\ & 18 \mathrm{Clb} \mathrm{Cb} \mathrm{ff} \end{aligned}$ | OrPw <br> OrPwo <br> OfrPwP <br> OfIfrPw <br> OfIPrPw |

Operation $\quad$ Grade of membership $\Rightarrow \mathrm{M}_{\mathrm{Y}}$
$(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y}$
$(\mathrm{X})+\$ 0004 \Rightarrow \mathrm{X}$
Before executing MEM, initialize A, X and Y. Load A with the current crisp value of a system input variable. Load Y with the fuzzy input RAM location where the grade of membership is to be stored. Load X with the first address of a 4-byte data structure that describes a trapezoidal membership function. The data structure consists of:

- Point_1 - The x -axis starting point for the leading side (at $\mathrm{M}_{\mathrm{X}}$ )
- Slope_1 - The slope of the leading side (at $\mathrm{M}_{\mathrm{X}+1}$ )
- Point_2 - The x-axis position of the rightmost point (at $\mathrm{M}_{\mathrm{X}+2}$ )
- Slope_2 - The slope of the trailing side (at $\mathrm{M}_{\mathrm{X}+3}$ )

A slope_1 or slope_2 value of $\$ 00$ is a special case in which the membership function either starts with a grade of $\$ \mathrm{FF}$ at input = point $\_1$, or ends with a grade of $\$ \mathrm{FF}$ at input = point_2 (infinite slope).

During execution, the value of A remains the same. X is incremented by four and Y is incremented by one.

CCR
Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| MEM | Special | 01 | RRfOw |

## Minimum in A

MIN [(A), (M)] $\Rightarrow$ A
Subtracts an unsigned 8-bit value in M from an unsigned 8-bit value in A to determine which is larger. Puts the smaller value in A . If the values are equal, the Z bit is set. If the value in M is larger, the C bit is set. If the value in A is larger, the C bit is cleared when the value in M replaces the value in A .

MINA accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate finding the smallest value in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: A7 • M7 • $\overline{\mathrm{R} 7} \mid \overline{\mathrm{A} 7} \bullet \mathrm{M} 7 \bullet R 7$; set if the operation produced a two's complement overflow; cleared otherwise
$C: \overline{A 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if the value of the value in $M$ is larger than the value in $A$; cleared otherwise
Condition codes reflect internal subtraction $R=(A)-(M)$.
Code and

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| MINA oprx0_xysppc | IDX | 1819 xb | OrPf |
| MINA oprx9,xysppc | IDX1 | 1819 xb ff | Orpo |
| MINA oprx16,xysppc | IDX2 | 1819 xb ee ff | OfrPP |
| MINA [D, xysppc] | [D,IDX] | 1819 xb | OfIfrPf |
| MINA [oprx16,xysppc] | [IDX2] | 1819 xb ee ff | OfIPrPf |

## Minimum in M

MIN [(A), (M)] $\Rightarrow$ M
Subtracts an unsigned 8-bit value in M from an unsigned 8-bit value in A to determine which is larger. Puts the smaller value in M . If the values are equal, the Z bit is set. If the value in M is larger, the C bit is set when the value in A replaces the value in M . If the value in A is larger, the C bit is cleared.

MINM accesses memory with indexed addressing modes for flexibility in specifying operand addresses. Autoincrement and autodecrement functions can facilitate controlling the values in a list of values.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: A7 • M7 • R7 | $\overline{\mathrm{A} 7} \bullet \mathrm{M} 7 \bullet R 7$; set if the operation produced a two's complement overflow; cleared otherwise
$C: \overline{A 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if the value in $M$ is larger than the value in $A$; cleared otherwise Condition codes reflect internal subtraction $R=(A)-(M)$.

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| MINM oprx0_xysppc | IDX | 18 1D xb | OrPw |
| MINM oprox9,xysppc | IDX1 | 18 1D xb ff | OrPwo |
| MINM oprx16,xysppc | IDX2 | 18 1D xb ee ff | OfrPwP |
| MINM [D,xysppc] | $[D, I D X]$ | 18 1D xb | OfIfrPw |
| MINM [oprx16,xysppc] | [IDX2] | 18 1D xb ee ff | OfIPrPw |

## Operation $\quad\left(\mathrm{M}_{1}\right) \Rightarrow \mathrm{M}_{2}$

Moves the value in one 8-bit memory location, $\mathrm{M}_{1}$, to another 8-bit memory location, $\mathrm{M}_{2}$.
The value in $\mathrm{M}_{1}$ does not change.
Move instructions can use different addressing modes to access the source and destination of a move. Supported addressing mode combinations are: IMM-EXT, IMM-IDX, EXT-EXT, EXT-IDX, IDX-EXT, and IDX-IDX. IDX operands allow indexed addressing mode specifications that fit in a single postbyte; including 5-bit constant, accumulator offsets, and autoincrement/decrement modes. Nine-bit and 16-bit constant offsets would require additional extension bytes and are not allowed. Indexed-indirect modes (for example [D,r]) are also not allowed.

## CCR

## Effects



Code and

| Source Form ${ }^{1}$ | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| MOVB \#opr8, opr16a | IMM-EXT | 18 OB ii hh 11 | OPwP |
| MOVB \#opr8i, oprx0_xysppc | IMM-IDX | 1808 xb ii | OPwO |
| MOVB opr16a, opr16] | EXT-EXT | 180 Chh 11 hh 11 | OrPwPO |
| MOVB opr16a, oprx0_xysppc | EXT-IDX | 1809 xb hh 11 | OPrPw |
| MOVB oprx0_xysppc, opr16a | IDX-EXT | 18 0D xb hh ll | OrPwP |
| MOVB oprx0_xysppc, oprx0_xysppc | IDX-IDX | 180 Axb xb | OrPwo |

NOTES:

1. The first operand in the source code statement specifies the source for the move.

Operation $\quad\left(\mathrm{M}_{1}\right):\left(\mathrm{M}_{1}+1\right) \Rightarrow \mathrm{M}_{2}: \mathrm{M}_{2}+1$
Moves the value in one 16-bit memory location, $\mathrm{M}_{1}: \mathrm{M}_{1}+1$, to another 16-bit memory location, $\mathrm{M}_{2}: \mathrm{M}_{2}+1$. The value in $\mathrm{M}_{1}: \mathrm{M}_{1}+1$ does not change.

Move instructions can use different addressing modes to access the source and destination of a move. These combinations of addressing modes are supported: IMM-EXT, IMM-IDX, EXT-EXT, EXT-IDX, IDX-EXT, and IDX-IDX. IDX operands allow indexed addressing mode specifications that fit in a single postbyte; including 5-bit constant, accumulator offsets, and autoincrement/decrement modes. Nine-bit and 16-bit constant offsets would require additional extension bytes and are not allowed. Indexed-indirect modes (for example [D,r]) are also not allowed.

## CCR

## Effects



Code and

| Source Form ${ }^{1}$ | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| MOVW \#opr16i, opr16a | IMM-EXT | 1803 jjkk hh ll | OPWPO |
| MOVW \#opr16i, oprx0_xysppc | IMM-IDX | 1800 xb jj kk | OPPW |
| MOVW opr16a, opr16a | EXT-EXT | 1804 hh 1 l hh ll | ORPWPO |
| MOVW opr16a, oprx0_xysppc | EXT-IDX | 1801 xb hh 11 | OPRPW |
| MOVW oprx0_xysppc, opr16a | IDX-EXT | 1805 xb hh 11 | ORPWP |
| MOVW oprx0_xysppc, oprx0_xysppc | IDX-IDX | 1802 xb xb | ORPWO |

NOTES:

1. The first operand in the source code statement specifies the source for the move.

Multiply, Unsigned

Operation $\quad(A) \times(B) \Rightarrow A: B$
Multiplies the 8-bit unsigned value in $A$ by the 8-bit unsigned value in $B$ and places the 16 -bit unsigned result in D . The carry flag allows rounding the high byte of the result through the sequence: MUL, ADCA \#0.

CCR
Effects


C: R7; set if bit 7 of the result is set; cleared otherwise
Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| MUL | INH | 12 | 0 |

## : User Guide - S12CPU15Ư̇Gestscale Semiconductor, Inc.

## Negate M

$0-(\mathrm{M})=(\overline{\mathrm{M}})+1 \Rightarrow \mathrm{M}$
Replaces the value in $M$ with its two's complement. A value of $\$ 80$ does not change.

## CCR

## Effects



N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{R} 7 \bullet \overline{\mathrm{R} 6} \cdot \overline{\mathrm{R} 5} \cdot \overline{\mathrm{R} 4} \cdot \overline{\mathrm{R} 3} \cdot \overline{\mathrm{R} 2} \cdot \overline{\mathrm{R} 1} \cdot \overline{\mathrm{RO}}$; set if there is a two's complement overflow from the implied subtraction from 0; cleared otherwise; two's complement overflow occurs if and only if $(\mathrm{M})=\$ 80$
C: $R 7|R 6| R 5|R 4| R 3|R 2| R 1 \mid R 0$; set if there is a borrow in the implied subtraction from 0 ; cleared otherwise; set in all cases except when $(\mathrm{M})=\$ 00$

Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| NEG opr16a | EXT | 70 hh 11 | rPwo |
| NEG oprx0_xysppc | IDX | 60 xb | rPw |
| NEG oprx9,xysppc | IDX1 | 60 xb ff | rPwo |
| NEG oprx16,xysppc | IDX2 | 60 xb ee ff | frPwP |
| NEG [D, xysppc] | [D,IDX] | 60 xb | fifrPw |
| NEG [oprx16,xysppc] | [IDX2] | 60 xb ee ff | fIPrPw |

## Negate A

Operation
$0-(\mathrm{A})=(\overline{\mathrm{A}})+1 \Rightarrow \mathrm{~A}$
Replaces the value in A with its two's complement. A value of $\$ 80$ does not change.


N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : R7 $\bullet \overline{\mathrm{R} 6} \cdot \overline{\mathrm{R} 5} \bullet \overline{\mathrm{R} 4} \bullet \overline{\mathrm{R} 3} \bullet \overline{\mathrm{R} 2} \bullet \overline{\mathrm{R} 1} \bullet \overline{\mathrm{R} 0}$; set if there is a two's complement overflow from the implied subtraction from 0; cleared otherwise; two's complement overflow occurs if and only if $(A)=\$ 80$
$C: R 7|R 6| R 5|R 4| R 3|R 2| R 1 \mid R 0$; set if there is a borrow in the implied subtraction from 0 ; cleared otherwise; set in all cases except when $(A)=\$ 00$

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| NEGA | INH | 40 | 0 |

## Negate B

Operation $\quad 0-(B)=(\bar{B})+1 \Rightarrow B$
Replaces the value in B with its two's complement. A value of $\$ 80$ does not change.


N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : R7 $\bullet \overline{\mathrm{R} 6} \cdot \overline{\mathrm{R} 5} \bullet \overline{\mathrm{R} 4} \bullet \overline{\mathrm{R} 3} \bullet \overline{\mathrm{R} 2} \bullet \overline{\mathrm{R} 1} \bullet \overline{\mathrm{R} 0}$; set if there is a two's complement overflow from the implied subtraction from 0 ; cleared otherwise; two's complement overflow occurs if and only if $(B)=\$ 80$
$C: R 7|R 6| R 5|R 4| R 3|R 2| R 1 \mid R 0$; set if there is a borrow in the implied subtraction from 0; cleared otherwise; set in all cases except when $(B)=\$ 00$

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| NEGB | INH | 50 | 0 |

## Null Operation

Operation No operation
This single-byte instruction increments the PC and does nothing else. No other CPU registers are affected. NOP typically is used to produce a time delay, although some software disciplines discourage CPU frequency-based time delays. During debug, NOP instructions are sometimes used to temporarily replace other machine code instructions, thus disabling the replaced instruction(s).


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| NOP | INH | A7 | 0 |

$(\mathrm{A}) \mid(\mathrm{M}) \Rightarrow \mathrm{A}$
or
(A) $\mid$ imm $\Rightarrow A$

Performs logical inclusive OR of the value in A and either the value in M or an immediate value. Puts the result in A.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{S}$ | $\mathbf{C}$ |  |  |  |  |  |  |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ORAA \#oprsi | IMM | 8A ii | P |
| ORAA opr8a | DIR | 9A dd | rPf |
| ORAA opr16a | EXT | BA hh 11 | rPO |
| ORAA oprx0_xysppc | IDX | AA xb | rPf |
| ORAA oprx9,xysppc | IDX1 | AA xb ff | rPo |
| ORAA oprx $16, x y$ sppc | IDX2 | AA xb ee ff | frpp |
| ORAA [D, xysppc] | [D,IDX] | AA xb | fifrpf |
| ORAA [oprx16,xysppc] | [IDX2] | AA xb ee ff | fiprpf |

(B) $\mid(\mathrm{M}) \Rightarrow \mathrm{B}$
or
(B) $\mid \mathrm{imm} \Rightarrow \mathrm{B}$

Performs logical inclusive OR of the value in B and either the value in M or an immediate value. Puts the result in B.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine Coding <br> (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ORAB \#opr8i | IMM | CA ii | P |
| ORAB opr8a | DIR | DA dd | rPf |
| ORAB opr16a | EXT | FA hh ll | rPO |
| ORAB oprx0 xysppc | IDX | EA xb | rPf |
| ORAB oprx9,xysppc | IDX1 | EA xb ff | rPO |
| ORAB oprx16,xysppc | IDX2 | EA xb ee ff | frPP |
| ORAB [D,xysppc] | ORAB [oprx16,xysppc] | [DID] | EA xb |
| [IDX2] | EA xb ee ff | fIPrPf |  |

## OR CCR

Operation $\quad(C C R) \mid i m m \Rightarrow C C R$
Performs a logical inclusive OR of the value in the CCR and an immediate value. Puts the result in the CCR. CCR bits that correspond to 1 s in M are set. No other CCR bits change.

NOTE: The X bit cannot be set by any software instruction.
CCR
Effects


A condition code bit is set if the corresponding bit was 1 before the operation or if the corresponding bit in the instruction-provided mask is 1 . The X bit cannot be set by any software instruction.

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ORCC \#opr8i | IMM | 14 ii | P |

## Push A onto Stack

Operation
(SP) - \$0001 $\Rightarrow$ SP
(A) $\Rightarrow \mathrm{M}_{\mathrm{SP}}$

Decrements SP by one and loads the value in A into the address to which SP points.
Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PSHA | INH | 36 | Os |

## Push B onto Stack

Operation
(SP) - \$0001 $\Rightarrow$ SP
(B) $\Rightarrow \mathrm{M}_{\mathrm{SP}}$

Decrements SP by one and loads the value in B into the address to which SP points.
Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PSHB | INH | 37 | Os |

## Push CCR onto Stack

Operation
(SP) - \$0001 $\Rightarrow$ SP
(CCR) $\Rightarrow \mathrm{M}_{\mathrm{SP}}$
Decrements SP by one and loads the value in CCR into the address to which the SP points.
Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PSHC | INH | 39 | Os |

## Push D onto Stack

Operation $\quad(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}$
(A):(B) $\Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$

Decrements SP by two and loads the value in A into the address to which SP points. Loads the value in B into the address to which SP points plus one. After PSHD executes, SP points to the stacked value of A .

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can restore the saved CPU registers just before returning from the subroutine.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PSHD | INH | $3 B$ | OS |

## Push X onto Stack

Operation
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}$
$\left(\mathrm{X}_{\mathrm{H}}\right):\left(\mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
Decrements SP by two and loads the high byte of X into the address to which SP points. Loads the low byte of X into the address to which SP points plus one. After PSHX executes, SP points to the stacked value of the high byte of X.

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can restore the saved CPU registers just before returning from the subroutine.

## CCR

Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PSHX | INH | 34 | OS |

## Push Y onto Stack

Operation
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}$
$\left(\mathrm{Y}_{\mathrm{H}}\right):\left(\mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
Decrements SP by two and loads the high byte of Y into the address to which SP points. Loads the low byte of Y into the address to which SP points plus one. After PSHY executes, SP points to the stacked value of the high byte of Y.

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can restore the saved CPU registers just before returning from the subroutine.

CCR
Effects


Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PSHY | INH | 35 | OS |

Operation $\quad\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{A}$
$(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$
Loads A from the address to which SP points. Then increments SP by one.
Pull instructions are commonly used at the end of a subroutine to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PULA | INH | 32 | ufO |

## Pull B from Stack

Operation $\quad\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{B}$

$$
(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}
$$

Loads B from the address to which SP points. Then increments SP by one.
Pull instructions are commonly used at the end of a subroutine to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PULB | INH | 33 | ufO |

## Pull CCR from Stack

Operation $\quad\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{CCR}$
$(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$
Loads CCR from the address to which SP points. Then increments SP by one.
Pull instructions are commonly used at the end of a subroutine to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Condition codes take on the value pulled from the stack, except that the $X$ mask bit cannot change from 0 to 1. Software can leave the $X$ bit set, leave it cleared, or change it from 1 to 0 , but it can only be set by a reset or by recognition of an $\overline{\mathrm{XIRQ}}$ interrupt.

Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PULC | INH | 38 | ufO |

Pull D from Stack

Operation $\quad\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{A}: \mathrm{B}$
$(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$
Loads the high byte of D from the address to which SP points. Loads the low byte of D from the address to which SP points plus one. Then increments SP by two.

Pull instructions are commonly used at the end of a subroutine to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PULD | INH | 3 A | UfO |

Operation
$\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}$ $(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$

Loads the high byte of X from the address to which SP points. Loads the low byte of X from the address to which SP points plus one. Then increments SP by two.

Pull instructions are commonly used at the end of a subroutine to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PULX | INH | 30 | UfO |

## Pull Y from Stack

Operation $\quad\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}$

$$
(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}
$$

Loads the high byte of Y from the address to which SP points. Loads the low byte of Y from the address to which SP points plus one. Then increments SP by two.

Pull instructions are commonly used at the end of a subroutine to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

## CCR

## Effects



Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| PULY | INH | 31 | UfO |

Fuzzy Logic Rule Evaluation

Operation MIN - MAX rule evaluation
Performs an unweighted evaluation of a list of rules, using fuzzy inputs to produce fuzzy outputs. REV can be interrupted, so it does not adversely affect interrupt latency.

REV uses an 8-bit unsigned offset from a base address stored in Y to determine the address of each fuzzy input and fuzzy output. Each rule in the knowledge base must consist of a table of 8-bit antecedent offsets followed by a table of 8 -bit consequent offsets. The value $\$ \mathrm{FE}$ marks boundaries between antecedents and consequents and between successive rules. The value $\$$ FF marks the end of the rule list.

REV begins with the address pointed to by the first rule antecedent and evaluates successive fuzzy input values until it finds an $\$$ FE separator. Operation is similar to that of a MINA instruction. The smallest input value is the truth value of the rule. Then, beginning with the address pointed to by the first rule consequent, REV compares the truth value to successive fuzzy output values until it finds another $\$$ FE separator. If the truth value is greater than the current output value, REV writes it to the output. Operation is similar to that of a MAXM instruction. Rule processing continues up to the $\$$ FF terminator

Before executing REV, clear fuzzy outputs and initialize A, CCR, X, and Y. Load A with $\$$ FF. Clear the $V$ bit. Load X with the address of the first 8 -bit rule element in the list. Load Y with the base address for fuzzy inputs and fuzzy outputs.

X points to the element in the rule list that is being evaluated. REV updates X so that execution can resume correctly in case of an interrupt. After execution, X points to the address after the $\$$ FF separator at the end of the rule list.

Y points to the base address for the fuzzy inputs and fuzzy outputs. The value in Y does not change during execution.

A holds intermediate results. During antecedent processing, a MIN function compares each fuzzy input to the value in A and writes the smaller value to A. After evaluation of all antecedents, A contains the smallest input value. This is the truth value used during consequent processing. For subsequent rules, REV reinitializes A with $\$$ FF when it finds an $\$$ FE separator. After execution, A contains the truth value for the last rule.

The V bit signals whether antecedents (0) or consequents (1) are being processed. V must be initialized to 0 for processing to begin with the antecedents of the first rule. The value of V changes as $\$$ FE separators are encountered. After execution, V should equal 1 , because the last element before the $\$ F F$ terminator should be a rule consequent. If V is 0 at the end of execution, the rule list is incorrect.

## CCR

Effects


V: Set unless rule structure is incorrect
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| REV | Special | 183 A | OrfttxO <br> $\mathrm{ff}+\mathrm{Orf}^{2}$ |

NOTES:

1. The 3-cycle ttx loop is executed once for each element in the rule list.
2. These are additional cycles caused by an interrupt: $f f$ is a 2-cycle exit sequence and Orf is a 3-cycle re-entry sequence. Execution resumes with a prefetch of the last antecedent or consequent being processed at the time of the interrupt.

Fuzzy Logic Rule Evaluation, Weighted

Operation MIN - MAX rule evaluation with optional rule weighting
Performs either weighted or unweighted evaluation of a list of rules, using fuzzy inputs to produce fuzzy outputs. REVW can be interrupted, so it does not adversely affect interrupt latency.

Each rule in the knowledge base must consist of a table of 16-bit antecedent pointers followed by a table of 16 -bit consequent pointers. The value \$FFFE marks boundaries between antecedents and consequents and between successive rules. The value \$FFFF marks the end of the rule list.

In weighted evaluation, a table of 8 -bit weighting factors, one per rule, must be stored in memory.

REVW begins with the address pointed to by the first rule antecedent, and evaluates successive fuzzy input values until it finds an \$FFFE separator. Operation is similar to that of a MINA instruction. The smallest input value is the truth value of the rule. If weighted evaluation is enabled, the truth value is modified. Then, beginning with the address pointed to by the first consequent, REVW compares the truth value to successive fuzzy output values until it finds another \$FFFE. If the truth value is greater than the current output value, REVW writes it to the output. Operation is similar to that of a MAXM instruction. Rule processing continues up to the \$FFFF terminator.

Before executing REVW, clear fuzzy outputs and initialize A, CCR, X, and Y. Load A with $\$ F F$. Clear the V bit. Set or clear the C bit for weighted or unweighted evaluation. For weighted evaluation, load Y with the first item in a table of 8-bit weighting factors. Load X with the address of the first 16 -bit element in the list.

X points to the element in the list that is being evaluated. REVW updates X so that execution can resume after an interrupt. After execution, X points to the address after the \$FFFF separator at the end of the list.

Y points to the current weighting factor. REVW updates Y so that execution can resume after an interrupt. After execution, Y points to the last weighting factor used. Y does not change in unweighted evaluation.

A holds intermediate results. During antecedent processing, a MIN function compares each fuzzy input to the value stored in A and writes the smaller value to A. After evaluation of all antecedents, A contains the smallest input value. In unweighted evaluation, this is the truth value for consequent processing. In weighted evaluation, it is multiplied by the quantity rule weight +1 , and the upper eight bits of the result replace the value in A. REVW reinitializes A with $\$$ FF when it finds an \$FFFE separator. After execution, A holds the truth value for the last rule.

The V bit signals whether antecedents (0) or consequents (1) are being processed. V must be initialized to 0 for processing to begin with the antecedents of the first rule. The value of V changes as \$FFFE separators are found. After execution, V should equal 1, because the last element before the $\$ \mathrm{FF}$ end marker should be a rule consequent. If V is equal to 0 at the end of execution, the rule list is incorrect.

CCR Effects

| $\mathbf{S}$ |  | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{l}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | $\mathbf{C}$ |  |  |  |  |  |  |
| - | ? | - | $?$ | $?$ | $\Delta$ | $!$ |  |

V: Set unless rule structure is incorrect
C: 1 selects weighted rule evaluation; 0 selects unweighted rule evaluation
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| REVW | Special | 18 3B | ```ORftTxO1 or ORftTfRfO2 ffff + ORf }\mp@subsup{}{}{3``` |

NOTES:

1. Weighting not enabled; the 3-cycle $t \mathrm{Tx}$ loop is executed once for each element in the rule list.
2. Weighting enabled; the 3 -cycle $t T x$ loop expands to $t T f R f$ for separators.
3. These are additional cycles caused by an interrupt: $f f f f$ is a 4 -cycle exit sequence and ORf is a 3-cycle re-entry sequence. Execution resumes with a prefetch of the last antecedent or consequent being processed at the time of the interrupt.


Shifts all bits of M one place to the left. Bit 0 is loaded from the C bit. The C bit is loaded from the most significant bit of M. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the left, the sequence ASL LOW, ROL MID, ROL HIGH could be used where LOW, MID, and HIGH refer to the low, middle, and high bytes of the 24-bit value, respectively.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\mathrm{N} \cdot \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift)
C: M7; set if the MSB of M was set before the shift; cleared otherwise
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ROL opr16a | EXT | 75 hh 11 | rPwo |
| ROL oprx0_xysppc | IDX | 65 xb | rPw |
| ROL oprx9,xysppc | IDX1 | 65 xb ff | rPwo |
| ROL oprx $16, x y s p p c$ | IDX2 | 65 xb ee ff | frPwP |
| ROL [D,xysppc] | [D,IDX] | 65 xb | fIfrPw |
| ROL [oprx16,xysppc] | [IDX2] | 65 xb ee ff | fIPrPw |

## Operation



Shifts all bits of A one place to the left. Bit 0 is loaded from the C bit. The C bit is loaded from the most significant bit of A. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the left, the sequence ASL LOW, ROL MID, ROL HIGH could be used where LOW, MID and HIGH refer to the low, middle, and high bytes of the 24-bit value, respectively.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\bar{N} \cdot \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift)
C: A7; set if the MSB of A was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ROLA | INH | 45 | 0 |

## Rotate Left B

## Operation



Shifts all bits of B one place to the left. Bit 0 is loaded from the C bit. The C bit is loaded from the most significant bit of B. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the left, the sequence ASL LOW, ROL MID, ROL HIGH could be used where LOW, MID and HIGH refer to the low, middle, and high bytes of the 24-bit value, respectively.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\mathbf{C}$ |  |  |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\bar{N} \cdot \mathrm{C}]$ (for N and C after the shift); set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift)
$C$ : $B 7$; set if the MSB of $B$ was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| ROLB | INH | 55 | 0 |

## Operation



Shifts all bits of M one place to the right. Bit 7 is loaded from the C bit. The C bit is loaded from the least significant bit of M . Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the right, the sequence LSR HIGH, ROR MID, ROR LOW could be used where LOW, MID and HIGH refer to the low, middle, and high bytes of the 24-bit value, respectively.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\overline{\mathrm{N}} \bullet \mathrm{C}]$ for N and C after the shift; cleared otherwise
C: M0; set if the LSB of $M$ was set before the shift; cleared otherwise
Code and
CPU Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| ROR opr16a | EXT | 76 hh 1 l | rPwO |
| ROR oprx0_xysppc | IDX | 66 xb | rPw |
| ROR oprx9, xysppc | IDX1 | 66 xb ff | rPwo |
| ROR oprx16,xysppc | IDX2 | 66 xb ee ff | frPwP |
| ROR [D,xysppc] | [D,IDX] | 66 xb | fIfrPw |
| ROR [oprx16,xysppc] | [IDX2] | 66 xb ee ff | fIPrPw |

## Operation



Shifts all bits of A one place to the right. Bit 7 is loaded from the C bit. The C bit is loaded from the least significant bit of A. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the right, the sequence LSR HIGH, ROR MID, ROR LOW could be used where LOW, MID and HIGH refer to the low, middle, and high bytes of the 24-bit value, respectively.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\overline{\mathrm{N}} \bullet \mathrm{C}]$ for N and C after the shift; cleared otherwise
C: AO; set if the LSB of $A$ was set before the shift; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| RORA | INH | 46 | 0 |

## Operation



Shifts all bits of B one place to the right. Bit 7 is loaded from the C bit. The C bit is loaded from the least significant bit of B. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the right, the sequence LSR HIGH, ROR MID, ROR LOW could be used where LOW, MID and HIGH refer to the low, middle, and high bytes of the 24-bit value, respectively.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}] \mid[\mathrm{N} \bullet \mathrm{C}]$ for N and C after the shift; cleared otherwise
$C$ : $B 0$; set if the LSB of $B$ was set before the shift; cleared otherwise
Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| RORB | INH | 56 | 0 |

Operation $\quad\left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow$ PPAGE
$(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$
$\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}}$
$(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$
Terminates subroutines in expanded memory invoked by the CALL instruction. Returns execution flow from the subroutine to the calling program. The program overlay page (PPAGE) register and the return address are restored from the stack; program execution continues at the restored address. For code compatibility purposes, CALL and RTC also execute correctly in MCUs that do not have expanded memory capability.

CCR
Effects


Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| RTC | INH | 0 A | UUnfPPP |

Operation

$$
\begin{aligned}
& \left(\mathrm{M}_{\mathrm{SP}}\right) \Rightarrow \mathrm{CCR},(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP} \\
& \left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{B}: \mathrm{A},(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP} \\
& \left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}},(\mathrm{SP})+\$ 0004 \Rightarrow \mathrm{SP} \\
& \left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}},(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP} \\
& \left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}},(\mathrm{SP})+\$ 0004 \Rightarrow \mathrm{SP}
\end{aligned}
$$

Restores the values of CPU registers CCR, B, A, X, PC, and Y from the stack.
The X bit may be cleared as a result of an RTI instruction, but cannot be set if it was cleared prior to execution of the RTI instruction.

If another interrupt is pending when RTI finishes restoring registers from the stack, the SP is adjusted to preserve stack content, and the new vector is fetched.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Condition codes take on the value pulled from the stack, except that the $X$ mask bit cannot change from 0 to 1. Software can leave the $X$ bit set, leave it cleared, or change it from 1 to 0 , but it can only be set by a reset or by recognition of an XIRQ interrupt.

Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| RTI | INH | OB | uUUUUPPP <br> or <br> uUUUUfVfPPP |

NOTES:

1. RTI takes 11 cycles if an interrupt is pending.

Return from Subroutine
RTS

Operation $\quad\left(\mathrm{M}_{\mathrm{SP}}\right):\left(\mathrm{M}_{\mathrm{SP}+1}\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}}$
$(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$
Restores the value of PC from the stack and increments SP by two. Program execution continues at the address restored from the stack.

CCR
Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| RTS | INH | 3D | UfPPP |

## Subtract B from A

Operation $\quad(\mathrm{A})-(\mathrm{B}) \Rightarrow \mathrm{A}$
Subtracts the value in B from the value in A and puts the result in A. The value in B is not affected. The C bit represents a borrow.

CCR
Effects


N: Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 00$; cleared otherwise
V: A7 • $\overline{\mathrm{B7}} \bullet \overline{\mathrm{R7}} \mid \overline{\mathrm{A7}} \bullet \mathrm{B7} \bullet \mathrm{R7}$; set if a two's complement overflow resulted from the operation; cleared otherwise
$C: \overline{A 7} \bullet B 7|B 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if the absolute value of $B$ is larger than the absolute value of $A$; cleared otherwise

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| SBA | INH | 1816 | 00 |

## Subtract with Carry from A

Operation
(A) - (M) - C $\Rightarrow \mathrm{A}$
or
(A) $-\mathrm{imm}-\mathrm{C} \Rightarrow \mathrm{A}$

Subtracts either the value in M and the C bit or an immediate value and the C bit from the value in A . Puts the result in A . The C bit represents a borrow.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{l}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{A} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R}} \mid \overline{\mathrm{A} 7} \bullet \mathrm{M} 7 \bullet \mathrm{R} 7$; set if a two's complement overflow resulted from the operation; cleared otherwise
$C: \overline{A 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if the absolute value of the content of memory plus previous carry is larger than the absolute value of A ; cleared otherwise

Code and CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| SBCA \#opr8i | IMM | 82 ii | P |
| SBCA opr8a | DIR | 92 dd | rPf |
| SBCA opr16a | EXT | B2 hh 11 | rPo |
| SBCA oprx0_xysppc | IDX | A2 2 xb | rPf |
| SBCA oprx9,xysppc | IDX1 | A 2 xb ff | rPO |
| SBCA oprx $16, x y$ sppo | IDX2 | A2 xb ee ff | frpe |
| SBCA [D, xysppc] | [D,IDX] | A 2 xb | fifrPf |
| SBCA [oprx16,xysppc] | [IDX2] | A2 xb ee ff | fiprpf |

## Subtract with Carry from B

Operation
(B) $-(\mathrm{M})-\mathrm{C} \Rightarrow \mathrm{B}$
or
(B) $-\mathrm{imm}-\mathrm{C} \Rightarrow \mathrm{B}$

Subtracts either the value in M and the C bit or an immediate value and the C bit from the value in $B$. Puts the result in $B$. The C bit represents a borrow.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{l}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : $\mathrm{B7} \cdot \overline{\mathrm{M} 7 \bullet} \cdot \overline{\mathrm{R}} \mid \overline{\mathrm{B7}} \bullet \mathrm{M} 7 \bullet \mathrm{R7}$; set if a two's complement overflow resulted from the operation; cleared otherwise
$C: \overline{B 7} \cdot M 7|M 7 \cdot R 7| R 7 \bullet \overline{B 7}$; set if the absolute value in $M$ plus previous carry is larger than the absolute value in $B$; cleared otherwise

Code and CPU Cycles

| Source Form | Address Mode |  | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: | :---: |
| SBCB \#opr8i | IMM | C2 | ii | P |
| SBCB opr8a | DIR |  | dd | rPf |
| SBCB opr16a | EXT |  | hh 11 | rPo |
| SBCB oprx0_xysppc | IDX | E2 |  | rPf |
| SBCB oprx9,xysppc | IDX1 |  | xb ff | rPO |
| SBCB oprx $16, x y$ sppc | IDX2 |  | xb ee ff | frpp |
| SBCB [D,xysppc] | [D,IDX] | E2 |  | fifrPf |
| SBCB [oprx16,xysppc] | [IDX2] |  | xb ee ff | fIPrPf |

Operation $\quad(C C R) \mid \$ 01 \Rightarrow \mathrm{CCR}$
Performs a logical inclusive OR of the value in the CCR and $\$ 01$. Puts the result in the CCR, setting the C bit. SEC assembles as ORCC \#\$01.

SEC can be used to initialize the C bit prior to a shift or rotate instruction involving the C bit.


C: Set
Code and
CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| SEC | IMM | 1401 | P |

Operation $\quad(C C R) \mid \$ 10 \Rightarrow C C R$
Performs a logical inclusive OR of the value in the CCR and $\$ 10$. Puts the result in the CCR, setting the I bit. SEI assembles as ORCC \#\$10. When the I bit is set, all I-maskable interrupts are inhibited.

CCR
Effects


I: Set
Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| SEI | IMM | 1410 | P |

Set V
(same as ORCC \#\$02)
Operation (CCR) $\mid \$ 02 \Rightarrow \mathrm{CCR}$
Performs a logical inclusive OR of the value in the CCR and $\$ 02$. Puts the result in the CCR, setting the V bit. SEV assembles as ORCC \#\$02.

CCR
Effects


V: Set
Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| SEV | IMM | 1402 | P |

If r1 bit $7=0$, then $\$ 00:(r 1) \Rightarrow r 2$
If r 1 bit $7=1$, then $\$ \mathrm{FF}:(\mathrm{r} 1) \Rightarrow \mathrm{r} 2$
Transfers the two's complement value in A, B, or CCR to the low byte of D, X, Y, or SP. Loads the high byte with $\$ 00$ if bit 7 is 0 or $\$ F F$ if bit 7 is 1 . The result is the 16 -bit sign-extended version of the original 8-bit value. SEX is an alternate mnemonic for the TFR r1,r2 instruction, The value in the original register does not change except in the case of SEX A,D (D is A:B).

## CCR

## Effects



Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| SEX $a b c, d x y s p$ | INH | B7 eb | P |


| Sign-Extend Postbyte (eb) Coding |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte | Object Code |  | Sign Extension |
| SEX A,TMP2 | $0000 \times 011$ | B7 | 03 | (\$00 or \$FF): $\mathrm{A} \Rightarrow \mathrm{TMP2}$ |
| SEX A, D | $0000 \times 100$ | B7 | 04 | (\$00 or \$FF): $A \Rightarrow D$ |
| SEX A, X | $0000 \times 101$ | B7 | 05 | (\$00 or \$FF): $A \Rightarrow X$ |
| SEX A,Y | 0000 X110 | B7 | 06 | (\$00 or \$FF): $A \Rightarrow Y$ |
| SEX A,SP | $0000 \times 111$ | B7 | 07 | (\$00 or \$FF): $\mathrm{A} \Rightarrow \mathrm{SP}$ |
| SEX B,TMP2 | $0001 \times 011$ | B7 | 13 | (\$00 or \$FF): $\mathrm{B} \Rightarrow$ TMP2 |
| SEX B, ${ }^{\text {d }}$ | 0001 X100 | B7 | 14 | (\$00 or \$FF): $\mathrm{B} \Rightarrow \mathrm{D}$ |
| SEX B,X | 0001 X101 | B7 | 15 | (\$00 or \$FF): $\mathrm{B} \Rightarrow \mathrm{X}$ |
| SEX B, Y | $0001 \times 110$ | B7 | 16 | (\$00 or \$FF): $\mathrm{B} \Rightarrow \mathrm{Y}$ |
| SEX B,SP | $0001 \times 111$ | B7 | 17 | (\$00 or \$FF): $\mathrm{B} \Rightarrow \mathrm{SP}$ |
| SEX CCR,TMP2 | $0010 \times 011$ | B7 | 23 | (\$00 or \$FF):CCR $\Rightarrow$ TMP2 |
| SEX CCR,D | 0010 X100 | B7 | 24 | (\$00 or \$FF):CCR $\Rightarrow$ D |
| SEX CCR, X | $0010 \times 101$ | B7 | 25 | (\$00 or \$FF):CCR $\Rightarrow \mathrm{X}$ |
| SEX CCR, ${ }^{\text {P }}$ | $0010 \times 110$ | B7 | 26 | (\$00 or \$FF):CCR $\Rightarrow$ Y |
| SEX CCR,SP | 0010 X111 | B7 | 27 | (\$00 or \$FF):CCR $\Rightarrow$ SP |

## Store Accumulator A

Operation $\quad(\mathrm{A}) \Rightarrow \mathrm{M}$
Stores the value in A in M. The value in A does not change.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| STAA opr8a | DIR | 5A dd | Pw |
| STAA opr16a | EXT | 7A hh 11 | Pwo |
| STAA oprx0_xysppc | IDX | 6A xb | Pw |
| STAA oprx9,xysppc | IDX1 | 6 A xb ff | Pwo |
| STAA oprx16,xysppc | IDX2 | $6 \mathrm{~A} x \mathrm{~b}$ ee ff | PwP |
| STAA [D,xysppc] | [D,IDX] | 6A xb | PIfw |
| STAA [oprx16,xysppc] | [IDX2] | $6 \mathrm{~A} x \mathrm{~b}$ ee ff | PIPw |

## Store Accumulator B

Operation
$(\mathrm{B}) \Rightarrow \mathrm{M}$
Stores the value in B in M. The value in B does not change.

## Effects



N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| STAB opr8a | DIR | 5B dd | Pw |
| STAB opr16a | EXT | 7B hh ll | Pwo |
| STAB oprx0_xysppc | IDX | 6 Bxb | Pw |
| STAB oprx9,xysppc | IDX1 | 6 Bxb ff | Pwo |
| STAB oprx16,xysppc | IDX2 | 6 Bxb ee ff | PwP |
| STAB [D,xysppc] | [D,IDX] | 6 B xb | PIfw |
| STAB [oprx16,xysppc] | [IDX2] | 6 Bxb ee ff | PIPw |

## Store D

Operation $\quad(\mathrm{A}):(\mathrm{B}) \Rightarrow \mathrm{M}: \mathrm{M}+1$
Stores the value in $A$ in $M$ and the value in $B$ in $M: M+1$. The values in $A$ and $B$ do not change.

## CCR

Effects


N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| STD opr8a | DIR | 5c dd | PW |
| STD opr16a | EXT | 7 Chh 11 | PWO |
| STD oprx0_xysppc | IDX | 6 C xb | PW |
| STD oprx9,xysppc | IDX1 | 6 Cxb ff | Pwo |
| STD oprx16,xysppc | IDX2 | 6 Cxb ee ff | PWP |
| STD [D,xysppc] | [D,IDX] | 6 Cxb | PIfW |
| STD [oprx16,xysppc] | [IDX2] | 6C xb ee ff | PIPW |

## STOP

## Stop Processing

Operation $\quad(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}, \mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},\left(\mathrm{Y}_{\mathrm{H}}\right):\left(\mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},\left(\mathrm{X}_{\mathrm{H}}\right):\left(\mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
(SP) $-\$ 0002 \Rightarrow \mathrm{SP},(\mathrm{B}):(\mathrm{A}) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP},(\mathrm{CCR}) \Rightarrow \mathrm{M}_{\mathrm{SP}}$
Stop all clocks
When the $S$ bit is set, STOP is disabled and operates like a 2-cycle NOP instruction. When S is cleared, STOP stacks CPU registers, stops all system clocks, and puts the device in standby mode. Standby mode minimizes power consumption. The contents of registers and the states of I/O pins do not change.

Asserting $\overline{\text { RESET }}, \overline{\text { XIRQ, }}$, or $\overline{\text { IRQ }}$ ends standby mode. If the clock reference crystal also stops during low-power mode, crystal startup delay lengthens recovery time.
If $\overline{\text { XIRQ }}$ is asserted while the X mask bit $=0$ ( $\overline{\mathrm{XIRQ}}$ interrupts enabled), execution resumes with a vector fetch for the $\overline{\mathrm{XIRQ}}$ interrupt. If the X mask bit $=1$ ( $\overline{\mathrm{XIRQ}}$ interrupts disabled), a 2 -cycle recovery sequence, including an O cycle, adjusts the instruction queue, and execution continues with the next instruction after STOP.

CCR
Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| STOP | INH | 18 3E | OOSSSSs f (enter stop mode) <br> fVfPPP (exit stop mode) <br> ff (continue stop mode) <br> OO (if stop mode disabled by S = 1) |

## Store SP

Operation $\quad\left(\mathrm{SP}_{\mathrm{H}}\right):\left(\mathrm{SP}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1$
Stores the high byte of SP in M and the low byte in $\mathrm{M}+1$.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| STS opr8a | DIR | 5 F dd | PW |
| STS opr16a | EXT | 7 Fhh 11 | Pwo |
| STS oprx0_xysppc | IDX | 6 F xb | PW |
| STS oprx9,xysppc | IDX1 | 6 Fxb ff | Pwo |
| STS oprx16,xysppc | IDX2 | 6 Fxb ee ff | PWP |
| STS [D,xysppc] | [D,IDX] | 6 Fxb | PIfW |
| STS [oprx16,xysppc] | [IDX2] | 6F xb ee ff | PIPW |

## Store X

Operation $\quad\left(\mathrm{X}_{\mathrm{H}}\right):\left(\mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1$
Stores the high byte of X in M and the low byte in $\mathrm{M}+1$.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| STX opr8a | DIR | 5 Edd | PW |
| STX opr16a | EXT | 7 E hh 11 | PWO |
| STX oprx0_xysppc | IDX | 6 Exb | PW |
| STX oprx9,xysppc | IDX1 | 6 Exb ff | Pwo |
| STX oprx16,xysppc | IDX2 | 6 Exb ee ff | PWP |
| STX [D, xysppc] | [D,IDX] | 6 Exb | PIfW |
| STX [oprx16,xysppc] | [IDX2] | 6 Exb ee ff | PIPW |

Store Y

Operation $\quad\left(\mathrm{Y}_{\mathrm{H}}\right):\left(\mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1$
Stores the high by of Y in M and the low byte in $\mathrm{M}+1$.

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| STY opr8a | DIR | 5D dd | PW |
| STY opr16a | EXT | 7D hh 11 | PWO |
| STY oprx0_xysppc | IDX | 6 D xb | PW |
| STY oprx9,xysppc | IDX1 | 6 D xb ff | PWo |
| STY oprx16,xysppc | IDX2 | $6 \mathrm{D} x \mathrm{beeff}$ | PWP |
| STY [D,xysppc] | [D,IDX] | 6 D xb | PIfW |
| STY [oprx16,xysppc] | [IDX2] | $6 \mathrm{D} x \mathrm{~b}$ ee ff | PIPW |

## Subtract from A

Operation $\quad(\mathrm{A})-(\mathrm{M}) \Rightarrow \mathrm{A}$
or
(A) - imm $\Rightarrow \mathrm{A}$

Subtracts either the value in M or an immediate value from the value in A . Puts the result in A . The C bit represents a borrow.

CCR
Effects

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise
$Z$ : Set if result is $\$ 00$; cleared otherwise
$\mathrm{V}: \mathrm{A} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R7}} \mid \overline{\mathrm{A}} \cdot \mathrm{M} 7 \bullet \mathrm{R} 7$; set if a two's complement overflow resulted from the operation; cleared otherwise
$C: \overline{A 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{A 7}$; set if the value in $M$ is larger than the value in $A$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| SUBA \#opr8i | IMM | 80 ii | P |
| SUBA opr8a | DIR | 90 dd | rPf |
| SUBA opr16a | EXT | B0 hh 11 | rPO |
| SUBA oprx0_xysppc | IDX | A0 xb | rPf |
| SUBA oprx9,xysppc | IDX1 | A0 xb ff | rPO |
| SUBA oprx $16, x y$ sppc | IDX2 | A0 xb ee ff | frpp |
| SUBA [D, xysppc] | [D,IDX] | A0 xb | fifrPf |
| SUBA [oprx16,xysppc] | [IDX2] | A0 xb ee ff | fIPrPf |

Subtract from B

Operation
(B) $-(\mathrm{M}) \Rightarrow \mathrm{B}$
or
(B) $-\mathrm{imm} \Rightarrow \mathrm{B}$

Subtracts either the value in M or an immediate value from the value in B. Puts the result in B. The C bit represents a borrow.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V : $\mathrm{B7} \cdot \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R7}} \mid \overline{\mathrm{B7}} \bullet \mathrm{M} 7 \bullet \mathrm{R7}$; set if a two's complement overflow resulted from the operation; cleared otherwise
$C: \overline{B 7} \bullet M 7|M 7 \bullet R 7| R 7 \bullet \overline{B 7}$; set if the value in $M$ is larger than the value in $B$; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| SUBB \#opr8i | IMM | C0 ii | P |
| SUBB opr8a | DIR | D0 dd | rPf |
| SUBB opr16a | EXT | F0 hh 11 | rPO |
| SUBB oprx0_xysppc | IDX | E0 xb | rPf |
| SUBB oprx9,xysppc | IDX1 | E0 xb ff | rPO |
| SUBB oprx16,xysppc | IDX2 | E0 xb ee ff | frPP |
| SUBB [D, xysppc] | [D,IDX] | E0 xb | fifrPf |
| SUBB [oprx16,xysppc] | [IDX2] | E0 xb ee ff | fIPrPf |

## Subtract from D

(A):(B) - (M): $(\mathrm{M}+1) \Rightarrow \mathrm{A}: \mathrm{B}$
or
(A):(B) $-\mathrm{imm} \Rightarrow \mathrm{A}: \mathrm{B}$

Subtracts either the value in $\mathrm{M}: \mathrm{M}+1$ or an immediate value from the value in D . Puts the result in D . The C bit represents a borrow.

## CCR

Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 0000$; cleared otherwise
V: D15 • $\overline{\mathrm{M} 15} \bullet \overline{\mathrm{R} 15} \mid \overline{\mathrm{D} 15} \bullet$ M15 • R15; set if a two's complement overflow resulted from the operation; cleared otherwise
C: $\overline{\mathrm{D} 15} \cdot \mathrm{M} 15|M 15 \bullet R 15| R 15 \cdot \bar{D} 15$; set if the value in $M$ is larger than the value in D ; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| SUBD \#opr16i | IMM | 83 jjkk | PO |
| SUBD opr8a | DIR | 93 dd | RPf |
| SUBD opr16a | EXT | B3 hh 11 | RPO |
| SUBD oprx0_xysppc | IDX | A3 xb | RPf |
| SUBD oprx9,xyssp | IDX1 | A3 xb ff | RPO |
| SUBD oprx16,xysppc | IDX2 | A3 xb ee ff | fRPP |
| SUBD [D,xysppc] | [D,IDX] | A3 xb | fifrpf |
| SUBD [oprx16,xysppc] | [IDX2] | A3 xb ee ff | fIPRPf |

## Software Interrupt

```
\((\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}, \mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\)
\((\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},\left(\mathrm{Y}_{\mathrm{H}}\right):\left(\mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\)
\((\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},\left(\mathrm{X}_{\mathrm{H}}\right):\left(\mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\)
\((\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},(\mathrm{B}):(\mathrm{A}) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}\)
\((\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP},(\mathrm{CCR}) \Rightarrow \mathrm{M}_{\mathrm{SP}}\)
\(1 \Rightarrow\) I
SWI vector \(\Rightarrow P C\)
```

Causes an interrupt without an external interrupt service request. Uses the address of the next instruction after SWI as a return address. Stacks the return address and CPU registers Y, X, B, A, and CCR, decrementing SP before each item is stacked. Sets the I bit and loads PC with the SWI vector. Instruction execution resumes at the address to which the vector points. SWI is not affected by the I bit.

## CCR

Effects


I: Set
Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| SWI | INH | 3 F | VSPSSPSsP $^{1}$ |

NOTES:

1. The CPU also uses the SWI processing sequence for hardware interrupts and unimplemented opcode traps. A variation of the sequence (VfPPP) is used for resets.

## Transfer A to B

Operation $\quad(\mathrm{A}) \Rightarrow \mathrm{B}$
Loads the value in A into B . The former value in B is lost; the value in A does not change. Unlike the general transfer instruction TFR A,B which does not affect condition code bits, the TAB instruction affects the $\mathrm{N}, \mathrm{Z}$, and V bits.

CCR
Effects

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TAB | INH | 180 E | 00 |

Transfer A to CCR<br>(same as TFR A,CCR)

Operation $\quad(\mathrm{A}) \Rightarrow \mathrm{CCR}$
Loads the value in A into the CCR. The value in A does not change. The X bit can be cleared as a result of a TAP, but cannot be set if it was cleared prior to execution of the TAP. If the I bit is cleared, there is a one-cycle delay before the system allows interrupt requests. This delay prevents interrupts from occurring between instructions in the sequences CLI, WAI and CLI, SEI. TAP assembles as TFR A,CCR.

## CCR

## Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Condition codes take on the value of the corresponding bit of accumulator A , except that the X mask bit cannot change from 0 to 1 . Software can leave the $X$ bit set, leave it cleared, or change it from 1 to 0 , but it can only be set by a reset or by recognition of an XIRQ interrupt.

Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TAP | INH | B7 02 | P |

(B) $\Rightarrow \mathrm{A}$

Loads the value in B into A . The former value in A is lost; the value in B does not change. Unlike the general transfer instruction TFR B,A, which does not affect condition code bits, the TBA instruction affects the $\mathrm{N}, \mathrm{Z}$, and V bits.

CCR
Effects

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
v : Cleared
Code and

Cycles

| Source Form | Address <br> Mode | Machine Code <br> (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TBA | INH | 180 F | 00 |

## Test and Branch if Equal to Zero

Operation If (counter) $=0$, then $(\mathrm{PC})+\$ 0003+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Tests the counter register A, B, D, X, Y, or SP. Branches to a relative destination if the counter register reaches zero. Rel is a 9-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 100$ to $\$ 0 \mathrm{FF}(-256$ to +255$)$ from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TBEQ abdxysp,rel9 | REL <br> (9-bit) | 04 lb rr | PPP (branch) <br> PPO (no branch) |


| Loop Primitive Postbyte (1b) Coding |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte ${ }^{1}$ | Object Code | Counter Register | Offset |
| TBEQ A, rel9 | $0100 \times 000$ | 0440 rr | A |  |
| TBEQ B, rel9 | $0100 \times 001$ | 0441 rr | B |  |
| TBEQ D, rel9 | $0100 \times 100$ | 0444 rr | D | Positive |
| TBEQ X, rel9 | $0100 \times 101$ | 0445 rr | X | Positive |
| TBEQ Y, rel9 | $0100 \times 110$ | 0446 rr | Y |  |
| TBEQ SP, rel9 | 0100 X111 | 0447 rr | SP |  |
| TBEQ A, rel9 | $0101 \times 000$ | 0450 rr | A |  |
| TBEQ B, rel9 | 0101 X001 | 0451 rr | B |  |
| TBEQ D, rel9 | 0101 X100 | 0454 rr | D | Negative |
| TBEQ X, rel9 | 0101 X101 | 0455 rr | X | Negative |
| TBEQ Y, rel9 | 0101 X110 | 0456 rr | Y |  |
| TBEQ SP, rel9 | 0101 X111 | 0457 rr | SP |  |

NOTES:

1. Bits $7: 6: 5$ select TBEQ or TBNE; bit 4 is the offset sign bit: bit 3 is not used; bits 2:1:0 select the counter register.

# : User Guide - S12CPU15UGET.scale Semiconductor, Inc. 

TBL

## Table Lookup and Interpolate

$(\mathrm{M})+[(\mathrm{B}) \times((\mathrm{M}+1)-(\mathrm{M}))] \Rightarrow \mathrm{A}$
Linearly interpolates and stores in A one of 256 values between a pair of data entries, Y1 and Y2, in a lookup table. Data entries represent y coordinates of line segment endpoints. Table entries and interpolated results are 8-bit values.


Before executing TBL, point an indexing register at the Y1 value closest to but less than or equal to the Y value to interpolate. Point to Y1 using any indexed addressing mode except indirect, 9-bit offset, and 16-bit offset. The next table entry after Y1 is Y2. Load B with a binary fraction (radix point to the left of the MSB) representing the ratio:
$(\mathrm{XL}-\mathrm{X} 1) \div(\mathrm{X} 2-\mathrm{X} 1)$
where
$\mathrm{X} 1=\mathrm{Y} 1$ and $\mathrm{X} 2=\mathrm{Y} 2$
XL is the x coordinate of the value to interpolate
The 8-bit unrounded result, YL, is calculated using the expression:
$\mathrm{YL}=\mathrm{Y} 1+[(\mathrm{B}) \times(\mathrm{Y} 2-\mathrm{Y} 1)]$
where
Y1 $=8$-bit data entry pointed to by the effective address
Y2 $=8$-bit data entry pointed to by the effective address plus one
The 16 -bit intermediate value $(\mathrm{B}) \times(\mathrm{Y} 2-\mathrm{Y} 1)$ has a radix point between bits 7 and 8 . The result in A is the sum of the upper 8 bits (the integer part) of the intermediate 16-bit value and the 8 -bit value Y 1 .

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

N: Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
C: Set if result can be rounded up; cleared otherwise
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TBL oprxO_xysppc | IDX | 183 Db | ORfffP |

## TBNE

Test and Branch if Not Equal to Zero

Operation If (counter) $\neq 0$, then (PC) $+\$ 0003+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Tests the counter register A, B, D, X, Y, or SP. Branches to a relative destination if the counter does not reach zero. Rel is a 9-bit two's complement offset for branching forward or backward in memory. Branching range is $\$ 100$ to $\$ 0 \mathrm{FF}(-256$ to +255$)$ from the address following the last byte of object code in the instruction.

## CCR

Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TBNE abdxysp,rel9 | REL <br> (9-bit) | 04 lb rr | PPP (branch) <br> PPO (no branch) |


| Loop Primitive Postbyte (1b) Coding |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte ${ }^{1}$ | Object Code | Counter Register | Offset |
| TBNE A, rel9 | $0110 \times 000$ | 0460 rr | A |  |
| TBNE B, rel9 | $0110 \times 001$ | 0461 rr | B |  |
| TBNE D, rel9 | $0110 \times 100$ | 0464 rr | D | Positive |
| TBNE X, rel9 | $0110 \times 101$ | 0465 rr | X | Positive |
| TBNE Y, rel9 | $0110 \times 110$ | 0466 rr | Y |  |
| TBNE SP, rel9 | $0110 \times 111$ | 0467 rr | SP |  |
| TBNE A, rel9 | 0111 X000 | 0470 rr | A |  |
| TBNE B, rel9 | 0111 X001 | 0471 rr | B |  |
| TBNE D, rel9 | 0111 X100 | 0474 rr | D | Negative |
| TBNE X, rel9 | 0111 X101 | 0475 rr | X | Negative |
| TBNE Y, rel9 | 0111 X110 | 0476 rr | Y |  |
| TBNE SP, rel9 | 0111 X111 | 0477 rr | SP |  |

NOTES:

1. Bits $7: 6: 5$ select TBEQ or TBNE; bit 4 is the offset sign bit: bit 3 is not used; bits 2:1:0 select the counter register.

Operation See the table on the next page.
Transfers the value in a source register A, B, CCR, D, X, Y, or SP to a destination register A, B, CCR, D, X, Y, or SP. Transfers involving TMP2 and TMP3 are reserved for Motorola use.

CCR
Effects

or


CCR bits affected only when the CCR is the destination register. The $X$ bit cannot change from 0 to 1 .
Software can leave the $X$ bit set, leave it cleared, or change it from 1 to 0 , but $X$ can only be set by a reset or by recognition of an XIRQ interrupt.

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TFR $a b c d x y s p, a b c d x y s p$ | INH | B7 eb | P |

(continued)

| Transfer Postbyte (eb) Coding |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Source Form | Postbyte | Object Code | Transfer | Source Form | Postbyte | Object Code | Transfer |
| TFR A, A | $0000 \times 000$ | B7 00 | $A \Rightarrow A$ | TFR B,A | 0100 X000 | B7 40 | $B \Rightarrow A$ |
| TFR A, B | $0000 \times 001$ | B7 01 | $A \Rightarrow B$ | TFR B, B | $0100 \times 001$ | B7 41 | $B \Rightarrow B$ |
| TFR A, CCR | $0000 \times 010$ | B7 02 | $A \Rightarrow C C R$ | TFR B,CCR | $0100 \times 010$ | B7 42 | $B \Rightarrow C C R$ |
| TFR A,TMP2 | $0000 \times 011$ | B7 03 | sex:A $\Rightarrow$ TMP2 | TFR D,TMP2 | $0100 \times 011$ | B7 43 | $\mathrm{D} \Rightarrow \mathrm{TMP2}$ |
| TFR A, D | $0000 \times 100$ | B7 04 | sex:A $\Rightarrow D$ | TFR D, D | $0100 \times 100$ | B7 44 | $\mathrm{D} \Rightarrow \mathrm{D}$ |
| TFR A, X | $0000 \times 101$ | B7 05 | sex: $A \Rightarrow X$ | TFR D, X | $0100 \times 101$ | B7 45 | $D \Rightarrow X$ |
| TFR A, Y | $0000 \times 110$ | B7 06 | sex: $A \Rightarrow Y$ | TFR D, Y | $0100 \times 110$ | B7 46 | $D \Rightarrow Y$ |
| TFR A, SP | 0000 X111 | B7 07 | sex:A $\Rightarrow$ SP | TFR D, SP | 0100 X111 | B7 47 | $D \Rightarrow S P$ |
| TFR B,A | 0001 X000 | B7 10 | $B \Rightarrow A$ | TFR X,A | 0101 X000 | B7 50 | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{A}$ |
| TFR B, B | 0001 X001 | B7 11 | $B \Rightarrow B$ | TFR X, B | 0101 X001 | B7 51 | $X_{L} \Rightarrow B$ |
| TFR B,CCR | $0001 \times 010$ | B7 12 | $B \Rightarrow C C R$ | TFR X,CCR | $0101 \times 010$ | B7 52 | $\mathrm{X}_{\mathrm{L}} \Rightarrow$ CCR |
| TFR B,TMP2 | 0001 X011 | B7 13 | sex:B $\Rightarrow$ TMP2 | TFR X,TMP2 | $0101 \times 011$ | B7 53 | $\mathrm{X} \Rightarrow$ TMP2 |
| TFR B, D | 0001 X100 | B7 14 | sex: $B \Rightarrow D$ | TFR X, D | 0101 X100 | B7 54 | $\mathrm{X} \Rightarrow \mathrm{D}$ |
| TFR B, X | 0001 X101 | B7 15 | sex: $B \Rightarrow X$ | TFR X, X | $0101 \times 101$ | B7 55 | $X \Rightarrow X$ |
| TFR B, Y | 0001 X110 | B7 16 | sex: $B \Rightarrow Y$ | TFR X,Y | $0101 \times 110$ | B7 56 | $X \Rightarrow Y$ |
| TFR B, SP | $0001 \times 111$ | B7 17 | sex: $B \Rightarrow$ SP | TFR X,SP | $0101 \times 111$ | B7 57 | $X \Rightarrow S P$ |
| TFR CCR,A | 0010 X000 | B7 20 | CCR $\Rightarrow$ A | TFR Y,A | 0110 X000 | B7 60 | $\mathrm{Y}_{\mathrm{L}} \Rightarrow \mathrm{A}$ |
| TFR CCR,B | $0010 \times 001$ | B7 21 | $C C R \Rightarrow B$ | TFR Y, B | $0110 \times 001$ | B7 61 | $Y_{L} \Rightarrow B$ |
| TFR CCR,CCR | $0010 \times 010$ | B7 22 | $\mathrm{CCR} \Rightarrow \mathrm{CCR}$ | TFR Y,CCR | $0110 \times 010$ | B7 62 | $Y_{L} \Rightarrow C C R$ |
| TFR CCR,TMP2 | $0010 \times 011$ | B7 23 | sex:CCR $\Rightarrow$ TMP2 | TFR Y,TMP2 | $0110 \times 011$ | B7 63 | $Y \Rightarrow$ TMP2 |
| TFR CCR,D | $0010 \times 100$ | B7 24 | sex:CCR $\Rightarrow \mathrm{D}$ | TFR Y, ${ }^{\text {T }}$ | $0110 \times 100$ | B7 64 | $\mathrm{Y} \Rightarrow \mathrm{D}$ |
| TFR CCR, X | $0010 \times 101$ | B7 25 | sex:CCR $\Rightarrow X$ | TFR Y, X | $0110 \times 101$ | B7 65 | $Y \Rightarrow X$ |
| TFR CCR, ${ }^{\text {TF }}$ | $0010 \times 110$ | B7 26 | sex:CCR $\Rightarrow Y$ | TFR Y, Y | $0110 \times 110$ | B7 66 | $Y \Rightarrow Y$ |
| TFR CCR,SP | 0010 X111 | B7 27 | sex:CCR $\Rightarrow$ SP | TFR Y,SP | 0110 X111 | B7 67 | $\mathrm{Y} \Rightarrow \mathrm{SP}$ |
| TFR TMP3, A | 0011 X000 | B7 30 | $\mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{A}$ | TFR SP,A | 0111 X000 | B7 70 | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{A}$ |
| TFR TMP3, B | 0011 X001 | B7 31 | $\mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{B}$ | TFR SP,B | 0111 X001 | B7 71 | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{B}$ |
| TFR TMP3,CCR | $0011 \times 010$ | B7 32 | TMP3 ${ }_{\text {L }} \Rightarrow$ CCR | TFR SP,CCR | 0111 X010 | B7 72 | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{CCR}$ |
| TFR TMP3,TMP2 | 0011 X011 | B7 33 | TMP3 $\Rightarrow$ TMP2 | TFR SP,TMP2 | 0111 X011 | B7 73 | SP $\Rightarrow$ TMP2 |
| TFR TMP3, ${ }^{\text {T }}$ | $0011 \times 100$ | B7 34 | $\text { TMP3 } \Rightarrow \mathrm{D}$ | TFR SP, D | 0111 X100 | B7 74 | $S P \Rightarrow D$ |
| TFR TMP3, X | $0011 \times 101$ | BY 35 | TMP3 $\Rightarrow$ X | TFR SP, X | $0111 \times 101$ | B7 75 | $S P \Rightarrow X$ |
| TFR TMP3, ${ }^{\text {T }}$ | 0011 X110 | B7 36 | $\text { TMP3 } \Rightarrow \mathrm{Y}$ | TFR SP,Y | 0111 X110 | B7 76 | $S P \Rightarrow Y$ |
| TFR TMP3,SP | $0011 \times 111$ | B7 37 | TMP3 $\Rightarrow$ SP | TFR SP, SP | 0111 X111 | B7 77 | SP $\Rightarrow$ SP |

## TPA

Operation $\quad(C C R) \Rightarrow A$
Transfers the value in CCR to A. The CCR value does not change. TPA assembles as TFR CCR,A.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TPA | INH | B7 20 | P |

## Unimplemented Opcode Trap

Operation

$$
\begin{aligned}
& (\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP} ; \mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1} \\
& (\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP} ;\left(\mathrm{Y}_{\mathrm{H}}\right):\left(\mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1} \\
& (\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP} ;\left(\mathrm{X}_{\mathrm{H}}\right):\left(\mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1} \\
& (\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP} ;(\mathrm{B}):(\mathrm{A}) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1} \\
& (\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP} ;(\mathrm{CCR}) \Rightarrow \mathrm{M}_{\mathrm{SP}} \\
& 1 \Rightarrow \mathrm{I} \\
& \text { (trap vector) } \Rightarrow \mathrm{PC}
\end{aligned}
$$

Traps unimplemented opcodes. There are opcodes in all 256 positions in the page 1 opcode map, but only 54 of the 256 positions on page two of the opcode map are used. If the CPU attempts to execute one of the unimplemented opcodes on page two, an opcode trap interrupt occurs. Unimplemented opcode traps are essentially interrupts that share the \$FFF8:\$FFF9 interrupt vector.

TRAP uses the next address after the unimplemented opcode as a return address. It stacks the return address, CPU registers $\mathrm{Y}, \mathrm{X}, \mathrm{B}, \mathrm{A}$, and CCR , decrementing the SP before each item is stacked. The I bit is then set, the PC is loaded with the trap vector, and instruction execution resumes at that location. This instruction is not maskable by the I bit.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | 1 | - | - | - | - |

I: Set
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TRAP trapnum | INH | $18 \mathrm{tn}^{1}$ | OVSPSSPSsP |

NOTES:

1. The value tn is an unimplemented page two opcode from $\$ 30$ to $\$ 39$ or $\$ 40$ to $\$$ FF.

Operation (M) - \$00
Subtracts $\$ 00$ from the value in M . The condition code bits reflect the result. The value in M does not change.

The TST instruction provides limited information when testing unsigned values. Since no unsigned value is less than 0, BLO and BLS have no utility following TST. While BHI can be used after TST, it performs the same function as BNE, which is preferred. After testing signed values, all signed branches are available.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ |  |  | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{N}$ | $\mathbf{V}$ | $\mathbf{C}$ |  |  |  |  |  |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 0 |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
C: Cleared
Code and
CPU
Cycles

| Source Form | Address Mode | Machine Code (Hex) | CPU Cycles |
| :---: | :---: | :---: | :---: |
| TST opr16a | EXT | F7 hh 11 | rPo |
| TST oprx0_xysppc | IDX | E7 xb | rPf |
| TST oprx9,xysppc | IDX1 | E7 xb ff | rPO |
| TST oprx16,xysppc | IDX2 | E7 xb ee ff | frPP |
| TST [D,xysppc] | [D,IDX] | E7 xb | fIfrPf |
| TST [oprx16,xysppc] | [IDX2] | E7 xb ee ff | fIPrPf |

Operation (A) - \$00
Subtracts $\$ 00$ from the value in A . The condition code bits reflect the result. The value in A does not change.

The TSTA instruction provides limited information when testing unsigned values. Since no unsigned value is less than 0, BLO and BLS have no utility following TSTA. While BHI can be used after TST, it performs the same function as BNE, which is preferred. After testing signed values, all signed branches are available.

CCR
Effects

| S | X | H | 1 | N | Z | v | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 0 |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
C: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TSTA | INH | 97 | 0 |

## TSTB

(B) $-\$ 00$

Subtracts $\$ 00$ from the value in B. The condition code bits reflect the result. The value in $B$ does not change.

The TSTB instruction provides limited information when testing unsigned values. Since no unsigned value is less than 0, BLO and BLS have no utility following TSTB. While BHI can be used after TST, it performs the same function as BNE, which is preferred. After testing signed values, all signed branches are available.

CCR
Effects

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 0 |

N : Set if MSB of result is set; cleared otherwise
Z: Set if result is $\$ 00$; cleared otherwise
V: Cleared
C: Cleared
Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TSTB | INH | D7 | 0 |

Transfer SP to X
(same as TFR SP,X)

Operation $\quad(\mathrm{SP}) \Rightarrow X$
Transfers the value in SP to X . The value in SP does not change. After a TSX instruction, X points at the last value that was stored on the stack. TSX assembles as TFR SP, X.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TSX | INH | B7 75 | P |

## Transfer SP to Y <br> (same as TFR SP,Y)

Operation $\quad(\mathrm{SP}) \Rightarrow \mathrm{Y}$
Transfers the value in SP to Y. The value in SP does not change. After a TSY instruction, Y points at the last value that was stored on the stack. TPY assembles as TFR SP,Y.

## CCR

Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TSY | INH | B7 76 | P |

Transfer X to SP<br>(same as TFR X,SP)

Operation $\quad(X) \Rightarrow S P$
Transfers the value in X to SP . The value in X does not change. TXS assembles as TFR X,SP.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TXS | INH | B7 57 | P |

## TYS

Transfer Y to SP<br>(same as TFR Y,SP)

Operation $\quad(\mathrm{Y}) \Rightarrow \mathrm{SP}$
Transfers the value in Y to SP . The value in Y does not change. TYS assembles as TFR Y,SP.

CCR
Effects


Code and CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| TYS | INH | B7 67 | P |

(SP) - $\$ 0002 \Rightarrow \mathrm{SP}, \mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},\left(\mathrm{Y}_{\mathrm{H}}\right):\left(\mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},\left(\mathrm{X}_{\mathrm{H}}\right):\left(\mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP},(\mathrm{B}):(\mathrm{A}) \Rightarrow \mathrm{M}_{\mathrm{SP}}: \mathrm{M}_{\mathrm{SP}+1}$
$(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP},(\mathrm{CCR}) \Rightarrow \mathrm{M}_{\mathrm{SP}}$
Stop CPU clocks
Puts the CPU into a wait state. Uses the address of the instruction following WAI as a return address. Stacks the return address and CPU registers Y, X, B, A, and CCR, decrementing SP before each item is stacked.

The CPU then enters a wait state for an integer number of bus clock cycles. During the wait state, CPU clocks are stopped, but other MCU clocks can continue to run. The CPU leaves the wait state when it senses an interrupt that has not been masked.

Upon leaving the wait state, the CPU sets the appropriate interrupt mask bit(s) and fetches the vector corresponding to the interrupt sensed. Program execution continues at the location to which the vector points.

CCR
Effects


Although the WAI instruction itself does not alter the condition codes, the interrupt that causes the CPU to resume processing causes the I bit (and the $X$ bit, if the interrupt was $\overline{\mathrm{XIRQ}}$ ) to be set as the interrupt vector is fetched.

Code and
CPU
Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| WAI | INH | $3 E$ | OSSSSS $f$ (before interrupt) <br> fVfPPP (after interrupt) |

Partial product $=(\mathrm{M}$ pointed to by X$) \times(\mathrm{M}$ pointed to by Y$)$
Sum of products (24-bit SOP) = previous SOP + partial product
Sum of weights $(16$-bit SOW$)=$ previous SOW $+($ M pointed to by Y$)$
$(\mathrm{X})+\$ 0001 \Rightarrow \mathrm{X} ;(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y},(\mathrm{B})-\$ 01 \Rightarrow \mathrm{~B}$
Repeat until B = \$00; leave SOP in Y:D, SOW in X
Calculates weighted averages of values in memory. Uses indexed (X) addressing to access one source operand list, and indexed (Y) addressing mode to access another source operand list. Accumulator B is the counter that controls the number of elements to be included in the weighted average.

For each data point pair, a 24-bit SOP and a 16-bit SOW accumulates in temporary registers. When B reaches zero (no more data pairs), the SOP goes in Y:D. The SOW goes in X. To get the final weighted average, divide (Y):(D) by (X) with an EDIV after the WAV.

WAV can be interrupted. If an interrupt occurs, the intermediate results (six bytes) are stacked in the order $\mathrm{SOW}_{[15: 0]}, \mathrm{SOP}_{[15: 0]}, \$ 00: \mathrm{SOP}_{[23: 16]}$. The wavr pseudoinstruction resumes WAV execution. The interrupt mechanism is reentrant; new WAV instructions can be started and interrupted while a previous WAV instruction is interrupted.

## CCR

Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| WAV | Special | 183 C | Offrrffffo <br> SSS+UUUrr |

NOTES:

1. The 7-cycle loop frrffff is the loop for one iteration of SOP and SOW accumulation.
2. These are additional cycles caused by interrupt: SSS is a three-cycle exit sequence and UUUrr is a five-cycle re-entry sequence. Six extra bytes of stack are used for intermediate values.
(D) $\Leftrightarrow(\mathrm{X})$

Exchanges the value in D with the value in X . XGDX assembles as EXG D, X.
CCR

## Effects



Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| XGDX | INH | B7 C5 | P |

: User Guide - S12CPU15EtGefscale Semiconductor, Inc.

## XGDY

## Exchange D with $Y$ (same as EXG D,Y)

(D) $\Leftrightarrow(\mathrm{Y})$

Exchanges the value in D with the value in Y. XGDY assembles as EXG D, Y.
CCR
Effects


Code and CPU Cycles

| Source Form | Address <br> Mode | Machine <br> Code (Hex) | CPU Cycles |
| :--- | :--- | :--- | :--- |
| XGDY | INH | B7 C6 | P |

## Appendix B Fuzzy Logic Support

## B. 1 General

This section describes the use of fuzzy logic in control systems, discusses the fuzzy logic instructions, and provides examples of fuzzy logic programs.

## B. 2 Introduction

There are four instructions that perform fuzzy logic tasks. Several other instructions are also useful in fuzzy logic programs.

This section explains the basic fuzzy logic algorithm for which the four fuzzy logic instructions are intended. Each fuzzy logic instruction is then explained in detail. Finally, other custom fuzzy logic algorithms are discussed, with emphasis on other useful instructions.

The four fuzzy logic instructions are:

- MEM - evaluates trapezoidal membership functions
- REV and REVW - perform unweighted or weighted MIN-MAX rule evaluation
- WAV - performs weighted average defuzzification on singleton output membership functions

Other instructions that are useful for custom fuzzy logic programs include MINA, EMIND, MAXM, EMAXM, TBL, ETBL, and EMACS. For higher resolution fuzzy programs, the extended math instructions are also useful. Indexed addressing modes help simplify access to fuzzy logic data structures stored as lists or tabular data structures in memory.

## B. 3 Fuzzy Logic Basics

This overview of basic fuzzy logic concepts is the background for a detailed explanation of the fuzzy logic instructions.

In general, fuzzy logic provides for definitions of sets that have fuzzy boundaries rather than the crisp boundaries of Aristotelian logic. The sets can overlap so that, for a particular input value, one or more sets may be true at the same time. As the input varies out of the range of one set and into the range of an adjacent set, the first set becomes progressively less true while the second set becomes progressively more true.

Fuzzy logic has membership functions that emulate human perceptions such as "temperature is warm," in which humans recognize gradual boundaries. This perception seems to be important to the human ability to solve certain types of complex problems that elude traditional control methods.

Fuzzy sets are a means of using linguistic expressions such as "temperature is warm" as labels in rules that can be evaluated with a high degree of numerical precision and repeatability. A specific set of input conditions always produces the same result, just as a conventional control system does. User Guide - S12CPu 15 Fiters.scale Semiconductor, Inc.

A microcontroller-based fuzzy logic control system has two parts:

- A fuzzy inference kernel which is executed periodically to determine system outputs based on current system inputs
- A knowledge base which contains membership functions and rules

Figure B-1 is a block diagram of this kind of fuzzy logic system.
The knowledge base can be developed by an application expert without any microcontroller programming experience. Membership functions are simply expressions of the expert's understanding of the linguistic terms that describe the system to be controlled. Rules are ordinary language statements that describe the actions a human expert would take to solve the application problem.

Rules and membership functions can be reduced to relatively simple data structures (the knowledge base) stored in nonvolatile memory. A fuzzy inference kernel can be written by a programmer who does not know how the application system works. All that the programmer needs to do with knowledge base information is store it in the memory locations used by the kernel.


Figure B-1 Block Diagram of a Fuzzy Logic System

One execution pass through the fuzzy inference kernel generates system output signals in response to current input conditions. The kernel is executed as often as needed to maintain control. If the kernel is executed more often than needed, processor bandwidth and power are wasted. On the other hand, delaying too long between passes can cause the system to get too far out of control. Choosing a periodic rate for a fuzzy control system is the same as it would be for a conventional control system.

## B.3.1 Fuzzification (MEM)

During the fuzzification step, the current system input values are compared to stored input membership functions to determine the degree to which each label of each system input is true. This is accomplished by finding the $y$-value for the current input value on a trapezoidal membership function for each label of each system input. The MEM instruction performs this calculation for one label of one system input. To perform the complete fuzzification task for a system, several MEM instructions must be executed, usually in a program loop structure.

Figure B-2 shows a system of three input membership functions, one for each label of the system input. The $x$-axis of all three membership functions represents the range of possible values of the system input. The vertical line through all three membership functions represents a specific system input value. The $y$-axis represents degree of truth and varies from completely false ( $\$ 00$ or $0 \%$ ) to completely true ( $\$ \mathrm{FF}$ or $100 \%)$. The $y$-value where the vertical line intersects each of the membership functions is the degree to which the current input value matches the associated label for this system input. For example, the expression "temperature is warm" is $25 \%$ true ( $\$ 40$ ). The value $\$ 40$ is stored to a RAM location, and is called a fuzzy input (in this case, the fuzzy input for "the temperature is warm"). There is a RAM location for each fuzzy input (for each label of each system input).

When the fuzzification step begins, the current value of the system input is in an accumulator, one index register points to the first membership function definition in the knowledge base, and a second index register points to the first fuzzy input in RAM. As each fuzzy input is calculated by executing a MEM instruction, the result is stored to the fuzzy input and both pointers are updated automatically to point to the locations associated with the next fuzzy input. The MEM instruction takes care of everything except counting the number of labels per system input and loading the current value of any subsequent system inputs.

The end result of the fuzzification step is a table of fuzzy inputs representing current system conditions.
:User Guide - S12CPU15UGefscale Semiconductor, Inc.


Figure B-2 Fuzzification Using Membership Functions

## B.3.2 Rule Evaluation (REV and REVW)

Rule evaluation is the central element of a fuzzy logic inference program. This step processes a list of rules from the knowledge base using current fuzzy input values from RAM to produce a list of fuzzy outputs in RAM. These fuzzy outputs can be thought of as raw suggestions for what the system output should be in response to the current input conditions. Before the results can be applied, the fuzzy outputs must be further processed, or defuzzified, to produce a single output value that represents the combined effect of all of the fuzzy outputs.

There are two variations of the rule evaluation instruction. The REV instruction provides for unweighted rules that are considered to be equally important. The REVW instruction is similar but allows each rule to have a weighting factor which is stored in a separate parallel data structure in the knowledge base. REV and REVW also differ in the way rules are encoded into the knowledge base.

An understanding of the structure and syntax of rules is needed to understand how a microcontroller performs the rule evaluation task. The following is an example of a typical rule.

If temperature is warm and pressure is high then heat is (should be) off.

At first glance, it seems that encoding this rule in a compact form understandable to the microcontroller would be difficult, but it is actually simple to reduce the rule to a small list of memory pointers. The left portion of the rule is a statement of input conditions and the right portion of the rule is a statement of output actions.

The left portion of a rule is made up of one or more (in this case two) antecedents connected by a fuzzy and operator. Each antecedent expression consists of the name of a system input, followed by is, followed by a label name. The label must be defined by a membership function in the knowledge base. Each antecedent expression corresponds to one of the fuzzy inputs in RAM. Since and is the only operator allowed to connect antecedent expressions, there is no need to include these in the encoded rule. The antecedents can be encoded as a simple list of pointers to (or addresses of) the fuzzy inputs to which they refer.

The right portion of a rule is made up of one or more (in this case one) consequents. Each consequent expression consists of the name of a system output, followed by $i s$, followed by a label name. Each consequent expression corresponds to a specific fuzzy output in RAM. Consequents for a rule can be encoded as a simple list of pointers to (or addresses of) the fuzzy outputs to which they refer.

The complete rules are stored in the knowledge base as a list of pointers or addresses of fuzzy inputs and fuzzy outputs. In order for the rule evaluation logic to work, there must be some means of knowing which pointers refer to fuzzy inputs, and which refer to fuzzy outputs. There also must be a way to know when the last rule in the system has been reached.

One method of organization is to have a fixed number of rules with a specific number of antecedents and consequents. A second method, employed in Motorola Freeware M68HC11 kernels, is to mark the end of the rule list with a reserved value, and use a bit in the pointers to distinguish antecedents from consequents. A third method of organization, used in the HCS12 CPU, is to mark the end of the rule list with a reserved value, and separate antecedents and consequents with another reserved value. This permits any number of rules, and allows each rule to have any number of antecedents and consequents, subject to availability of system memory.

Each rule is evaluated sequentially, but the rules as a group are treated as if they were all evaluated simultaneously. Two mathematical operations take place during rule evaluation. The fuzzy and operator corresponds to the mathematical minimum operation and the fuzzy or operation corresponds to the mathematical maximum operation. The fuzzy and is used to connect antecedents within a rule. The fuzzy or is implied between successive rules. Before evaluating any rules, all fuzzy outputs are cleared, meaning not true at all. As each rule is evaluated, the smallest (minimum) antecedent is taken to be the overall truth of the rule. This rule truth value is applied to each consequent of the rule (by storing this value to the corresponding fuzzy output) unless the fuzzy output is already larger (maximum). If two rules affect the same fuzzy output, the rule that is most true governs the value in the fuzzy output because the rules are connected by an implied fuzzy or.

In the case of rule weighting, the truth value for a rule is determined as usual by finding the smallest rule antecedent. Before applying this truth value to the consequents for the rule, the value is multiplied by a fraction from zero (rule disabled) to one (rule fully enabled). The resulting modified truth value is then applied to the fuzzy outputs.

The end result of the rule evaluation step is a table of suggested or raw fuzzy outputs in RAM. These values were obtained by plugging current conditions (fuzzy input values) into the system rules in the knowledge

User Guide - S12CPU155teresscale Semiconductor, Inc.
base. The raw results cannot be supplied directly to the system outputs because they may be ambiguous. For instance, one raw output can indicate that the system output should be medium with a degree of truth of $50 \%$ while, at the same time, another indicates that the system output should be low with a degree of truth of $25 \%$. The defuzzification step resolves these ambiguities.

## B.3.3 Defuzzification (WAV)

The final step in the fuzzy logic program combines the raw fuzzy outputs into a composite system output. Instead of the trapezoidal shapes used for inputs, singletons are typically used for output membership functions. As with the inputs, the x -axis represents the range of possible values for a system output. Singleton membership functions consist of the x-axis position for a label of the system output. Fuzzy outputs correspond to the $y$-axis height of the corresponding output membership function.

The WAV instruction calculates the numerator and denominator sums for weighted average of the fuzzy outputs according to the formula:

$$
\text { System Output }=\frac{\sum_{i=1}^{n} s_{i} F_{i}}{\sum_{i=1}^{n} F_{i}}
$$

where:
$n$ is the number of labels of a system output
$\mathrm{S}_{\mathrm{i}}$ are the singleton positions from the knowledge base
$\mathrm{F}_{\mathrm{i}}$ are the fuzzy outputs from RAM
For a common fuzzy logic program, $n$ is eight or less (though this instruction can handle any value to 255) and $\mathrm{S}_{\mathrm{i}}$ and $\mathrm{F}_{\mathrm{i}}$ are 8-bit values. The final divide is performed with a separate EDIV instruction placed immediately after the WAV instruction.

Before executing WAV, an accumulator must be loaded with the number of iterations ( n ), one index register must be pointed at the list of singleton positions in the knowledge base, and a second index register must be pointed at the list of fuzzy outputs in RAM. If the system has more than one system output, the WAV instruction is executed once for each system output.

## B. 4 Example Inference Kernel

Figure B-3 is a complete fuzzy inference kernel written in assembly language. Numbers in square brackets are cycle counts. The kernel uses two system inputs with seven labels each and one system output with seven labels. The program assembles to 57 bytes. It executes in about $54 \mu \mathrm{~s}$ at an $8-\mathrm{MHz}$ bus rate. The basic structure can easily be extended to a general-purpose system with a larger number of inputs and outputs.

Lines 1 to 3 set up pointers and load the system input value into the A accumulator.
Line 4 sets the loop count for the loop in lines 5 and 6.

Lines 5 and 6 make up the fuzzification loop for seven labels of one system input. The MEM instruction finds the $y$-value on a trapezoidal membership function for the current input value, for one label of the current input, and then stores the result to the corresponding fuzzy input. Pointers in X and Y are automatically updated by four and one so they point at the next membership function and fuzzy input respectively.

Line 7 loads the current value of the next system input. Pointers in X and Y already point to the right places as a result of the automatic update function of the MEM instruction in line 5.

Line 8 reloads a loop count.
Lines 9 and 10 form a loop to fuzzify the seven labels of the second system input. When the program drops to line 11 , the Y index register is pointing at the next location after the last fuzzy input, which is the first fuzzy output in this system.

| 01 | [2] | FUZZIFY | LDX | \#INPUT_MFS; Point at MF definitions |
| :---: | :---: | :---: | :---: | :---: |
| 02 | [2] |  | LDY | \#FUZ_INS ; Point at fuzzy input table |
| 03 | [3] |  | LDAA | CURRENT_INS; Get first input value |
| 04 | [1] |  | LDAB | \#7 ;7 labels per input |
| 05 | [5] | GRAD_LOOP | MEM | ; Evaluate one MF |
| 06 | [3] |  | DBNE | B,GRAD_LOOP; For 7 labels of 1 input |
| 07 | [3] |  | LDAA | CURRENT_INS+1; Get second input value |
| 08 | [1] |  | LDAB | \#7 ; 7 labels per input |
| 09 | [5] | GRAD_LOOP 1 | 1MEM | ; Evaluate one MF |
| 10 | [3] |  | DBNE | B,GRAD_LOOP1;For 7 labels of 1 input |
| 11 | [1] |  | LDAB | \#7 ; Loop count |
| 12 | [2] | RULE_EVAL | CLR |  |
| 13 | [3] |  | DBNE | b, RULE_EVAL; Loop to clr all fuzzy outs |
| 14 | [2] |  | LDX | \#RULE_START;Point at first rule element |
| 15 | [2] |  | LDY | \#FUZ_INS ; Point at fuzzy ins and outs |
| 16 | [1] |  | LDAA | \#\$FF ; Init A (and clears V-bit) |
| 17 | [3n+4] |  | REV | ;Process rule list |
| 18 | [2] | DEFUZ | LDY | \#FUZ_OUT ; Point at fuzzy outputs |
| 19 | [1] |  | LDX | \#SGLTN_POS;Point at singleton positions |
| 20 | [1] |  | LDAB | \#7 ; 7 fuzzy outs per COG output |
| 21 | [8b+9] |  | WAV | ; Calculate sums for wtd av |
| 22 | [11] |  | EDIV | ; Final divide for wtd av |
| 23 | [1] |  | TFR | Y D ; Move result to A:B |
| 24 | [3] |  | STAB | COG_OUT ; Store system output |
|  | * |  |  |  |
|  | ***** |  |  |  |

Figure B-3 Fuzzy Inference Engine
Line 11 sets the loop count to clear seven fuzzy outputs.
Lines 12 and 13 form a loop to clear all fuzzy outputs before rule evaluation starts.
Line 14 initializes the X index register to point at the first element in the rule list for the REV instruction.

Line 15 initializes the Y index register to point at the fuzzy inputs and outputs in the system. The rule list (for REV) consists of 8-bit offsets from this base address to particular fuzzy inputs or fuzzy outputs. The special value $\$ F E$ is interpreted by REV as a marker between rule antecedents and consequents.

Line 16 initializes the A accumulator to the highest 8-bit value in preparation for finding the smallest fuzzy input referenced by a rule antecedent. The LDAA \#\$FF instruction also clears the V bit in the condition code register so the REV instruction knows it is processing antecedents. During rule list processing, the V bit is toggled each time an $\$$ FE is detected in the list. The V bit indicates whether REV is processing antecedents or consequents.

Line 17 is the REV instruction, a self-contained loop to process successive elements in the rule list until an $\$ F F$ character is found. For a system of 17 rules with two antecedents and one consequent each, the REV instruction takes 259 cycles, but it is interruptible so it does not cause a long interrupt latency.

Lines 18 through 20 set up pointers and an iteration count for the WAV instruction.
Line 21 is the beginning of defuzzification. The WAV instruction calculates a sum-of-products and a sum-of-weights.

Line 22 completes defuzzification. The EDIV instruction performs a 32-bit by 16-bit divide on the intermediate results from WAV to get the weighted average.

Line 23 moves the EDIV result into the double accumulator.
Line 24 stores the low 8-bits of the defuzzification result.
This example inference program shows how easy it is to incorporate fuzzy logic into general applications using the HCS12 CPU. Code space and execution time are no longer serious factors in the decision to use fuzzy logic. The next section begins a much more detailed look at the fuzzy logic instructions.

## B. 5 MEM Instruction Details

This section provides a more detailed explanation of the membership function evaluation instruction (MEM), including details about abnormal special cases for improperly defined membership functions.

## B.5.1 Membership Function Definitions

Figure B-4 shows how a normal membership function is specified. Typically a software tool is used to input membership functions graphically, and the tool generates data structures for the target processor and software kernel. Alternatively, points and slopes for the membership functions can be determined and stored in memory with define-constant assembler directives.

An internal CPU algorithm calculates the y-value where the current input intersects a membership function. This algorithm assumes the membership function obeys some common-sense rules. If the membership function definition is improper, the results may be unusual. B.5.2 Abnormal Membership Function Definitions discusses these cases. The following rules apply to normal membership functions.

- $\$ 00 \leq$ point $1<\$ F F$
- $\$ 00<$ point $2 \leq \$ F F$
- point1 < point2
- The sloping sides of the trapezoid meet at or above \$FF

Each system input such as temperature has several labels such as cold, cool, normal, warm, and hot. Each label of each system input must have a membership function to describe its meaning in an unambiguous numerical way. Typically, there are three to seven labels per system input, but there is no practical restriction on this number as far as the fuzzification step is concerned.

## B.5.2 Abnormal Membership Function Definitions

In the HCS12 CPU, it is possible (and proper) to define crisp membership functions. A crisp membership function has one or both sides vertical (infinite slope). Since the slope value $\$ 00$ is not used otherwise, it is assigned to mean infinite slope to the MEM instruction.

Although a good fuzzy development tool does not allow the user to specify an improper membership function, it is possible to have program errors or memory errors which result in erroneous abnormal membership functions. Although these abnormal shapes do not correspond to any working systems, understanding how the HCS12 CPU treats these cases can be helpful for debugging.


Figure B-4 Defining a Normal Membership Function

A close examination of the MEM instruction algorithm shows how such membership functions are evaluated. Figure B-5 is a complete flow diagram for the execution of a MEM instruction. Each rectangular box represents one CPU bus cycle. The number in the upper left corner corresponds to the cycle number and the letter corresponds to the cycle type (refer to Appendix A Instruction Set and :User Guide - S12CPU15Uteptscale Semiconductor, Inc.

Commands for details). The upper portion of the box includes information about bus activity, if any, during this cycle. The lower portion of the box, which is separated by a dashed line, includes information about internal CPU processes. It is common for several internal functions to take place during a single CPU cycle. In cycle 3, for example, two 8-bit subtractions take place and a flag is set based on the results.


Figure B-5 MEM Instruction Flow Diagram

Consider 4a: If $\left(\left((\right.\right.$ slope_2 $=0)$ or $($ grade_2 > \$FF) $)$ and $\left.\left(f l a g \_d 12 n=0\right)\right)$.
The flag_d12n is zero as long as the input value in accumulator A is within the trapezoid. Everywhere outside the trapezoid, one or the other delta term is negative, and the flag equals one. Slope_2 equals zero indicates the right side of the trapezoid has infinite slope, so the resulting grade should be \$FF everywhere in the trapezoid, including at point_2, as far as this side is concerned. The term grade_2 greater than $\$ \mathrm{FF}$ means the value is far enough into the trapezoid that the right sloping side of the trapezoid has crossed above the $\$ F F$ cutoff level and the resulting grade should be $\$ F F$ as far as the right sloping side is concerned. 4a decides if the value is left of the right sloping side (grade $=\$ F F$ ), or on the sloping portion of the right side of the trapezoid (grade = grade $\_2$ ). 4 b could still override this tentative value in grade.

In 4 b , slope_1 is zero if the left side of the trapezoid has infinite slope (vertical). If so, the result (grade) should be $\$ F F$ at and to the right of point_1 everywhere within the trapezoid as far as the left side is concerned. The grade_1 greater than $\$$ FF term corresponds to the input being to the right of where the left sloping side passes the $\$ F F$ cutoff level. If either of these conditions is true, the result (grade) is left at the
value it got from 4 a . The else condition in 4 b corresponds to the input falling on the sloping portion of the left side of the trapezoid or possibly outside the trapezoid, so the result is grade equals grade_1. If the input is outside the trapezoid, flag_d12n is one and grade_1 and grade_2 would have been forced to $\$ 00$ in cycle 3. The else condition of 4 b sets the result to $\$ 00$.

The following special cases represent abnormal membership function definitions. The explanations describe how the specific algorithm in the HCS12 CPU resolves these unusual cases. The results are not all intuitively obvious, but rather fall out from the specific algorithm. Remember, these cases should not occur in a normal system.

## B.5.2.1 Abnormal Membership Function Case 1

This membership function is abnormal because the sloping sides cross below the $\$ F F$ cutoff level. The flag_d12n signal forces the membership function to evaluate to $\$ 00$ everywhere except from point_1 to point_2. Within this interval, the tentative values for grade_1 and grade_2 calculated in cycle 3 fall on the crossed sloping sides. In step 4 a , grade gets set to the grade_ 2 value, but in 4 b this is overridden by the grade_1 value, which ends up as the result of the MEM instruction. One way to say this is that the result follows the left sloping side until the input passes point_2, where the result goes to $\$ 00$.

Memory Definition: $\$ 60$, $\$ 80$, $\$ 04$, $\$ 04$; Point_1, Point_2, Slope_1, Slope_2

Graphical Representation:


How Interpreted:


Figure B-6 Abnormal Membership Function Case 1

If point_1 was to the right of point_2, flag_d12n would force the result to be $\$ 00$ for all input values. In fact, flag_d12n always limits the region of interest to the space greater than or equal to point_1 and less than or equal to point_2.

## B.5.2.2 Abnormal Membership Function Case 2

Like the previous example, the membership function in case 2 is abnormal because the sloping sides cross below the $\$ F F$ cutoff level, but the left sloping side reaches the $\$ F F$ cutoff level before the input gets to point_2. In this case, the result follows the left sloping side until it reaches the $\$$ FF cutoff level. At this point, the (grade_1>\$FF) term of 4 b kicks in, making the expression true so grade equals grade (no overwrite). The result from here to point_2 becomes controlled by the else part of 4 a (grade = grade_2), and the result follows the right sloping side. : User Guide - S12CPU15UGeq.Scale Semiconductor, Inc.

Memory Definition: \$60, \$C0, \$04, \$04; Point_1, Point_2, Slope_1, Slope_2

Graphical Representation


How Interpreted


Figure B-7 Abnormal Membership Function Case 2

## B.5.2.3 Abnormal Membership Function Case 3

The membership function in case 3 is abnormal because the sloping sides cross below the \$FF cutoff level, and the left sloping side has infinite slope. In this case, 4 a is not true, so grade equals grade_2. 4 b is true because slope_1 is zero, so 4 b does not overwrite grade.

Memory Definition: $\$ 60, \$ 80, \$ 00, \$ 04$; Point_1, Point_2, Slope_1, Slope_2

Graphical Representation


How Interpreted


Figure B-8 Abnormal Membership Function Case 3

## B. 6 REV, REVW Instruction Details

This section provides a more detailed explanation of the rule evaluation instructions, REV and REVW. The data structures that specify rules are somewhat different for the weighted versus unweighted versions of the instruction. One uses 8 -bit offsets in the encoded rules, while the other uses full 16 -bit addresses. This affects the size of the rule data structure and execution time.

## B.6.1 Unweighted Rule Evaluation (REV)

This instruction implements basic min-max rule evaluation. CPU registers are used for pointers and intermediate calculation results.

Since the REV instruction is essentially a list-processing instruction, execution time is dependent on the number of elements in the rule list. The REV instruction is interruptible, typically within three bus cycles, so it does not adversely affect worst-case interrupt latency. Since all intermediate results and instruction status are held in stacked CPU registers, the interrupt service code can even include independent REV and REVW instructions.

## B.6.1.1 Initialization Prior to Executing REV

Some CPU registers and memory locations need to be initialized before executing the REV instruction. X and Y index registers are index pointers to the rule list and the fuzzy inputs and outputs. The A accumulator holds intermediate calculation results and needs to be initially set to $\$ F F$. The V bit is an instruction status indicator showing whether antecedents or consequents are being processed. Initially, the V bit is cleared to indicate antecedents are being processed. The fuzzy outputs in working RAM locations need to be cleared to $\$ 00$. Improper initialization produces erroneous results.

The X index register is set to the address of the first element in the rule list (in the knowledge base). The REV instruction automatically updates this pointer so that the instruction can resume correctly if it is interrupted. After the REV instruction finishes, X points at the next address past the $\$ \mathrm{FF}$ separator character that marks the end of the rule list.

The Y index register is set to the base address for the fuzzy inputs and outputs in working RAM. Each rule antecedent is an unsigned 8 -bit offset from this base address to the referenced fuzzy input. Each rule consequent is an unsigned 8 -bit offset from this base address to the referenced fuzzy output. The Y index register remains constant throughout execution of the REV instruction.

The 8-bit A accumulator is used to hold intermediate calculation results during execution of the REV instruction. During antecedent processing, A starts out at \$FF and is replaced by any smaller fuzzy input that is referenced by a rule antecedent (MIN). During consequent processing, A holds the truth value for the rule. This truth value is stored to any fuzzy output that is referenced by a rule consequent, unless that fuzzy output is already larger (MAX).

Before execution of REV begins, A must be set to \$FF (the largest 8-bit value) because rule evaluation always starts with processing of the antecedents of the first rule. For subsequent rules in the list, A is automatically set to $\$$ FF when the instruction detects the $\$$ FE marker character between the last consequent of the previous rule, and the first antecedent of a new rule.

The instruction LDAA \#\$FF clears the V bit at the same time it initializes A to $\$$ FF. This satisfies the REV setup requirement to clear the V bit as well as the requirement to initialize A to $\$ \mathrm{FF}$. Once the REV instruction starts, the value in the V bit is automatically maintained as $\$$ FE separator characters are detected.

The final requirement to clear all fuzzy outputs to $\$ 00$ is part of the MAX algorithm. Each time a rule consequent references a fuzzy output, that fuzzy output is compared to the truth value for the current rule. If the current truth value is larger, it is written over the previous value in the fuzzy output. After all rules have been evaluated, the fuzzy output contains the truth value for the most-true rule that referenced that fuzzy output.

After REV finishes, A holds the truth value for the last rule in the rule list. The V bit should be one because the last element before the $\$ \mathrm{FF}$ end marker should have been a rule consequent. If V is zero after executing REV, it indicates the rule list was structured incorrectly.

## B.6.1.2 Interrupt Details

The REV instruction includes a three-cycle processing loop for each byte in the rule list including antecedents, consequents, and special separator characters. Within this loop, a check is performed to see User Guide - S12CPU15ƯGET.Zcale Semiconductor, Inc.
if any qualified interrupt request is pending. If an interrupt is detected, the current CPU registers are stacked and the interrupt is serviced. When the interrupt service routine finishes, an RTI instruction causes the CPU to recover its previous context from the stack, and the REV instruction is resumed as if it had not been interrupted.

When a REV instruction is interrupted, the stacked value of the program counter, PC, points to the REV instruction rather than the instruction that follows. This causes the CPU to try to execute a new REV instruction upon return from the interrupt. Since the CPU registers, including the V bit in the condition code register, indicate the current status of the interrupted REV instruction, the rule evaluation operation resumes where it was interrupted.

## B.6.1.3 Cycle-by-Cycle REV Details

The central element of the REV instruction is a three-cycle loop that is executed once for each byte in the rule list. There is a small amount of housekeeping activity to get this loop started as REV begins, and a small sequence to end the instruction. If an interrupt comes, there is a special small sequence to save CPU status on the stack before servicing the requested interrupt.

Figure B-9 is a REV instruction flow diagram. Each box represents one CPU clock cycle. Decision blocks and connecting arrows are considered to take no time at all. The letters in the upper left corner of each box are execution cycle codes (refer to Appendix A Instruction Set and Commands for details).

When a value is read from memory, it cannot be used by the CPU until the second cycle after the read takes place. This is due to access and propagation delays.

Since there is more than one flow path through the REV instruction, cycle numbers have a decimal place. This decimal place indicates which of several possible paths is being used. The CPU normally moves forward by one digit at a time within the same flow. The flow number is indicated after the decimal point in the cycle number. There are two exceptions possible to this orderly sequence through an instruction. The first is a branch back to an earlier cycle number to form a loop as in 6.0 to 4.0. The second type of sequence change is from one flow to a parallel flow within the same instruction such as 4.0 to 5.2 , which occurs if the REV instruction senses an interrupt. In this second type of sequence branch, the whole number advances by one and the flow number, the digit after the decimal point, changes to a new value.

In cycle 1.0 , the CPU does an optional program word access to replace the $\$ 18$ prebyte of the REV instruction. Notice that cycle 7.0 is also an O cycle. One of these cycles is a program word fetch, while the other is a free cycle in which the CPU does not access the bus. Although the $\$ 18$ page prebyte is part of the REV instruction, the CPU treats it as a separate single-cycle instruction.


Figure B-9 REV Instruction Flow Diagram

Rule evaluation begins at cycle 2.0 with a byte read of the first element in the rule list. Usually this is the first antecedent of the first rule, but the REV instruction can be interrupted, so this could be a read of any byte in the rule list. The X index register is incremented so it points to the next element in the rule list. Cycle 3.0 satisfies the required delay between a read and when data is valid to the CPU. Some internal

CPU housekeeping activity takes place during this cycle, but there is no bus activity. By cycle 4.0 , the rule element that was read in cycle 2.0 is available to the CPU

Cycle 4.0 is the first cycle of the main three-cycle rule evaluation loop. Depending on whether rule antecedents or consequents are being processed, the loop consists of cycles 4.0, 5.0, and 6.0 or $4.0,5.0$, and 6.1. This loop is executed once for every byte in the rule list, including the $\$$ FE separators and the $\$ \mathrm{FF}$ end-of-rules marker.

At each cycle 4.0, a fuzzy input or fuzzy output is read, except during the loop passes associated with the $\$ F E$ and $\$ F F$ marker bytes, in which no bus access takes place during cycle 4.0. The read access uses the Y index register as the base address and the previously read rule byte, $\mathrm{R}_{\mathrm{X}}$, as an unsigned offset from Y . The fuzzy input or output value read here is used during the next cycle 6.0 or 6.1 . Besides being the offset from $Y$ for this read, the previously read $R_{X}$ can be a separator character, $\$ F E$. If $R_{X}$ is $\$ F E$ and the $V$ bit was one, this indicates a switch from processing consequents of one rule to processing antecedents of the next rule. At this transition, the A accumulator is initialized to $\$ \mathrm{FF}$ to prepare for the min operation to find the smallest fuzzy input. Also, if $\mathrm{R}_{\mathrm{X}}$ is $\$$ FE, the V bit toggles to indicate the change from antecedents to consequents, or consequents to antecedents.

During cycle 5.0, a new rule byte is read unless this is the last loop pass, and $\mathrm{R}_{\mathrm{X}}$ is $\$ F F$, marking the end of the rule list. This new rule byte is not used until cycle 4.0 of the next pass through the loop.

Between cycle 5.0 and $6 . x$, the $V$ bit determines which of two paths to take. If $V$ is zero, antecedents are being processed and the CPU progresses to cycle 6.0 . If V is one, consequents are being processed and the CPU goes to cycle 6.1.

During cycle 6.0, the min operation compares the current value in the A accumulator to the fuzzy input that was read in the previous cycle 4.0 and puts the lower value in the $A$ accumulator. If $R_{X}$ is $\$ F E$, this is the transition between rule antecedents and rule consequents, and the min operation is skipped although the cycle is still used. Cycle $6.0 / 6.1$ is an x cycle because it could be a byte write or a free cycle.

If an interrupt arrives while the REV instruction is executing, REV can break between cycles 4.0 and 5.0 in an orderly fashion so that the rule evaluation operation can resume after the interrupt service. Cycles 5.2 and 6.2 adjust the PC and X index register so the REV operation can recover after the interrupt. In cycle $5.2, \mathrm{PC}$ is decremented so that it points to the currently-running REV instruction. After the interrupt, rule evaluation resumes, but the stacked values for the index registers, accumulator A, and CCR cause the operation to pick up where it left off. In cycle 6.2 , the X index register is decremented by one because the last rule byte needs to be refetched when the REV instruction resumes.

After cycle 6.2, the REV instruction is finished, and execution continues with the normal interrupt processing flow.

## B.6.2 Weighted Rule Evaluation (REVW)

This instruction implements a weighted variation of min-max rule evaluation. The weighting factors are stored in a table with one 8-bit entry per rule. The weight is used to multiply the truth value of the rule (minimum of all antecedents) by a value from zero to one to get the weighted result. This weighted result is then applied to the consequents, just as it would be for unweighted rule evaluation.

Since the REVW instruction is essentially a list-processing instruction, execution time depends on the number of rules and the number of elements in the rule list. The REVW instruction is interruptible, typically within three to five bus cycles, so it does not adversely affect worst-case interrupt latency. Since intermediate results and instruction status are held in stacked CPU registers, the interrupt service code can even include independent REV and REVW instructions.

The rule structure is different for REVW than for REV. For REVW, the rule list is made up of 16-bit elements rather than 8-bit elements. Each antecedent is represented by the full 16-bit address of the corresponding fuzzy input. Each rule consequent is represented by the full address of the corresponding fuzzy output.

The marker separating antecedents from consequents is the reserved 16 -bit value $\$$ FFFE, and the end of the last rule is marked by the reserved 16 -bit value $\$$ FFFF. Since $\$$ FFFE and $\$ F F F F$ are the addresses of the reset vector, there is never a fuzzy input or output at either of these locations.

## B.6.2.1 Initialization Prior to Executing REVW

Some CPU registers and memory locations need to be initialized before executing the REVW instruction. X and Y index registers are index pointers to the rule list and the list of rule weights. The A accumulator holds intermediate calculation results and needs to be initialized to $\$ F F$. The V bit is an instruction status indicator that shows whether antecedents or consequents are being processed. Initially the V bit is cleared to indicate antecedent processing. The C bit enables (1) or disables (0) rule weighting. The fuzzy outputs in working RAM locations need to be cleared to $\$ 00$. Improper initialization produces erroneous results.

Initialize the X index register with the address of the first element in the rule list (in the knowledge base). The REVW instruction automatically updates this pointer so that the instruction can resume correctly if it is interrupted. After the REVW instruction finishes, X points at the next address past the $\$$ FFFF separator word that marks the end of the rule list.

Initialize the Y index register with the starting address of the list of rule weights. Each rule weight is an 8 -bit value. The weighted result is the truncated upper eight bits of the 16 -bit result, which is derived by multiplying the minimum rule antecedent value ( $\$ 00-\$ F F$ ) by the weight plus one ( $\$ 001-\$ 100$ ). This method of weighting rules allows an 8-bit weighting factor to represent a value between zero and one inclusive.

The 8-bit A accumulator holds intermediate calculation results during execution of the REVW instruction. During antecedent processing, A starts out at $\$ F F$ and is replaced by any smaller fuzzy input that is referenced by a rule antecedent. If the C bit is one, rule weights are enabled, and the rule truth value is multiplied by the rule weight just before consequent processing starts. During consequent processing, A holds the weighted or unweighted truth value for the rule. This truth value is stored to any fuzzy output that is referenced by a rule consequent, unless that fuzzy output is already larger (MAX).

Before executing REVW, initialize A with \$FF (the largest 8-bit value) because rule evaluation always starts with processing of the antecedents of the first rule. For subsequent rules in the list, A is automatically set to $\$ F F$ when the instruction detects the $\$ F F F E$ marker word between the last consequent of the previous rule, and the first antecedent of a new rule.

Both the C and V bits must be initialized before starting a REVW instruction. Once the REVW instruction starts, the C bit remains constant and the value in the V bit is automatically maintained as \$FFFE separator words are detected.

The final requirement to clear all fuzzy outputs to $\$ 00$ is part of the MAX algorithm. Each time a rule consequent references a fuzzy output, the fuzzy output is compared to the weighted truth value for the current rule. If the current truth value is larger, it is written over the previous value in the fuzzy output. After all rules are evaluated, the fuzzy output contains the truth value for the most-true rule referencing that fuzzy output.

After REVW finishes, accumulator A holds the weighted truth value for the last rule in the rule list. The $V$ bit should be one because the last element before the \$FFFF end marker should be a rule consequent. If V is zero after executing REVW, it indicates the rule list is structured incorrectly.

## B.6.2.2 Interrupt Details

The REVW instruction includes a three-cycle processing loop for each word in the rule list. This loop expands to five cycles between antecedents and consequents to allow time for multiplication by the rule weight. Within this loop is a check to see if any qualified interrupt request is pending. If an interrupt is detected, the CPU registers are stacked and the interrupt request is serviced. When the interrupt service routine finishes, an RTI instruction causes the CPU to recover its previous context from the stack, and the REVW instruction resumes as if it had not been interrupted.

When a REVW instruction is interrupted, the stacked value of the program counter, PC, points to the REVW instruction rather than the instruction that follows. This causes the CPU to try to execute a new REVW instruction upon return from the interrupt. Since the CPU registers, including the C and V bits in the condition code register, indicate the status of the interrupted REVW instruction, the rule evaluation operation resumes where it was interrupted.

## B.6.2.3 Cycle-by-Cycle REVW Details

The central element of the REVW instruction is a three-cycle loop that is executed once for each word in the rule list. This loop takes five cycles in the special-case pass in which weights are enabled $(\mathrm{C}=1)$ and the $\$$ FFFE separator word is read between the rule antecedents and the rule consequents. There is a small amount of housekeeping activity to get this loop started as REVW begins and a small sequence to end the instruction. If an interrupt request comes, there is a special small sequence to save CPU status on the stack before the interrupt is serviced.

Figure B-10 is a detailed flow diagram for the REVW instruction. Each rectangular box represents one CPU clock cycle. Decision blocks and connecting arrows are considered to take no time at all. The letters in the small rectangles in the upper left corner of each box correspond to the execution cycle codes (refer to Appendix A Instruction Set and Commands for details).

In cycle 2.0 , the first element of the rule list, a 16-bit address, is read from memory. Due to propagation delays, this value cannot be used for calculations until two cycles later in cycle 4.0. The X index register is incremented by two to point to the next element of the rule list.

The operations performed in cycle 4.0 depend on the value of the word read from the rule list. \$FFFE is a special token that indicates a transition from antecedents to consequents, or from consequents to
antecedents of a new rule. The V bit toggles at every $\$$ FFFE encountered and indicates which transition is taking place. If V is zero, a change from antecedents to consequents is taking place, and it is time to apply weighting if weighting is enabled. The address in TMP2, derived from Y, is used to read the weight byte from memory. In this case, there is no bus access in cycle 5.0, but the index into the rule list is updated to point to the next rule element.

The old value of $\mathrm{X}\left(\mathrm{X}_{0}\right)$ is temporarily held on internal nodes, so it can be used to access a rule word in cycle 7.2. The read of the rule word is timed to start two cycles before it is used in cycle 4.0 of the next loop pass. The multiply takes place in cycles 6.2 through 8.2. The 8 -bit weight from memory is incremented, possibly overflowing to $\$ 100$, before the multiply, and the upper eight bits of the 16 -bit internal result are the weighted result. By using weight +1 , the result can range from $0.0 \times \mathrm{A}$ to $1.0 \times \mathrm{A}$. After 8.2, flow continues to the next loop pass at cycle 4.0.

At cycle 4.0, if $\mathrm{R}_{\mathrm{X}}$ is $\$ F F F E$ and V was one, a change from consequents to antecedents of a new rule is taking place, so accumulator A must be reinitialized to $\$ F F$. During processing of rule antecedents, A is updated with the smaller of A and the current fuzzy input (cycle 6.0). Cycle 5.0 usually reads the next rule word and updates the pointer in $X$. This read is skipped if the current $\mathrm{R}_{\mathrm{X}}$ is the end of rules mark, \$FFFF. If this is a weight multiply pass, the read is delayed until cycle 7.2. During processing of consequents, cycle 6.1 optionally updates a fuzzy output if the value in accumulator A is larger.

User Guide - S12CPU15tterps.scale Semiconductor, Inc.


Figure B-10 REVW Instruction Flow Diagram

After all rules are processed, cycle 7.0 updates the PC to point at the next instruction. If weights are enabled, Y is updated to point at the location that immediately follows the last rule weight.

## B. 7 WAV Instruction Details

The WAV instruction performs weighted average calculations used in defuzzification. The pseudoinstruction wavr resumes an interrupted weighted average operation. WAV calculates the numerator and denominator sums using:

$$
\text { system output }=\frac{\sum_{i=1}^{n} S_{i} F_{i}}{\sum_{i=1}^{n} F_{i}}
$$

where
$n$ is the number of labels of a system output
$\mathrm{S}_{\mathrm{i}}$ are the singleton positions from the knowledge base (8-bit values)
$\mathrm{F}_{\mathrm{i}}$ are the fuzzy outputs from RAM (8-bit values)
The 8-bit B accumulator holds the iteration count n. Internal temporary registers hold intermediate sums, 24 bits for the numerator and 16 bits for the denominator. This makes this instruction suitable for n values up to 255 although eight is a more typical value. The final long division is performed with a separate EDIV instruction immediately after the WAV instruction. The WAV instruction returns the numerator and denominator sums in the correct registers for the EDIV. EDIV performs the unsigned division $\mathrm{Y}=\mathrm{Y}: \mathrm{D} \div$ X , remainder in D .

Execution time for this instruction depends on the number of iterations which equals the number of labels for the system output. WAV is interruptible so that worst-case interrupt latency is not affected by the execution time for the complete weighted average operation. WAV includes initialization for the 24 -bit and 16-bit partial sums so the first entry into WAV looks different than a resume-from-interrupt operation. The CPU handles this difficulty with a pseudo-instruction, wavr, which is specifically intended to resume an interrupted weighted average calculation. Refer to B.7.3 Cycle-by-Cycle Details for WAV and wavr for details.

## B.7.1 Initialization Prior to Executing WAV

Before executing the WAV instruction, index registers X and Y and accumulator B must be initialized. Index register $X$ is a pointer to the $S_{i}$ singleton list; $X$ must have the address of the first singleton value in the knowledge base. Index register $Y$ is a pointer to the fuzzy outputs $\mathrm{F}_{\mathrm{i}} . \mathrm{Y}$ must have the address of the first fuzzy output for this system output. Accumulator B contains the iteration count n and must be initialized with the number of labels for this system output.

## B.7.2 WAV Interrupt Details

The WAV instruction includes an 8-cycle processing loop for each label of the system output. Within this loop, the CPU checks to see whether a qualified interrupt request is pending. If an interrupt request is detected, the CPU registers and the current values of the internal temporary registers for the 24-bit and 16 -bit sums are stacked, and the interrupt is serviced.

A special processing sequence is executed when an interrupt is detected during a weighted average calculation. This exit sequence adjusts the PC so that it points to the second byte of the WAV object code (\$3C) before the PC is stacked. Upon return from the interrupt, the $\$ 3 \mathrm{C}$ value is interpreted as a wavr pseudoinstruction. The wavr pseudoinstruction causes the CPU to execute a special WAV resumption sequence. The wavr recovery sequence adjusts the PC so that it looks as it did during execution of the original WAV instruction, then jumps back into the WAV processing loop. If another interrupt request occurs before the weighted average calculation finishes, the PC is adjusted again as it was for the first interrupt. WAV can be interrupted any number of times, and additional WAV instructions can be executed while a WAV instruction is interrupted.

## B.7.3 Cycle-by-Cycle Details for WAV and wavr

The WAV instruction is unusual in that the logic flow has two separate entry points. The first entry point is the normal start of a WAV instruction. The second entry point resumes the weighted average operation after a WAV instruction has been interrupted. This recovery operation is called the wavr pseudoinstruction.

Figure B-11 is a flow diagram of the WAV instruction including the wavr pseudoinstruction. Each box in this figure represents one CPU clock cycle. Decision blocks and connecting arrows are considered to take no time at all. The letters in the small rectangles in the upper left corner of the boxes are execution cycle codes (refer to Appendix A Instruction Set and Commands for details).

In terms of cycle-by-cycle bus activity, the $\$ 18$ page select prebyte is treated as a one-byte instruction. In cycle 1.0 of the WAV instruction, one word of program information is fetched into the instruction queue if the $\$ 18$ is located at an odd address. If the $\$ 18$ is at an even address, the instruction queue cannot advance so there is no bus access in this cycle.

Cycle 2.0 clears three internal 16-bit temporary registers in preparation for summation operations. The WAV instruction maintains a 32-bit sum-of-products in TMP3:TMP2 and a 16-bit sum-of-weights in TMP1. Keeping these sums inside the CPU reduces bus accesses and optimizes the WAV operation for high speed.

Cycles 3.0 through 9.0 form the seven-cycle main loop for WAV. The value in the 8 -bit B accumulator counts the number of loop iterations. B is decremented at the top of the loop in cycle 3.0, and the test for zero is located at the bottom of the loop after cycle 9.0. Cycles 4.0 and 5.0 fetch the 8 -bit operands for one iteration of the loop. The X and Y index registers are used to access these operands. The index registers are incremented as the operands are fetched. Cycle 6.0 accumulates the current fuzzy output into TMP3. Cycles 7.0 and 8.0 perform the eight-by-eight multiply of $\mathrm{F}_{\mathrm{i}}$ times $\mathrm{S}_{\mathrm{i}}$. TMP1:TMP2 accumulates the product during cycles 8.0 and 9.0. Even though the sum-of-products does not exceed 24 bits, the sum is maintained in the 32-bit combined TMP1:TMP2 register because it is easier to use existing 16-bit operations than to create a new smaller operation to handle the high bits of this sum.

Since the weighted average operation could be quite long, it is made to be interruptible. The usual longest latency path is from very early in cycle 6.0 through cycle 9.0 to the top of the loop in cycle 3.0 , and through cycle 5.0 to the interrupt check. The three-cycle ( 6.1 through 8.1 ) exit sequence gives this latency path a total of 10 cycles.

If the WAV instruction is interrupted, the internal temporary registers TMP3, TMP2, and TMP1 need to be stored on the stack so that the operation can be resumed. Since the WAV instruction includes initialization in cycle 2.0 , the recovery path after an interrupt needs to be different. The wavr pseudoinstruction has the same opcode as WAV, but it is on the first page of the opcode map so it doesn't have the $\$ 18$ page 2 prebyte that WAV has. When WAV is interrupted, the PC is adjusted to point at the second byte of the WAV object code, so that it is interpreted as the wavr pseudoinstruction on return from the interrupt, rather than the WAV instruction. During the recovery sequence, the PC is readjusted in case another interrupt comes before the weighted average operation finishes.


Figure B-11 WAV and wavr Instruction Flow Diagram
The resume sequence includes recovery of the temporary registers from the stack (1.1 through 5.0), and reads to get the operands for the current iteration. The normal WAV flow is then rejoined at cycle 6.0.

Upon normal completion of the instruction (cycle 10.0), the PC is adjusted so it points to the next instruction. The results transfer from the TMP registers into CPU registers in such a way that the EDIV
instruction can divide the sum-of-products by the sum-of-weights. TMP1:TMP2 transfers into Y:D and TMP3 transfers into X.

## B. 8 Custom Fuzzy Logic Programming

The basic fuzzy logic inference techniques described above are suitable for a broad range of applications, but some systems may require customization. The built-in fuzzy instructions use 8 -bit resolution and some systems may require finer resolution. The rule evaluation instructions support only variations of MIN-MAX rule evaluation. Other methods have been discussed in fuzzy logic literature. The weighted average of singletons is not the only defuzzification technique. The HCS12 CPU has several instructions and addressing modes that can be helpful in developing custom fuzzy logic systems.

## B.8.1 Fuzzification Variations

The MEM instruction supports trapezoidal and several other membership functions, including functions with vertical (infinite slope) sides. Triangular membership functions are a subset of trapezoidal functions. Some practitioners refer to s-, z-, and $\pi$-shaped membership functions. These refer to trapezoids butted against the right, left, or neither end of the x -axis. Many other membership function shapes are possible with sufficient memory space and processing bandwidth.

Tabular membership functions offer total flexibility in shape and very fast evaluation time. However, tables take as many as 256 bytes of memory space per system input label. This makes them impractical for most microcontroller-based fuzzy systems. The HCS12 instruction set includes two instructions, TBL and ETBL, for lookup and interpolation of compressed tables.

The TBL instruction uses 8-bit table entries (y-values) and returns an 8-bit result. The ETBL instruction uses 16-bit table entries ( $y$-values) and returns a 16-bit result. Indexed addressing identifies the effective address of the data point at the beginning of the line segment. The data value for the end point of the line segment is the next consecutive memory location. The data values are bytes for TBL and words for ETBL. In both cases, the B accumulator contains the ratio

$$
\frac{x \text {-distance from beginning of line segment to lookup point }}{\text { x-distance from beginning to end of line segment }}
$$

The value in B is treated as an 8-bit binary fraction with radix point left of the MSB, so each line segment can effectively be divided into 256 pieces. During execution of the TBL or ETBL instruction, the difference between the end point $y$-value and the beginning point $y$-value (a signed byte-TBL or word-ETBL) is multiplied by the B accumulator to get an intermediate delta-y term. The result is the $y$-value of the beginning point, plus this signed intermediate delta- $y$ value.

Because indexed addressing identifies the starting point of the line segment of interest, there is a great deal of flexibility in constructing tables. A common method is to break the $x$-axis range into 256 equal width segments and store the $y$ value for each of the resulting 257 endpoints. The 16 -bit D accumulator is then the x input to the table. The upper eight bits in A are used as a coarse lookup to find the line segment of interest, and the lower eight bits in B are used to interpolate within this line segment.

In the program sequence:

| LDX | \#TBL_START |
| :--- | :--- |
| LDD | DATA_IN |
| TBL | A, X |

The notation $A, X$ causes the TBL instruction to use the $A^{\text {th }}$ line segment in the table. The low half of $D$ (B) is used by TBL to calculate the exact data value from this line segment. This type of table uses only 257 entries to approximate a table with 16 bits of resolution. This type of table has the disadvantage of equal width line segments, which means that just as many points are needed to describe a flat portion of the desired function as are needed for the most active portions.

Another type of table stores $x: y$ coordinate pairs for the endpoints of each linear segment. This type of table may reduce the table storage space compared to the previous fixed-width segments because flat areas of the functions can be specified with a single pair of endpoints. This type of table is a little harder to use with the TBL and ETBL instructions because the table instructions expect $y$-values for segment endpoints to be in consecutive memory locations.

Consider a table made up of an arbitrary number of $x: y$ coordinate pairs, in which all values have eight bits. The table is entered with the x -coordinate of the desired point to lookup in the A accumulator. When the table is exited, the corresponding y-value is in the A accumulator. Figure $\mathbf{B}-12$ shows one way to work with this type of table.

| BEGIN | LDY | \#TABLE_START-2 | ; setup initial table pointer |
| :---: | :---: | :---: | :---: |
| FIND_LOOP | CMPA | $2,+Y$ | ; find first Xn > XL |
|  |  |  | ; (auto pre-inc Y by 2) |
|  | BLS | FIND_LOOP | ; loop if XL .le. Xn |
| * on fall | 2, Y | Y XE@0,Y and YE |  |
|  | TFR | D, X | ; save XL in high half of X |
|  | CLRA |  | ; zero upper half of $D$ |
|  | LDAB | 0, Y | ; $\mathrm{D}=0: \mathrm{XE}$ |
|  | SUBB | -2, Y | ; $\mathrm{D}=0:(X E-X B)$ |
|  | EXG | D, X | ; $\mathrm{X}=(\mathrm{XE}-\mathrm{XB}) \ldots \mathrm{D}=\mathrm{XL}$ : junk |
|  | SUBA | -2, Y | ; $\mathrm{A}=(\mathrm{XL}-\mathrm{XB})$ |
|  | EXG | A, D | ; $\mathrm{D}=0:(\mathrm{XL}-\mathrm{XB})$, uses trick of EXG |
|  | FDIV |  | ; X reg $=(\mathrm{XL}-\mathrm{XB}) /(\mathrm{XE}-\mathrm{XB})$ |
|  | EXG | D, X | ; move fractional result to $A: B$ |
|  | EXG | A, B | ; byte swap - need result in B |
|  | TSTA |  | ; check for rounding |
|  | BPL | NO_ROUND |  |
|  | INCB |  | ; round B up by 1 |
| NO_ROUND | LDAA | $1, Y$ | ; YE |
|  | PSHA |  | ; put on stack for TBL later |
|  | LDAA | $-1, Y$ | ; YB |
|  | PSHA |  | ; now YB@0,SP and YE@1,SP |
|  | TBL | 2, SP+ | ;interpolate and deallocate |
|  |  |  | ;stack temps |

## Figure B-12 Endpoint Table Handling

The basic idea is to find the segment of interest, temporarily build a one-segment table of the correct format on the stack, then use TBL with stack-relative indexed addressing to interpolate. The most difficult part of the routine is calculating the proportional distance from the beginning of the segment to the lookup point versus the width of the segment $((\mathrm{XL}-\mathrm{XB}) /(\mathrm{XE}-\mathrm{XB}))$. With this type of table, this calculation must
be done at run time. In the previous type of table, this proportional term is an inherent part (the lowest order bits) of the data input to the table.

Some fuzzy theorists have suggested that membership functions should be shaped like normal distribution curves or other mathematical functions. This may be correct, but the processing requirements to solve for an intercept on such a function would be unacceptable for most microcontroller-based fuzzy systems. Such a function could be encoded into a table of one of the previously described types.

For many common systems, the thing that is most important about membership function shape is that there is a gradual transition from nonmembership to membership as the system input value approaches the central range of the membership function. Let us examine the human problem of stopping a car at an intersection. We might use rules like "If intersection is close and speed is fast, apply brakes." The meaning of the labels "close" and "fast", reflected in membership function shape and position, is different for a teenager than it is for a grandmother, but both can accomplish the goal of stopping. It makes intuitive sense that the exact shape of a membership function is much less important than the fact that it has gradual boundaries.

## B.8.2 Rule Evaluation Variations

The REV and REVW instructions expect fuzzy input and fuzzy output values to be 8-bit values. In a custom fuzzy inference program, higher resolution may be desirable, although this is not a common requirement. The HCS12 CPU includes variations of minimum and maximum operations that work with the fuzzy MIN-MAX inference algorithm. The problem with the fuzzy inference algorithm is that the min and max operations need to store their results differently, so the min and max instructions must work differently or more than one variation of these instructions is needed.

The HCS12 CPU has min and max instructions for 8- or 16-bit operands, with one operand in an accumulator and the other in a referenced memory location. There are separate variations that replace the accumulator or the memory location with the result. While processing rule antecedents in a fuzzy inference program, a reference value must be compared to each of the referenced fuzzy inputs, and the smallest input must end up in an accumulator. The instruction:

```
EMIND 2,X+ ;process one rule antecedent
```

automates the central operations needed to process rule antecedents. The E stands for extended, so this instruction compares 16 -bit operands. The D at the end of the mnemonic stands for the D accumulator, which is both the first operand for the comparison and the destination of the result. The $2, \mathrm{X}+$ is an indexed addressing specification that says X points to the second operand for the comparison.

When processing rule consequents, the operand in the accumulator must remain constant in case there is more than one consequent in the rule, and the result of the comparison must replace the referenced fuzzy output in RAM. To do this, use the instruction:

```
EMAXM 2,X+ ;process one rule consequent
```

The M at the end of the mnemonic indicates that the result replaces the referenced memory operand. Again, indexed addressing is used. These two instructions can form the working part of a 16-bit resolution fuzzy inference routine. User Guide - S12CPU15U゙GE.ZCale Semiconductor, Inc.

There are many other methods of performing inference, but the min-max method is most widely used. Since the HCS12 is a general-purpose microcontroller, the programmer has complete freedom to program any algorithm desired. A custom algorithm would typically take more code space and execution time than a routine that used the built-in REV or REVW instructions.

## B.8.3 Defuzzification Variations

There are two main areas where other HCS12 instructions can help with custom defuzzification routines. The first case is working with operands with more than eight bits. The second case involves using an entirely different approach than weighted average of singletons.

The primary part of the WAV instruction is a multiply and accumulate operation to get the numerator for the weighted average calculation. When working with operands as large as 16 bits, the EMACS instruction could at least automate the multiply and accumulate function. The HCS12 CPU has extended math capabilities, including 32-bit by 16-bit divide instructions and the EMACS instruction which uses 16-bit input operands and accumulates the sum to a 32-bit memory location.

One benefit of the WAV instruction is that both a sum of products and a sum of weights are maintained, while the fuzzy output operand is only accessed from memory once. Since memory access time is such a significant part of execution time, this provides a speed advantage over conventional instructions.

The weighted average of singletons is the most commonly used technique in microcontrollers because it is computationally less difficult than most other methods. The simplest method is called max defuzzification, which simply uses the largest fuzzy output as the system result. However, this approach does not take into account any other fuzzy outputs, even when they are almost as true as the chosen max output. Max defuzzification is not a good general choice because it only works for a subset of fuzzy logic applications.

The HCS12 CPU is well suited for more computationally challenging algorithms than weighted average. A 32-bit by 16-bit divide instruction takes eleven or twelve 8-MHz cycles for unsigned or signed variations. A 16 -bit by 16 -bit multiply with a 32 -bit result takes only three $8-\mathrm{MHz}$ cycles. The EMACS instruction uses 16 -bit operands and accumulates the result in a 32 -bit memory location, taking only twelve $8-\mathrm{MHz}$ cycles per iteration, including accessing all operands from memory and storing the result to memory.

## Appendix C M68HC11 to HCS12 Upgrade

## C. 1 General

This appendix discusses aspects of upgrading system software from one based upon the Motorola 68 HC 11 to one using the HCS12 CPU. In general, the HCS12 is a proper superset of the M68HC11 instruction set (as was the HC12 CPU prior to the HCS12).

## C. 2 Source Code Compatibility

Every M68HC11 instruction mnemonic and source code statement can be assembled directly with a HCS12 assembler with no modifications.

The HCS12 supports all M68HC11 addressing modes and includes several new variations of indexed addressing. HCS12 instructions affect condition code bits in the same way as M68HC11 instructions.

HCS12 object code is similar to but not identical to M68HC11 object code. Some primary objectives, such as the elimination of the penalty for using Y, could not be achieved without object code differences. While the object code has been changed, the majority of the opcodes are identical to those of the M6800, which was developed more than 20 years earlier.

The HCS12 assembler automatically translates a few M 68 HC 11 instruction mnemonics into functionally equivalent HCS12 instructions. For example, the HCS12 does not have an increment stack pointer (INS) instruction, so the INS mnemonic is translated to LEAS 1,S. The HCS12 does provide single-byte DEX, DEY, INX, and INY instructions because the LEAX and LEAY instructions do not affect the condition codes, while the M68HC11 instructions update the Z bit according to the result of the decrement or increment.

Table C-1 shows M68HC11 instruction mnemonics that are automatically translated into equivalent HCS12 instructions. This translation is performed by the assembler so there is no need to modify an old M68HC11 program in order to assemble it for the HCS12. In fact, the M68HC11 mnemonics can be used in new HCS12 programs.

## Table C-1 Translated M68HC11 Mnemonics

| M68HC11 <br> Mnemonic | Equivalent |
| :--- | :--- | :--- |
| HCS12 Instruction |  |$\quad$| Comments |
| :--- |
| ABX <br> ABY |
| LEAX B,X <br> LEAY B,Y |
| Since HCS12 has accumulator offset indexing, ABX and ABY are <br> rarely used in new HCS12 programs. ABX was one byte on <br> M68HC11 but ABY was two bytes. The LEA substitutes are two <br> bytes. |
| CLC |
| CLI | | ANDCC \#\$FE |
| :--- |
| ANDCC \#\$EF |
| ANDCC \#\$FD |
| SEC |

Table C-1 Translated M68HC11 Mnemonics

| M68HC11 <br> Mnemonic | Equivalent HCS12 Instruction | Comments |
| :---: | :---: | :---: |
| $\begin{aligned} & \text { DES } \\ & \text { INS } \end{aligned}$ | $\begin{array}{\|l} \text { LEAS -1,S } \\ \text { LEAS 1,S } \end{array}$ | Unlike DEX and INX, DES and INS did not affect CCR bits in the M68HC11, so the LEAS equivalents in HCS12 duplicate the function of DES and INS. These instructions were one byte on M68HC11 and two bytes on HCS12. |
| TAP <br> TPA <br> TSX <br> TSY <br> TXS <br> TYS <br> XGDX <br> XGDY | TFR A,CCR <br> TFR CCR,A <br> TFR S, X <br> TFR S, Y <br> TFR X,S <br> TFR Y,S <br> EXG D,X <br> EXG D,Y | The M68HC11 had a small collection of specific transfer and exchange instructions. HCS12 expanded this to allow transfer or exchange between any two CPU registers. For all but TSY and TYS (which take two bytes on either CPU), the HCS12 transfer/exchange costs one extra byte compared to the M68HC11. The substitute instructions execute in one cycle rather than two. |

All of the translations produce the same amount of or slightly more object code than the original M68HC11 instructions. However, there are offsetting savings in other instructions. Y-indexed instructions in particular assemble into one byte less object code than the same M68HC11 instruction.

The HCS12 has a two-page opcode map, rather than the four-page M68HC11 map. This is largely due to redesign of the indexed addressing modes. Most of pages 2, 3, and 4 of the M68HC11 opcode map are required because Y -indexed instructions use different opcodes than X-indexed instructions.
Approximately two-thirds of the M 68 HC 11 page 1 opcodes are unchanged in HCS12, and some M68HC11 opcodes have been moved to page 1 of the HCS12 opcode map. Object code for each of the moved instructions is one byte smaller than object code for the equivalent M68HC11 instruction. Table C-2 shows instructions that assemble to one byte less object code on the HCS12.

Instruction set changes offset each other to a certain extent. Programming style also affects the rate at which instructions appear. As a test, the BUFFALO monitor, an 8 K byte M68HC11 assembly code program, was reassembled for the HCS12. The resulting object code is six bytes smaller than the M68HC11 code. It is fair to conclude that M 68 HC 11 code can be reassembled with very little change in size.

Table C-2 Instructions with Smaller Object Code

| Instruction | Comments |
| :--- | :--- |
| DEY <br> INY | Page 2 opcodes in M68HC11 but page 1 in HCS12. |
| INST n,Y | For values of $n$ less than 16 (the majority of cases). Were on page 2, now are on page 1. <br> Applies to BSET, BCLR, BRSET, BRCLR, NEG, COM, LSR, ROR, ASR, ASL, ROL, DEC, <br> INC, TST, JMP, CLR, SUB, CMP, SBC, SUBD, ADDD, AND, BIT, LDA, STA, EOR, ADC, <br> ORA, ADD, JSR, LDS, and STS. If X is the index reference and the offset is greater than 15 <br> (much less frequent than offsets of 0, 1, and 2), the HCS12 instruction assembles to one <br> byte more of object code than the equivalent M68HC11 instruction. |
| PSHY <br> PULY | Were on page 2, now are on page 1. |
| LDY <br> STY <br> CPY | Were on page 2, now are on page 1. |

Table C-2 Instructions with Smaller Object Code

| Instruction | Comments |
| :--- | :--- |
| CPY $n, Y$ <br> LDY $n, Y$ <br> STY $n, Y$ | For values of $n$ less than 16 (the majority of cases). Were on page 3, now are on page 1. |
| CPD | Was on page 2, 3, or 4, now on page 1. In the case of indexed with offset greater than 15, <br> HCS12 and M68HC11 object code are the same size. |

The relative size of code for M 68 HC 11 vs. code for HCS12 has also been tested by rewriting several smaller programs from scratch. In these cases, the HCS12 code is typically about $30 \%$ smaller. These savings are mostly due to improved indexed addressing. A C program compiled for the HCS12 is about $30 \%$ smaller than the same program compiled for the $\mathbf{M} 68 \mathrm{HC11}$. The savings are largely due to better indexing.

## C. 3 Programmer's Model and Stacking

The HCS12 programming model and stacking order are identical to those of the M68HC11.

## C. 4 True 16-Bit Architecture

The M68HC11 is a direct descendant of the M6800, one of the first microprocessors, which was introduced in 1974. The M6800 was strictly an 8 -bit machine, with 8 -bit data buses and 8 -bit instructions. As Motorola devices evolved from the M6800 to the M68HC11, a number of 16-bit instructions were added, but the data buses remained eight bits wide, so these instructions were performed as sequences of 8 -bit operations. The HCS12 is a true 16 -bit implementation, but it retains the ability to work with the mostly 8-bit M68HC11 instruction set. The larger ALU of the HCS12 is used to calculate 16-bit pointers and to speed up math operations.

## C.4.1 Bus Structures

The HCS12 is a 16-bit processor with 16-bit data paths. Typical HCS12 devices have internal and external 16-bit data paths, but some derivatives incorporate operating modes that allow for an 8-bit data bus, so that a system can be built with low-cost 8 -bit program memory. HCS12 based systems include an on-chip block in the Core that manages the external bus interface. When the CPU makes a 16 -bit access to a resource that is served by an 8-bit bus, the Core performs two 8-bit accesses, freezes the CPU clocks for part of the sequence, and assembles the data into a 16 -bit word. As far as the CPU is concerned, there is no difference between this access and a 16-bit access to an internal resource via the 16-bit data bus. This is similar to the way an M 68 HC 11 can stretch clock cycles to accommodate slow peripherals.

## C.4.2 Instruction Queue

The CPU has a three-word instruction queue for storing program information. All program information is fetched from memory as aligned 16-bit words, even though there is no requirement for instructions to begin or end on even word boundaries. There is no penalty for misaligned instructions. If a program begins on an odd boundary (if the reset vector is an odd address), program information is fetched to fill the User Guide - S12CPU15UGEPT.Scale Semiconductor, Inc.
instruction queue, beginning with an aligned word read at the natural boundary of the misaligned reset vector. The instruction queue logic starts execution with the opcode in the low half of this word.

The instruction queue makes three bytes of program information (starting with the instruction opcode) directly available to the CPU at the beginning of every instruction. As each instruction executes, it performs enough additional program fetches to refill the space it took up in the queue. Alignment information is maintained by logic in the instruction queue. The CPU provides signals that tell the queue logic when to advance a word of program information, and when to toggle the alignment status.

The CPU is not aware of instruction alignment. The queue logic sorts out the information in the queue to present the opcode and additional bytes of information as CPU inputs. A control algorithm determines whether the opcode is in the even or odd half of the word at the head of the queue. The execution sequence for all instructions is independent of the alignment of the instruction.

The only situation in which alignment can affect the number of cycles an instruction takes occurs in devices that have a narrow (8-bit) external data bus, and is related to optional program fetch cycles. Optional cycles are always performed, but serve different purposes determined by instruction size and alignment.

Each instruction includes one program fetch cycle for every two bytes of object code. Instructions with an odd number of bytes can use an optional cycle to fetch an extra word of object code. If the queue is aligned at the start of an instruction with an odd byte count, the last byte of object code shares a queue word with the opcode of the next instruction. Since this word holds part of the next instruction, the queue cannot advance after the odd byte executes, or the first byte of the next instruction would be lost. In this case, the optional cycle appears as a free cycle since the queue is not ready to accept the next word of program information. If this same instruction had been misaligned, the queue would be ready to advance and the optional cycle would be used to perform a program word fetch.

In a single-chip system or in a system with the program in 16-bit memory, both the free cycle and the program fetch cycle take one bus cycle. In a system with the program in an external 8-bit memory, the optional cycle takes one bus cycle when it appears as a free cycle, but it takes two bus cycles when used to perform a program fetch. In this case, the on-chip integration module freezes the CPU clocks long enough to perform the cycle as two smaller accesses. The CPU handles only 16-bit data, and is not aware that the 16 -bit program access is split into two 8 -bit accesses.

In order to allow development systems to track events in the HCS12 instruction queue, two status signals (IPIPE[1:0]) provide information about data movement in the queue and about the start of instruction execution. A development system can use this information along with address and data information to externally reconstruct the queue. This representation of the queue can also track both the data and address buses.

## C.4.3 Stack Function

Both the M68HC11 and the HCS12 stack nine bytes for interrupts. Since this is an odd number of bytes, there is no practical way to assure that the stack will stay aligned. To assure that instructions take a fixed number of cycles regardless of stack alignment, the internal RAM in HCS12 systems is designed to allow single-cycle 16-bit accesses to misaligned addresses. As long as the stack is located in this special RAM, stacking and unstacking operations take the same amount of execution time, regardless of stack alignment.

If the stack is located in an external 16-bit RAM, a PSHX instruction can take two or three cycles depending on the alignment of the stack. This extra access time is transparent to the CPU because the integration module freezes the CPU clocks while it performs the extra 8-bit bus cycle required for a misaligned stack operation.

The HCS12 has a last-used stack rather than a next-available stack like the M68HC11 CPU. That is, the stack pointer points to the last 16-bit stack address used, rather than to the address of the next available stack location. This generally has very little effect, because it is very unusual to access stacked information using absolute addressing. The change allows a 16-bit word of data to be removed from the stack without changing the value of the SP twice.

To illustrate, consider the operation of a PULX instruction. With the next-available M68HC11 stack, if the $\mathrm{SP}=\$ 01 \mathrm{~F} 0$ when execution begins, the sequence of operations is: $\mathrm{SP}=\mathrm{SP}+1$; load X from $\$ 01 \mathrm{~F} 1: 01 \mathrm{~F} 2$; $\mathrm{SP}=\mathrm{SP}+1$; and the SP ends up at $\$ 01 \mathrm{~F} 2$. With the last-used HCS12 stack, if the $\mathrm{SP}=\$ 01 \mathrm{~F} 0$ when execution begins, the sequence is: load X from $\$ 01 \mathrm{~F} 0: 01 \mathrm{~F} 1 ; \mathrm{SP}=\mathrm{SP}+2$; and the SP again ends up at $\$ 01 \mathrm{~F} 2$. The second sequence requires one less stack pointer adjustment.

The stack pointer change also affects operation of the TSX and TXS instructions. In the M68HC11, TSX increments the SP by one during the transfer. This adjustment causes the X index to point to the last stack location used. The TXS instruction operates similarly, except that it decrements the SP by one during the transfer. HCS12 TSX and TXS instructions are ordinary transfers - the HCS12 stack requires no adjustment.

For ordinary use of the stack, such as pushes, pulls, and even manipulations involving TSX and TXS, there are no differences in the way the M68HC11 and the HCS12 stacks look to a programmer. However, the stack change can affect a program algorithm in two subtle ways.

The LDS \#\$xxxx instruction is normally used to initialize the stack pointer at the start of a program. In the M68HC11, the address specified in the LDS instruction is the first stack location used. In the HCS12, however, the first stack location used is one address lower than the address specified in the LDS instruction. Since the stack builds downward, M68HC11 programs reassembled for the HCS12 operate normally, but the program stack is one physical address lower in memory.

In very uncommon situations, such as test programs used to verify CPU operation, a program could initialize the SP, stack data, and then read the stack via an extended mode read (it is normally improper to read stack data from an absolute extended address). To make an M68HC11 source program that contains such a sequence work on the HCS12, change either the initial LDS \#\$xxxx, or the absolute extended address used to read the stack.

## C. 5 Improved Indexing

The HCS12 has significantly improved indexed addressing capability, yet retains compatibility with the M68HC11. The one-cycle and one-byte cost of doing Y-related indexing in the M68HC11 has been eliminated. In addition, high level language requirements, including stack-relative indexing and the ability to perform pointer arithmetic directly in the index registers, have been accommodated.

The M68HC11 has one variation of indexed addressing that works from X or Y as the reference pointer. For X indexed addressing, an 8-bit unsigned offset in the instruction is added to the index pointer to arrive
at the address of the operand for the instruction. A load accumulator instruction assembles into two bytes of object code, the opcode and a one-byte offset. Using Y as the reference, the same instruction assembles into three bytes (a page prebyte, the opcode, and a one-byte offset.) Analysis of M68HC11 source code indicates that the offset is most frequently zero and very seldom greater than four.

The HCS12 indexed addressing scheme uses a postbyte plus 0,1 , or 2 extension bytes after the instruction opcode. These bytes specify which index register is used, determine whether an accumulator is used as the offset, implement automatic pre/post increment/decrement of indices, and allow a choice of 5-, 9-, or 16-bit signed offsets. This approach eliminates the differences between X and Y register use and dramatically enhances indexed addressing capabilities.

Major improvements that result from this new approach are:

- Stack pointer can be used as an index register in all indexed operations
- Program counter can be used as index register in all but autoinc/dec modes
- Accumulator offsets allowed using A, B, or D accumulators
- Automatic pre- or post-, increment or decrement (by -8 to +8 )
- 5-bit, 9-bit, or 16-bit signed constant offsets
- 16-bit offset indexed-indirect and accumulator D offset indexed-indirect

The change completely eliminates pages three and four of the M68HC11 opcode map and eliminates almost all instructions from page two of the opcode map. For offsets of +0 to +15 from the X index register, the object code is the same size as it was for the M68HC11. For offsets of +0 to +15 from the Y index register, the object code is one byte smaller than it was for the M68HC11.

## C.5.1 Constant Offset Indexing

The HCS12 offers three variations of constant offset indexing in order to optimize the efficiency of object code generation.

The most common constant offset is zero. Offsets of $1,2, \ldots 4$ are used fairly often, but with less frequency than zero.

The 5-bit constant offset variation covers the most frequent indexing requirements by including the offset in the postbyte. This reduces a load accumulator indexed instruction to two bytes of object code, and matches the object code size of the smallest M68HC11 indexed instructions, which can only use X as the index register. The HCS12 can use X, Y, SP, or PC as the index reference with no additional object code size cost.

The signed 9-bit constant offset indexing mode covers the same positive range as the M68HC11 8-bit unsigned offset. The size was increased to nine bits with the sign bit (ninth bit) included in the postbyte, and the remaining 8-bits of the offset in a single extension byte.

The 16-bit constant offset indexing mode allows indexed access to the entire normal 64 K byte address space. Since the address consists of 16 bits, the 16 -bit offset can be regarded as a signed ( $-32,768$ to +32767 ) or unsigned ( 0 to 65,535 ) value. In 16-bit constant offset mode, the offset is supplied in two extension bytes after the opcode and postbyte.

## C.5.2 Autoincrement/Autodecrement Indexing

The HCS12 provides greatly enhanced autoincrement and autodecrement modes of indexed addressing. In the HCS12, the index modification may be specified before the index is used (pre), or after the index is used (post), and the index can be incremented or decremented by any amount from one to eight, independent of the size of the operand accessed. X, Y, and SP can be used as the index reference, but this mode does not allow PC to be the index reference. Modifying PC would interfere with proper program execution.

This addressing mode can be used to implement a software stack structure, or to manipulate data structures in lists or tables, rather than manipulating bytes or words of data. Anywhere an M68HC11 program has an increment or decrement index register operation near an indexed mode instruction, the increment or decrement operation can be combined with the indexed instruction with no cost in object code size, as shown in the following code comparison.

| $18 A 600$ <br> 1808 <br> 1808 | LDAA0,Y <br> INY <br> INY | A671 | LDAA2,Y + |
| :--- | :--- | :--- | :--- |

The M68HC11 object code takes seven bytes, while the HCS12 takes only two bytes to accomplish the same functions. Three bytes of M68HC11 code are due to the page prebyte for each Y-related instruction (\$18). HCS12 postincrement indexing capability allows the two INY instructions to be absorbed into the LDAA indexed instruction. The replacement code is not identical to the original three-instruction sequence because the Z bit is affected by the M68HC11 INY instructions, while the Z bit in the HCS12 is determined by the value loaded into $A$.

## C.5.3 Accumulator Offset Indexing

This indexed addressing variation allows the programmer to use either an 8-bit accumulator (A or B), or the 16 -bit D accumulator as the offset for indexed addressing. This allows for a program-generated offset, which is more difficult to achieve in the M 68 HC 11 . The following code compares the M68HC11 and HCS12 operations.

| C6 | 05 |  |  | LDAB | \#\$05 | [2] |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CE | 10 | 00 | LOOP | LDX | \#\$1000 | [3] | C6 | 05 |  |  | LDAB | \#\$05 | [1] |
| 3A |  |  |  | ABX |  | [3] | CE | 10 | 00 |  | LDX | \#\$1000 | [2] |
| A6 | 00 |  |  | LDAA | 0, X | [4] | A6 | E5 |  | LOOP | LDAA | B, X | [3] |
| 5A |  |  |  | DECB |  | [2] | 04 | 31 | FB |  | DBNE | B,LOOP | [3] |
| 26 | F7 |  |  | BNE | LOOP | [3] |  |  |  |  |  |  |  |

The HCS12 object code is only one byte smaller, but the LDX \# instruction is outside the loop. It is not necessary to reload the base address in the index register on each pass through the loop because the LDAA $\mathrm{B}, \mathrm{X}$ instruction does not alter the index register. This reduces the loop execution time from 15 cycles to six cycles.

User Guide - S12CPu15式eqpescale Semiconductor, Inc.

## C.5.4 Indirect Indexing

The HCS12 allows some forms of indexed indirect addressing in which the instruction points to a location in memory where the address of the operand is stored. This is an extra level of indirection compared to ordinary indexed addressing. The two forms of indexed-indirect addressing are 16-bit constant offset indexed-indirect and accumulator D indexed-indirect. The indexing register can be $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC as in other HCS12 indexed addressing modes. PC-relative indirect addressing is one of the more common uses of indexed indirect addressing. The indirect variations of indexed addressing help to implement pointers. Accumulator D indexed-indirect addressing can implement a runtime-computed GOTO function. Indirect addressing is also useful in high level language compilers. For instance, PC-relative indirect indexing can efficiently implement some C case statements.

## C. 6 Improved Performance

HCS12 based systems provide a number of performance improvements over the M68HC11. These improvements include cycle count reduction, faster math instruction execution and reduction of code size. Each of these aspects is discussed in the subsections below.

## C.6.1 Reduced Cycle Counts

No M68HC11 instruction takes less than two cycles, but the HCS12 has more than 50 opcodes that take only one cycle. Some of the reduction comes from the instruction queue, which assures that several program bytes are available at the start of each instruction. Other cycle reductions occur because the HCS12 can fetch 16 bits of information at a time, rather than eight bits at a time.

## C.6.2 Fast Math

The HCS12 has some of the fastest math ever designed into a Motorola general-purpose Core. Much of the speed is due to an execution unit that can perform several operations simultaneously. Table C-3 compares the speed of HCS12 and M68HC11 math instructions. The HCS12 requires fewer cycles to perform an operation, and the cycle time is half that of the M68HC11.

Table C-3 Comparison of Math Instruction Speeds

| Instruction Mnemonic | Math Operation | M68HC11 <br> 1 Cycle = 250 ns | M68HC11 <br> w/Coprocessor <br> 1 Cycle = 250 ns | $\begin{gathered} \text { HCS12 } \\ 1 \text { Cycle }=125 \mathrm{~ns} \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| MUL | $\begin{gathered} 8 \times 8=16 \\ \text { (signed) } \end{gathered}$ | 10 cycles | - | 1 cycle |
| EMUL | $\begin{gathered} 16 \times 16=32 \\ \text { (unsigned) } \end{gathered}$ | - | 20 cycles | 3 cycles |
| EMULS | $\begin{gathered} 16 \times 16=32 \\ (\text { signed }) \end{gathered}$ | - | 20 cycles | 3 cycles |
| IDIV | $16 \div 16=16$ <br> (unsigned) | 41 cycles | - | 12 cycles |
| FDIV | $\begin{gathered} 16 \div 16=16 \\ \text { (fractional) } \end{gathered}$ | 41 cycles | - | 12 cycles |
| EDIV | $\begin{gathered} 32 \div 16=16 \\ \text { (unsigned) } \end{gathered}$ | - | 33 cycles | 11 cycles |
| EDIVS | $\begin{gathered} 32 \div 16=16 \\ \text { (signed) } \end{gathered}$ | - | 37 cycles | 12 cycles |
| IDIVS | $\begin{gathered} 16 \div 16=16 \\ \text { (signed) } \end{gathered}$ | - | - | 12 cycles |
| EMACS | $\begin{gathered} 32 \times(16 \times 16) \Rightarrow 32 \\ (\text { signed MAC) } \end{gathered}$ | - | 20 cycles | 13 cycles |

The IDIVS instruction is included specifically for C compilers, where word-sized operands are divided to produce a word-sized result (unlike the $32 \div 16=16$ EDIV). The EMUL and EMULS instructions place the result in registers so a C compiler can choose to use only 16 bits of the 32-bit result.

## C.6.3 Code Size Reduction

HCS12 assembly language programs written from scratch tend to be $30 \%$ smaller than equivalent programs written for the M 68 HC 11 . This figure has been independently qualified by Motorola programmers and an independent C compiler vendor. The major contributors to the reduction appear to be improved indexed addressing and the universal transfer/exchange instruction.

In some specialized areas, the reduction is much greater. A fuzzy logic inference kernel requires about 250 bytes in the M 68 HC 11 , and the same program for the HCS12 requires about 50 bytes. The HCS12 fuzzy logic instructions replace whole subroutines in the M68HC11 version. Table lookup instructions also greatly reduce code space.

Other HCS12 code space reductions are more subtle. Memory to memory moves are one example. The HCS12 move instruction requires almost as many bytes as an equivalent sequence of M68HC11 instructions, but the move operations themselves do not require the use of an accumulator. This means that the accumulator often need not be saved and restored, which saves instructions.

Arithmetic on index pointers is another example. The M68HC11 usually requires that the content of the index register be moved into accumulator D , where calculations are performed, then back to the index register before indexing can take place. In the HCS12, the LEAS, LEAX, and LEAY instructions perform
arithmetic operations directly on the index pointers. The pre-/post-increment/decrement variations of indexed addressing also allow index modification to be incorporated into an existing indexed instruction rather than performing the index modification as a separate operation.

Transfer and exchange operations often allow register contents to be temporarily saved in another register rather than having to save the contents in memory. Some HCS12 instructions such as MIN and MAX combine the actions of several M 68 HC 11 instructions into a single operation.

## C. 7 Additional Functions

The HCS12 offers many new functions over that of the M68HC11. These new features are discussed in the subsections below,

## C.7.1 New Instructions

The HCS12 incorporates a number of new instructions that provide added functionality and code efficiency. Among other capabilities, these new instructions allow efficient processing for fuzzy logic applications and support subroutine processing in extended memory beyond the standard 64 K byte address map for HCS12 systems incorporating this feature. Table C-4 is a summary of these new instructions. Subsequent paragraphs discuss significant enhancements.

## Table C-4 New HCS12 Instructions

| Mnemonic | Addressing Modes | Brief Functional Description |
| :---: | :---: | :---: |
| ANDCC | Immediate | AND CCR with mask; replaces CLC, CLI, and CLV |
| BCLR | Extended | Bit(s) clear; added extended mode |
| BGND | Inherent | Enter background debug mode, if enabled |
| BRCLR | Extended | Branch if bit(s) clear; added extended mode |
| BRSET | Extended | Branch if bit(s) set; added extended mode |
| BSET | Extended | Bit(s) set; added extended mode |
| CALL | Extended, indexed | Similar to JSR except also stacks PPAGE value With RTC instruction, allows easy access to >64K byte space |
| CPS | Immediate, direct, extended, and indexed | Compare stack pointer |
| DBNE | Relative | Decrement and branch if equal to zero; looping primitive |
| DBEQ | Relative | Decrement and branch if not equal to zero; looping primitive |
| EDIV | Inherent | Extended divide $Y: D / X=Y(Q)$ and $D(R)$; unsigned |
| EDIVS | Inherent | Extended divide $Y: D / X=Y(Q)$ and $D(R)$; signed |
| EMACS | Special | Multiply and accumulate $16 \times 16 \Rightarrow 32$; signed |
| EMAXD | Indexed | Maximum of two unsigned 16-bit values |
| EMAXM | Indexed | Maximum of two unsigned 16-bit values |
| EMIND | Indexed | Minimum of two unsigned 16-bit values |
| EMINM | Indexed | Minimum of two unsigned 16-bit values |
| EMUL | Special | Extended multiply $16 \times 16 \Rightarrow 32$; M(idx) $* \mathrm{D} \Rightarrow \mathrm{Y}: \mathrm{D}$ |
| EMULS | Special | Extended multiply $16 \times 16 \Rightarrow 32$ (signed); M(idx) $* \mathrm{D} \Rightarrow \mathrm{Y}: \mathrm{D}$ |
| ETBL | Special | Extended table lookup and interpolate; 16-bit entries |
| EXG | Inherent | Exchange register contents |
| IBEQ | Relative | Increment and branch if equal to zero; looping primitive |

Table C-4 New HCS12 Instructions

| Mnemonic | Addressing Modes | Brief Functional Description |
| :---: | :---: | :---: |
| IBNE | Relative | Increment and branch if not equal to zero; looping primitive |
| IDIVS | Inherent | Signed integer divide $D / X \Rightarrow X(Q)$ and $D(R)$; signed |
| LBCC | Relative | Long branch if carry clear; same as LBHS |
| LBCS | Relative | Long branch if carry set; same as LBLO |
| LBEQ | Relative | Long branch if equal (if $\mathrm{Z}=1$ ) |
| LBGE | Relative | Long branch if greater than or equal to zero |
| LBGT | Relative | Long branch if greater than zero |
| LBHI | Relative | Long branch if higher |
| LBHS | Relative | Long branch if higher or same; same as LBCC |
| LBLE | Relative | Long branch if less than or equal to zero |
| LBLO | Relative | Long branch if lower; same as LBCS |
| LBLS | Relative | Long branch if lower or same |
| LBLT | Relative | Long branch if less than zero |
| LBMI | Relative | Long branch if minus |
| LBNE | Relative | Long branch if not equal to zero |
| LBPL | Relative | Long branch if plus |
| LBRA | Relative | Long branch always |
| LBRN | Relative | Long branch never |
| LBVC | Relative | Long branch if overflow clear |
| LBVS | Relative | Long branch if overflow set |
| LEAS | Indexed | Load stack pointer with effective address |
| LEAX | Indexed | Load X index register with effective address |
| LEAY | Indexed | Load Y index register with effective address |
| MAXA | Indexed | Maximum of two unsigned 8-bit values |
| MAXM | Indexed | Maximum of two unsigned 8-bit values |
| MEM | Special | Determine grade of fuzzy membership |
| MINA | Indexed | Minimum of two unsigned 8-bit values |
| MINM | Indexed | Minimum of two unsigned 8-bit values |
| MOVB MOVW | Combinations of immediate, extended and indexed | Move byte from one memory location to another Move word from one memory location to another |
| ORCC | Immediate | OR CCR with mask; replaces SEC, SEI, and SEV |
| PSHC | Inherent | Push CCR onto stack |
| PSHD | Inherent | Push double accumulator onto stack |
| PULC | Inherent | Pull CCR from stack |
| PULD | Inherent | Pull double accumulator from stack |
| REV | Special | Fuzzy logic rule evaluation |
| REVW | Special | Fuzzy logic rule evaluation with weights |
| RTC | Inherent | Restore program page and return address from stack; used with CALL instruction, allows easy access to extended space |
| SEX | Inherent | Sign-extend 8-bit register into 16-bit register |
| TBEQ | Relative | Test and branch if equal to zero; looping primitive |
| TBL | Inherent | Table lookup and interpolate; 8-bit entries |
| TBNE | Relative | Test register and branch if not equal to zero; looping primitive |
| TFR | Inherent | Transfer register contents to another register |
| WAV | Special | Weighted average; fuzzy logic support |

## C.7.2 Memory-to-Memory Moves

The HCS12 has both 8- and 16-bit variations of memory-to-memory move instructions. The source address can be specified with immediate, extended, or indexed addressing modes. The destination address can be specified by extended or indexed addressing mode. Indexed addressing for move instructions is limited to direct indexing modes that require no extension bytes ( 9 - and 16-bit constant offsets are not allowed). This leaves the 5-bit signed constant offset, accumulator offset, and the autoincrement/decrement modes. The following simple loop is a block move routine capable of moving up to 256 words of information from one memory area to another:

```
LOOP MOVW 2,X+ , 2,Y+ ;move a word and update pointers
DBNE B,LOOP ;repeat B times
```

The move immediate to extended is a convenient way to initialize a register without using an accumulator or affecting condition codes.

## C.7.3 Universal Transfer and Exchange

The M 68 HC 11 has only eight transfer instructions and two exchange instructions. The HCS12 has a universal transfer/exchange instruction that can be used to transfer or exchange data between any two CPU registers. The operation is obvious when the two registers are the same size, and some of the other combinations provide very useful results. For example when an 8 -bit register is transferred to a 16-bit register, a sign-extend operation is performed. Other combinations can be used to perform a zero-extend operation.

These instructions are used often in HCS12 assembly language programs. Transfers can be used to make extra copies of data in another register, and exchanges can be used to temporarily save data during a call to a routine that expects data in a specific register. This is sometimes faster and produces more compact object code than saving data to memory with pushes or stores.

## C.7.4 Loop Construct

The HCS12 instruction set includes a new family of six loop primitive instructions. These instructions decrement, increment, or test a loop count in a CPU register and then branch based on a zero or nonzero test result. The CPU registers that can be used for the loop count are A, B, D, X, Y, or SP. The branch range is a 9 -bit signed value $(-512$ to +511$)$ which gives these instructions twice the range of a short branch instruction.

## C.7.5 Long Branches

All of the branch instructions from the $\mathrm{M} 68 \mathrm{HC1} 1$ are also available with 16-bit offsets which allows them to reach any location in the 64 K byte address space.

## C.7.6 Minimum and Maximum Instructions

Control programs often need to restrict data values within upper and lower limits. The HCS 12 facilitates this function with 8 - and 16-bit versions of MIN and MAX instructions. Each of these instructions has a version that stores the result in either the accumulator or in memory.

For example, in a fuzzy logic inference program, rule evaluation consists of a series of MIN and MAX operations. The MIN operation determines the smallest rule input and stores the running result in an accumulator. The MAX operation stores the largest rule truth value in an accumulator or stores the previous fuzzy output value from a RAM location in the fuzzy output in RAM. The following code demonstrates how MIN and MAX instructions can be used to evaluate a rule with four inputs and two outputs.

| LDY | \#OUT1 | ; Point at first output |
| :---: | :---: | :---: |
| LDX | \# IN1 | ; Point at first input value |
| LDAA | \# \$FF | ; start with largest 8-bit number in A |
| MINA | 1, X+ | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, ~ I N 1)$ |
| MINA | 1, X+ | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, \mathrm{IN} 2)$ |
| MINA | 1, X+ | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, \mathrm{IN} 3)$ |
| MINA | 1, X+ | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, \mathrm{IN} 4)$ so A holds smallest input |
| MAXM | 1, Y+ | ; OUT1=MAX(A,OUT1) and A is unchanged |
| MAXM | 1, Y+ | ; OUT1=MAX (A, OUT2) A still has min input |

Before this sequence is executed, the fuzzy outputs must be cleared to zeros (not shown). M68HC11 MIN or MAX operations are performed by executing a compare followed by a conditional branch around a load or store operation.

These instructions can also be used to limit a data value prior to using it as an input to a table lookup or other routine. Suppose a table is valid for input values between $\$ 20$ and $\$ 7 \mathrm{~F}$. An arbitrary input value can be tested against these limits and be replaced by the largest legal value if it is too big, or the smallest legal value if too small using the following two HCS12 instructions.


The ",PCR" notation is also new for the HCS12. This notation indicates the programmer wants an appropriate offset from the PC reference to the memory location (HILIMIT or LOWLIMIT in this example), and then to assemble this instruction into a PC-relative indexed MIN or MAX instruction.

## C.7.7 Fuzzy Logic Support

The HCS12 includes four instructions (MEM, REV, REVW, and WAV) specifically designed to support fuzzy logic programs. These instructions have a very small impact on the size of the CPU, and even less impact on the cost of a complete MCU. At the same time these instructions dramatically reduce the object code size and execution time for a fuzzy logic inference program. A kernel written for the M68HC11 required about 250 bytes. The HCS12 kernel uses about 50 bytes.

## C.7.8 Table Lookup and Interpolation

The HCS12 instruction set includes two instructions (TBL and ETBL) for lookup and interpolation of compressed tables. Consecutive table values are assumed to be the x coordinates of the endpoints of a line segment. The TBL instruction uses 8 -bit table entries ( y -values) and returns an 8-bit result. The ETBL instruction uses 16-bit table entries (y-values) and returns a 16-bit result.

An indexed addressing mode is used to identify the effective address of the data point at the beginning of the line segment, and the data value for the end point of the line segment is the next consecutive memory location (byte for TBL and word for ETBL). In both cases, the B accumulator represents the ratio of (the $x$-distance from the beginning of the line segment to the lookup point) to (the $x$-distance from the beginning of the line segment to the end of the line segment). B is treated as an 8 -bit binary fraction with radix point left of the MSB , so each line segment is effectively divided into 256 pieces. During execution of the TBL or ETBL instruction, the difference between the end point $y$-value and the beginning point $y$-value (a signed byte for TBL or a signed word for ETBL) is multiplied by the B accumulator to get an intermediate delta-y term. The result is the $y$-value of the beginning point, plus this signed intermediate delta-y value.

## C.7.9 Extended Bit Manipulation

The M68HC11 CPU only allows direct or indexed addressing. This typically causes the programmer to dedicate an index register to point at some memory area such as the on-chip registers. The HCS12 allows all bit-manipulation instructions to work with direct, extended or indexed addressing modes.

## C.7.10 Push and Pull D and CCR

The HCS12 includes instructions to push and pull the D accumulator and the CCR. It is interesting to note that the order in which 8-bit accumulators A and B are stacked for interrupts is the opposite of what would be expected for the upper and lower bytes of the 16 -bit D accumulator. The order used originated in the M6800, an 8-bit microprocessor developed long before anyone thought 16-bit single-chip devices would be made. The interrupt stacking order for accumulators A and B is retained for code compatibility.

## C.7.11 Compare SP

This instruction was added to the HCS12 instruction set to improve orthogonality and high-level language support. One of the most important requirements for C high-level language support is the ability to do arithmetic on the stack pointer for such things as allocating local variable space on the stack. The LEAS $-5, \mathrm{SP}$ instruction is an example of how the compiler could easily allocate five bytes on the stack for local variables. LDX 5,SP+ loads X with the value on the bottom of the stack and deallocates five bytes from the stack in a single operation that takes only two bytes of object code.

## C.7.12 Support for Memory Expansion

Bank switching is a common method of expanding memory beyond the 64 K byte limit of a CPU with a 64 K byte physical address space, but there are some known difficulties associated with bank switching.

One problem is that interrupts cannot take place during the bank-switching operation. This increases worst case interrupt latency and requires extra programming space and execution time.

Some HCS12 Core includes a built-in bank switching scheme that eliminates many of the problems associated with external switching logic. The HCS12 includes CALL and return from call (RTC) instructions that manage the interface to the bank-switching system. These instructions are analogous to the JSR and RTS instructions, except that the bank page number is saved and restored automatically during execution. Since the page change operation is part of an uninterruptable instruction, many of the difficulties associated with bank switching are eliminated. On HCS12 systems with expanded memory capability, bank numbers are specified by on-chip control registers. Since the addresses of these control registers may not be the same in all systems, the HCS12 has a dedicated control line to the on-chip integration module that indicates when a memory-expansion register is being read or written. This allows the CPU to access the PPAGE register without knowing the register address.

The indexed-indirect versions of the CALL instruction access the address of the called routine and the destination page value indirectly. For other addressing mode variations of the CALL instruction, the destination page value is provided as immediate data in the instruction object code. CALL and RTC execute correctly in the normal 64 K byte address space, thus providing for portable code.
: User Guide - S12CPU15ƯGef.şcale Semiconductor, Inc.

## Freescale Semiconducterfe Inef tuide - s12CPU15UG v1.2

## Core User Guide End Sheet

## Core User Guide End Sheet

## Home Page:

www.freescale.com email: support@freescale.com
USA/Europe or Locations Not Listed:
Freescale Semiconductor
Technical Information Center, CH370
1300 N. Alma School Road
Chandler, Arizona 85224
(800) 521-6274

480-768-2130
support@freescale.com
Europe, Middle East, and Africa:
Freescale Halbleiter Deutschland GmbH
Technical Information Center
Schatzbogen 7
81829 Muenchen, Germany
+44 1296380456 (English)
+46 852200080 (English)
+49 8992103559 (German)
+33 169354848 (French)
support@freescale.com
Japan:
Freescale Semiconductor Japan Ltd.
Headquarters
ARCO Tower 15F
1-8-1, Shimo-Meguro, Meguro-ku
Tokyo 153-0064, Japan
0120191014
+81 26668080
support.japan@freescale.com
Asia/Pacific:
Freescale Semiconductor Hong Kong Ltd.
Technical Information Center
2 Dai King Street
Tai Po Industrial Estate,
Tai Po, N.T., Hong Kong
+800 26668080
support.asia@freescale.com
For Literature Requests Only:
Freescale Semiconductor
Literature Distribution Center
P.O. Box 5405

Denver, Colorado 80217
(800) 441-2447

303-675-2140
Fax: 303-675-2150
LDCForFreescaleSemiconductor
@hibbertgroup.com

RoHS-compliant and/or Pb- free versions of Freescale products have the functionality and electrical characteristics of their non-RoHS-compliant and/or non-Pb- free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative.

For information on Freescale.s Environmental Products program, go to http://www.freescale.com/epp.

Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.


[^0]:    *wavr is a pseudoinstruction that recovers intermediate results from the stack rather than initializing them to 0 .
    ${ }^{* *}$ The $\mathrm{frr} \wedge^{\wedge} \mathrm{ffff}$ sequence is the loop for one iteration of SOP and SOW recovery. The ^ denotes a check for pending interrupt requests.
    ${ }^{* * *}$ These are additional cycles caused by an interrupt: SSS is the exit sequence and UUUrr^ is the re-entry sequence.

[^1]:    Hex postbyte $\longrightarrow \begin{array}{cc}00 & 0 \mathrm{x} \\ \text { Type of offset } \longrightarrow \\ 5 \mathrm{~b} \text { const }\end{array} \longleftarrow$ Source code syntax C

[^2]:    *wavr is a pseudoinstruction that recovers intermediate results from the stack rather than initializing them to 0 .
    ${ }^{* *}$ The $\mathrm{frr} \wedge \mathrm{ffff}$ sequence is the loop for one iteration of SOP and SOW recovery. The $\wedge$ denotes a check for pending interrupt requests.
    ${ }^{* * *}$ These are additional cycles caused by an interrupt: SSS is the exit sequence and UUUrr^ is the re-entry sequence.

