MICROCOMPUTER MN103E MN103E Series Instruction Manual Pub.No.13350-020E MS-DOS is a registered trademark of Microsoft Corporation. Windows is a trademark of Microsoft Corporation. PanaXSeries is a trademark of Matsushita Electric Industrial Co., Ltd. The other corporation names, logotype and product names written in this book are trademarks or registered trademarks of their corresponding corporations. # Request for your special attention and precautions in using the technical information and semiconductors described in this book - (1) An export permit needs to be obtained from the competent authorities of the Japanese Government if any of the products or technologies described in this book and controlled under the "Foreign Exchange and Foreign Trade Law" is to be exported or taken out of Japan. - (2) The technical information described in this book is limited to showing representative characteristics and applied circuits examples of the products. It neither warrants non-infringement of intellectual property right or any other rights owned by our company or a third party, nor grants any license. - (3) We are not liable for the infringement of rights owned by a third party arising out of the use of the product or technologies as described in this book. - (4) The products described in this book are intended to be used for standard applications or general electronic equipment (such as office equipment, communications equipment, measuring instruments and household appliances). - Consult our sales staff in advance for information on the following applications: - Special applications (such as for airplanes, aerospace, automobiles, traffic control equipment, combustion equipment, life support systems and safety devices) in which exceptional quality and reliability are required, or if the failure or malfunction of the products may directly jeopardize life or harm the human body. - Any applications other than the standard applications intended. - (5) The products and product specifications described in this book are subject to change without notice for modification and/or improvement. At the final stage of your design, purchasing, or use of the products, therefore, ask for the most up-to-date Product Standards in advance to make sure that the latest specifications satisfy your requirements. - (6) When designing your equipment, comply with the guaranteed values, in particular those of maximum rating, the range of operating power supply voltage, and heat radiation characteristics. Otherwise, we will not be liable for any defect which may arise later in your equipment. Even when the products are used within the guaranteed values, take into the consideration of incidence of break down and failure mode, possible to occur to semiconductor products. Measures on the systems such as redundant design, arresting the spread of fire or preventing glitch are recommended in order to prevent physical injury, fire, social damages, for example, by using the products. - (7) When using products for which damp-proof packing is required, observe the conditions (including shelf life and amount of time let standing of unsealed items) agreed upon when specification sheets are individually exchanged. - (8) This book may be not reprinted or reproduced whether wholly or partially, without the prior written permission of Matsushita Electric Industrial Co., Ltd. If you have any inquiries or questions about this book or our semiconductors, please contact one of our sales offices listed at the back of this book. # About This Manual This manual describes the details of the instruction set for the MN103E series. MN103E series has the following four kinds of microprocessors; AM33-1/AM33-2/AM33-2A/AM34-1, and this manual describes mainly the AM33-2 microprocessor core. When specifications differ according to microprocessor core, this describes the contents with each microprocessor-core mark. Chapter 2 explains the overview of the instruction system, instruction functions, instruction format. Chapter 2 explains all instruction operations, flag changes and etc. Chapter 3 explains the pipeline architecture, cautions on the instruction description and recommendations on the instruction description. Moreover, the instruction lists: instruction set and instruction map, are shown as appendix. #### · How to search There are four search ways in this manual in order to find necessary information quickly. - 1. See the chapter title index at the beginning of the manual for finding each chapter title. - 2. See the table of contents at the beginning of the manual for finding each title. - 3. Each page has chapter title at the top end of the page and smaller title at the bottom end. You can roughly know the contents described on pages with turning pages. - 4. See the index at the end of the manual for finding instructions. Use the indexes showing the instruction functions on the right pages for search. #### Related Manuals The following related manuals are available. Please contact your sales representative for more details. MN103E Series Cross Assembler User's Manual <Describes the assembler syntax and writing method> MN103E Series C compiler User's Manual: Usage Guide <Describes the installation, startup and option of the C compiler> MN1030/MN103S/MN103E Series C Compiler User's Manual: Language Description <Describes the C-language syntax> MN1030/MN103S/MN103E Series C Compiler User's Manual: Library Reference <Describes the C-compiler standard library> MN103E Series C Source Code Debugger for Windows® User's Manual <Describes the use of the C Source Code Debugger for Windows®> MN103E Series Installation Manual <Describes the installation of Compiler, Crossassembler and C Source Code</p> Debugger, and the procedure for bringing up the in-circuit emulator> MN1030/MN103S/MN103E Series On-board Debug Unit Setup Manual <Describes the connection of the On-board Debug Unit and the initial setting of On-board debugger> MN101C/MN101D/MN101E/MN102E/MN102L/MN102H/MN1030/MN103S Series PCI/PC Card installation Manual <Describes the PCI/PC Card Installation> #### · How to read Chapter 1 consists of mainly titles, abstracts, main body and cautions. Chapter 2 consists of instruction formats, operational descriptions and cautions. Chapter 3 consists of pipeline architecture, sample program and cautions. The following shows the layout and meaning of each part. # **Table of Contents** Chapter 1 Instruction Introduction Chapter 2 Instruction Description Chapter 3 Directions for using instructions Chapter 4 Appendix Index # **Table of Contents** | jn | apter 1 | Instruction Introduction —————— | | |----|-----------|-------------------------------------------------|----| | 1 | Instruc | etion system | 2 | | 2 | Basic re | egister set | 3 | | | 2-1 Reg | ister set | 3 | | | 2-1-1 | Address register | 4 | | | 2-1-2 | Data register | 4 | | | 2-1-3 | Extension register | 4 | | | 2-1-4 | Stack pointer | 4 | | | 2-1-5 | Program counter | 5 | | | 2-1-6 | Processor status word | 5 | | | 2-1-7 | Loop instruction register | 6 | | | 2-1-8 | Loop address register | 6 | | | 2-1-9 | Multiply/divide register | 7 | | | 2-2 Exte | ended register set | 7 | | | 2-2-1 | Extended operation register | 7 | | | 2-2-2 | Multiply-and-accumulate operation registers | 7 | | | 2-2-3 | Multiply-and-accumulate overflow flag | 7 | | | 2-3 Floa | nting-point register set | 8 | | | 2-3-1 | Floating-point register | 8 | | | 2-3-2 | Floating-point unit control register | 8 | | 3 | Instruc | etion functions | 9 | | | 3-1 Tran | nfer instructions | 11 | | | 3-2 Arit | hmetic operation instruction | 11 | | | 3-3 Con | npare instruction | 12 | | | 3-4 Log | ic operation instruction | 12 | | | 3-6 Shif | t instructions | 13 | | | 3-7 NOI | P instructions | 13 | | | 3-5 Bit 1 | manipulation instructions | 13 | | | 3-8 Bran | nch instructions | 14 | | | 3-9 Deb | ug instruction | 14 | | | 3-10 Ex | tended operation instructions | 15 | | | 3-11 LIV | W extended operation instructions | 16 | | | 3-12 Flo | pating-point operation instructions | 17 | | 4 | Memo | ry space | 18 | | | Address | space when using an MMU (logical address space) | 18 | | | Address space when not using an MMU | 19 | |-----|-------------------------------------------------------|----| | 5 | Addressing mode | 20 | | | 5-1 Register direct | 21 | | | 5-2 Immediate | 21 | | | 5-3 Register indirect | 21 | | | 5-4 Register relative indirect | 22 | | | 5-5 Absolute | 22 | | | 5-6 Register indirect with indexed addressing | 22 | | 6 | Instruction formats | 23 | | | 6-1 Data formats | 25 | | | 6-2 Endian | 26 | | Cha | apter 2 Instruction Description ————— | | | | Notations | 30 | | Т | ransfer instructions | | | | MOV Reg1, Reg2 | | | | MOV imm, Reg | 33 | | | MOV MSP, An <privileged instruction=""></privileged> | | | | MOV Am, MSP <privileged instruction=""></privileged> | | | | MOV SSP, An <privileged instruction=""></privileged> | 35 | | | MOV Am, SSP < Privileged instruction> | 35 | | | MOV USP, An <privileged instruction=""></privileged> | 36 | | | MOV Am, USP <privileged instruction=""></privileged> | 36 | | | MOV EPSW, Dn <privileged instruction=""></privileged> | | | | MOV Dm, EPSW <privileged instruction=""></privileged> | | | | MOV PSW, Dn <privileged instruction=""></privileged> | 38 | | | MOV Dm, PSW <privileged instruction=""></privileged> | 38 | | | MOV MDR, Dn | 39 | | | MOV Dm, MDR | 39 | | | MOV imm, SP | 40 | | | MOV Reg, SP | 40 | | | MOV SP, Reg | 40 | | | MOV imm, MDRQ | 41 | | | MOV MDRQ, Rn | 41 | | | MOV Rm, MDRQ | 41 | | | MOV imm, MCRH | 42 | | | MOV MCRH, Rn | 42 | | | MOV Rm, MCRH | 42 | | | MOV imm, MCRL | 43 | | | | | | MOV MCRL, Rn | 43 | |------------------------------------------------------------------------|----| | MOV Rm, MCRL | 43 | | MOV imm, MCVF | 44 | | MOV MCVF, Rn | 44 | | MOV Rm, MDRQ | 44 | | MOV PC, An | 45 | | MOV Mem, Reg | 46 | | MOV Reg, Mem | 48 | | MOV (Rm+,imm), Rn | 50 | | MOV (Rm+), Rn | 50 | | MOV Rm, (Rn+,imm) | 51 | | MOV Rm, (Rn+) | 51 | | MOVU imm, Reg | 52 | | MOVHU Mem, Reg | 53 | | MOVHU Reg, Mem | 55 | | MOVHU (Rm+, imm), Rn | 57 | | MOVHU (Rm+), Rn | 57 | | MOVHU Rm, (Rn+, imm) | 58 | | MOVHU (Rm+), Rn | 58 | | MOVBU Mem, Reg | 59 | | MOVBU Reg, Mem | 60 | | MOVM (SP), regs (SP relative) | 61 | | MOVM regs, (SP) (SP relative) | 63 | | MOVM (SP), regs (SP relative) | 65 | | MOVM regs,(USP)(USP relative <privileged instruction="">)</privileged> | 67 | | EXT Reg | 69 | | EXTH Reg | 70 | | EXTH Reg1, Reg2 | 70 | | EXTHU Reg | | | EXTHU Reg1, Reg2 | | | EXTB Reg | | | EXTB Reg1, Reg2 | | | EXTBU Reg | | | EXTBU Reg1, Reg2 | | | EXTBU Reg | | | DCPF Mem | | | Arithmetic instructions | | | ADD Reg1, Reg2 | 76 | | ADD Reg1, Reg2, Reg3 | | |------------------------------------------|-----| | ADD imm, Reg | 77 | | ADD imm, SP | 77 | | ADDC Reg1, Reg2 | | | ADDC Reg1, Reg2, Reg3 | | | ADDC imm, Reg | 79 | | SUB Reg1, Reg2 | 80 | | SUB Reg1, Reg2, Reg3 | 80 | | SUB imm, Reg | 81 | | SUBC Reg1, Reg2 | 82 | | SUBC Reg1, Reg2, Reg3 | 82 | | SUBC imm, Reg | 83 | | MUL Reg1, Reg2 | 84 | | MUL Reg1, Reg2, Reg3, Reg4 | 84 | | MUL imm, Reg | 85 | | MULU Reg1, Reg2 | 86 | | MULU Reg1, Reg2, Reg3, Reg4 | 86 | | MULU imm, Reg | 87 | | DIV Reg1, Reg2 | 88 | | DIVU Reg1, Reg2 | 89 | | INC Reg | 90 | | INC4 Reg | 91 | | Compare instrucitons | | | CMP Reg1, Reg2 | 92 | | CMP imm, Reg | 93 | | Logical instructions | | | AND Reg1, Reg2 | 94 | | AND Reg1, Reg2, Reg3 | | | AND imm, Reg | | | AND imm16, PSW (Privileged instruction) | | | AND imm32, EPSW (Privileged instruction) | | | OR Reg1, Reg2 | | | OR Reg1, Reg2, Reg3 | | | OR imm, Reg | | | OR imm16, PSW (Privileged instruction) | | | OR imm32, EPSW (Privileged instruction) | | | XOR Reg1, Reg2 | 100 | | | | | XOR Reg1, Reg2, Reg3 | 100 | |-----------------------------------|-----| | XOR imm, Reg | 101 | | NOT Reg | 102 | | | | | Bit manipulate instructions | | | BTST imm, Reg | 103 | | BTST imm, Mem | | | BSET Reg, Mem | 104 | | BSET imm, Mem | | | BCLR Reg, Mem | 106 | | BCLR imm, Mem | | | Shift instructions | | | | 100 | | ASR Reg1, Reg2 | | | ASR Reg1, Reg2, Reg3 | | | ASR imm, Reg | | | LSR Reg1, Reg2 | | | LSR Reg1, Reg2, Reg3 LSR imm, Reg | | | ASL Reg1, Reg2 | | | ASL Reg1, Reg2, Reg3 | | | ASL imm, Reg | | | ASL2 Reg | | | ROR Reg | | | ROL Reg | | | KOL Keg | 119 | | Branch instructions | | | Bcc (d8, PC) | 120 | | Lee | 121 | | SETLB | 122 | | JMP (An) | 123 | | JMP (d16, PC) | 123 | | JMP (d32, PC) | 124 | | CALL (d16, PC), regs, imm8 | 125 | | CALL (d32, PC), regs, imm8 | 126 | | CALLS (An) | 127 | | CALLS (d16, PC) | | | CALLS (d32, PC) | | | RET regs, imm8 | 129 | | RETF | 130 | | RETS | 131 | |----------------------------------|-----| | RTI (Privileged instruction) | | | TRAP | | | NOP | | | SYSCALL imm4 | | | Debug instructions | | | PI | | | Extension operation instructions | | | DMULH Rm, Rn | 137 | | DMULH Rm, Rn, Rd1, Rd2 | 137 | | DMULH imm, Rn | | | DMULHU Rm, Rn | 139 | | DMULHU Rm, Rn, Rd1, Rd2 | | | DMULHU imm, Rn | 140 | | DMACH Rm, Rn, Rd | 141 | | DMACH Rm, Rn | 141 | | DMACH imm, Rn | 142 | | DMACHU Rm, Rn, Rd | 143 | | DMACHU Rm, Rn | | | DMACHU imm, Rn | 144 | | MAC Rm, Rn, Rd1, Rd2 | | | MAC Rm, Rn | 145 | | MAC imm, Rn | 146 | | MACU Rm, Rn, Rd1, Rd2 | 147 | | MACU Rm, Rn | 147 | | MACU imm, Rn | 148 | | MACH Rm, Rn | 149 | | MACH Rm, Rn, Rd1, Rd2 | 149 | | MACH imm, Rn | | | MACHU Rm, Rn | | | MACHU Rm, Rn, Rd1, Rd2 | | | MACHU imm, Rn | | | MACB Rm, Rn | | | MACB Rm, Rn, Rd | | | MACB imm, Rn | | | MACBU Rm, Rn | | | MACBU Rm, Rn, Rd | 155 | |------------------------------|-----| | MACBU imm, Rn | 156 | | SWHW Rm, Rn | 157 | | SWAP Rm, Rn | 158 | | SWAPH Rm, Rn | 159 | | SAT16 Rm, Rn | 160 | | SAT24 Rm, Rn | 161 | | MCSTE Rm, Rn | 162 | | MCSTE imm, Rn | 164 | | BSCH Rm, Rn | 166 | | BSCH Rm, Rn, Rd | 167 | | LIW instructions | | | ADD OP2 Rm1, Rn1, Rm2, Rn2 | 168 | | ADD OP2 Rm1, Rn1, imm, Rn2 | 169 | | ADD_OP2 imm, Rn1, Rm2, Rn2 | 170 | | ADD_OP2 imm, Rn1, imm, Rn2 | 171 | | CMP_OP2 Rm1, Rn1, Rm2, Rn2 | 172 | | CMP_OP2 Rm1, Rn1, imm, Rn2 | 172 | | CMP_OP2 imm, Rn1, Rm2, Rn2 | 173 | | CMP_OP2 imm, Rn1, imm, Rn2 | 173 | | SUB_OP2 Rm1, Rn1, Rm2, Rn2 | 174 | | SUB_OP2 Rm1, Rn1, imm, Rn2 | 175 | | SUB_OP2 imm, Rn1, Rm2, Rn2 | 176 | | SUB_OP2 imm, Rn1, imm, Rn2 | 177 | | MOV_OP2 Rm1, Rn1, Rm2, Rn2 | 178 | | MOV_OP2 Rm1, Rn1, imm, Rn2 | 179 | | MOV_OP2 imm, Rn1, Rm2, Rn2 | 180 | | MOV_OP2 imm, Rn1, imm, Rn2 | 181 | | AND_OP2 Rm1, Rn1, Rm2, Rn2 | 182 | | AND_OP2 Rm1, Rn1, imm, Rn2 | 183 | | OR_OP2 Rm1, Rn1, Rm2, Rn2 | 184 | | OR_OP2 Rm1, Rn1, imm, Rn2 | 185 | | XOR_OP2 Rm1, Rn1, Rm2, Rn2 | 186 | | XOR_OP2 Rm1, Rn1, imm, Rn2 | 187 | | DMACH_OP2 Rm1, Rn1, Rm2, Rn2 | 188 | | DMACH_OP2 Rm1, Rn1, imm, Rn2 | 189 | | SWHW_OP2 Rm1, Rn1, Rm2, Rn2 | 190 | | SWHW_OP2 Rm1, Rn1, imm, Rn2 | 191 | | SAT16_OP2 Rm1, Rn1, Rm2, Rn2 | 192 | | SAT16_OP2 Rm1, Rn1, imm, Rn2 | 193 | |--------------------------------------|-----| | OP1_ADD Rm1, Rn1, Rm2, Rn2 | 194 | | OP1_ADD imm, Rn1, Rm2, Rn2 | 195 | | OP1_ADD Rm1, Rn1, imm, Rn2 | 196 | | OP1_ADD imm, Rn1, imm, Rn2 | 197 | | OP1_SUB Rm1, Rn1, Rm2, Rn2 | 198 | | OP1_SUB imm, Rn1, Rm2, Rn2 | 199 | | OP1_SUB Rm1, Rn1, imm, Rn2 | 200 | | OP1_SUB imm, Rn1, imm, Rn2 | 201 | | OP1_CMP Rm1, Rn1, Rm2, Rn2 | 202 | | OP1_CMP imm, Rn1, Rm2, Rn2 | 202 | | OP1_CMP Rm1, Rn1, imm, Rn2 | 203 | | OP1_CMP imm, Rn1, imm, Rn2 | 203 | | OP1_MOV Rm1, Rn1, Rm2, Rn2 | 204 | | OP1_MOV imm, Rn1, Rm2, Rn2 | 205 | | OP1_MOV Rm1, Rn1, imm, Rn2 | 206 | | OP1_MOV imm, Rn1, imm, Rn2 | 207 | | OP1_ASR Rm1, Rn1, Rm2, Rn2 | 208 | | OP1_ASR imm, Rn1, Rm2, Rn2 | 209 | | OP1_ASR Rm1, Rn1, imm, Rn2 | 210 | | OP1_ASR imm, Rn1, imm, Rn2 | 211 | | OP1_LSR Rm1, Rn1, Rm2, Rn2 | 212 | | OP1_LSR imm, Rn1, Rm2, Rn2 | 213 | | OP1_LSR Rm1, Rn1, imm, Rn2 | 214 | | OP1_LSR imm, Rn1, imm, Rn2 | 215 | | OP1_ASL Rm1, Rn1, Rm2, Rn2 | 216 | | OP1_ASL imm, Rn1, Rm2, Rn2 | 217 | | OP1_ASL Rm1, Rn1, imm, Rn2 | 218 | | OP1_ASL imm, Rn1, imm, Rn2 | 219 | | MOV_Lec (Rm+, imm), Rn | 220 | | | | | UDF instructions | | | UDF00 Dm, Dn (MULQ Dm, Dn) | 222 | | UDF00 imm, Dn (MULQ imm, Dn) | 222 | | UDF01 Dm, Dn (MULQU Dm, Dn) | 223 | | UDFU01 imm, Dn (MULQU imm, Dn) | 223 | | UDF02 Dm, Dn (MCST32, MCST16, MCST8) | 224 | | UDF03 Dm, Dn (MCST9 Dn) | 226 | | UDF04 Dm, Dn (SAT16 Dm, Dn) | 227 | |---------------------------------------|-----| | UDF05 Dm, Dn (SAT24 Dm, Dn) | 228 | | UDF06 Dm, Dn (MCST48 Dn) | 229 | | UDF07 Dm, Dn (BSCH Dm, Dn) | 230 | | UDF08 Dm, Dn (SWAP Dm, Dn) | 231 | | UDF09 Dm, Dn (SWAPH Dm, Dn) | 232 | | UDF12 Dm, Dn (GETCHX Dn) | 233 | | UDF13 Dm, Dn (GETCLX Dn) | 234 | | UDF15 Dm, Dn (GETX, Dn) | 235 | | Floating-point operation instructions | | | FMOV Mem, FSn | 236 | | FMOV FSm, Mem | 237 | | FMOV (Rm+), FSn | 238 | | FMOV (Rm+, imm), FSn | 239 | | FMOV FSm, (Rn+) | 240 | | FMOV FSm, (Rn+, imm) | 241 | | FMOV FSm, FSn | 242 | | FMOV FSm, Rn | 242 | | FMOV Rm,FSn | 243 | | FMOV imm,FSn | 243 | | FMOV FPCR,Rn | 244 | | FMOV Rm,FPCR | 245 | | FMOV imm,FPCR | | | FMOV Mem,FDn | 247 | | FMOV FDm,Mem | 248 | | FMOV (Rm+),FDn | 249 | | FMOV (Rm+,imm),FDn | 250 | | FMOV FDm,(Rn+) | 251 | | FMOV FDm,(Rn+,imm) | 252 | | FABS FSn | 253 | | FABS FSm, FSn | 253 | | FNEG FSn | 254 | | FNEG FSm, FSn | 254 | | FRSQRT FSn | 255 | | FRSQRT FSm, FSn | 255 | | FCMP FSm1, FSm2 | 257 | | FCMP imm, FSm | 257 | | FADD FSm FSn | 260 | | FADD FSm1, FSm2, FSn | 260 | |-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FADD imm, FSm, FSn | 261 | | FSUB FSm1, FSm2, FSn | 263 | | FSUB FSm, FSn | 263 | | FSUB imm, FSm, FSn | 264 | | FMUL FSm, FSn | 266 | | FMUL FSm1, FSm2, FSn | 266 | | FMUL imm32, FSm, FSn | 267 | | FDIV FSm, FSn | 269 | | FDIV FSm1, FSm2, FSn | 269 | | FDIV imm, FSm, FSn | 270 | | FMADD FSm1, FSm2, FSm3, FSn | 272 | | FMSUB FSm1, FSm2, FSm3, FSn | 278 | | FNMADD FSm1, FSm2, FSm3,FSn | 284 | | FNMSUB FSm1, FSm2, FSm3,FSn | 290 | | FBCC (d8, PC) | 296 | | FLCC | 297 | | Pipeline architecture | 301 | | • | | | • • | | | | | | | | | | | | • • • • • • • • • • • • • • • • • • • • | | | • | | | | | | | | | | | | | | | Cautions on the instruction description | 310 | | Recommendations on Instruction description | 311 | | 3-1 Instruction assignment subsequent to branch instruction | 313 | | 3-2 Instruction assignment subsequent to SETLB | 316 | | 3-3 Assignment of the instructions preceding RETF | 317 | | 3-4 Assignment of the instructions of CALL/CALLS branch targets | 321 | | | FADD imm, FSm, FSn FSUB FSm1, FSm2, FSn FSUB FSm1, FSm2, FSn FSUB imm, FSm, FSn FMUL FSm, FSn FMUL FSm1, FSm2, FSn FMUL FSm1, FSm2, FSn FMUL imm32, FSm, FSn FDIV FSm1, FSm2, FSn FDIV FSm1, FSm2, FSn FDIV imm, FSm, FSn FMADD FSm1, FSm2, FSm3, FSn FMSUB FSm1, FSm2, FSm3, FSn FMSUB FSm1, FSm2, FSm3, FSn FNMADD FSm1, FSm2, FSm3, FSn FNMSUB FSm1, FSm2, FSm3, FSn FNMSUB FSm1, FSm2, FSm3, FSn FNMSUB FSm1, FSm2, FSm3, FSn FBCC (d8, PC) FLCC Apter 3 Directions for using instructions autions for programming Pipeline architecture 1-1 Pipeline operation 1-2 Pipeline operation of data load 1-4 Pipeline operations of operations between registers 1-3 Pipeline operations of data store 1-5 Branch pipeline operations of SETLB and LCC 1-7 Number of instruction executing cycles 1-7-1 No dependence between instructions 1-7-2 Register dependence between instructions 1-7-3 Flag dependence between instructions 1-7-4 When the FPU instruction is subsequent to CPU load/store instruction Cautions on the instruction description Recommendations on Instruction description Recommendations on Instruction description 3-1 Instruction assignment subsequent to SETLB 3-3 Assignment of the instructions preceding RETF | | Chapter 4 Appendix ——————— | | |--------------------------------------------|-----| | • | | | Instruction cycle | | | Instruction set | | | Instruction map | 377 | | INDEX ———————————————————————————————————— | | | Index | 388 | # **Instruction system** 32-bit microcontroller MN103E series is a upward microprocessor core of our 32-bit microcontroller MN103S series. This has the instruction extended in MN103E series as well as the MN103S-series instruction set and can be designed for a wide range of applications from information processing to signal processing. It consists of MN103E extending part to implement architecture extension, MMU, cache memory, FPU, and bus control circuit as centering a compact 32-bit CPU core with the instruction set having 1-byte basic instruction word length. #### CPU core AM33-1, AM33-2, AM33-2A and AM34-1 are the 32-bit microprocessor cores of Matsushita-original C language-oriented 8/16/32 bit microprocessor AM series. The instruction specification is partly different depending on the microprocessor core. Each core is defined as shown below. AM33-1...32 bit processor-typed microprocessor core. This consists of MN103E extending part to implement architecture extension, MMU, cache memory, and four modules of the bus control circuit. AM33-2...32 bit processor-typed microprocessor core. This consists of MN103E extending part to implement architecture extension, MMU, cache memory, and four FPU modules.. AM33-2A...32 bit processor-typed microprocessor core. This consists of MN103E extending part to implement architecture extension, MMU, and three modules of cache memory. AM34-1...32 bit processor-typed microprocessor core. This consists of MN103E extending part to implement architecture extension, MMU, cache memory, and four FPU modules. This manual describes mainly AM33-1 microprocessor core, and when each microprocessor core has different specifications, it shows the specifications with the above microprocessor core marks. # Register set The register set is divided into a basic register set and an extending register set for the extension operating instruction implemented in MN103E series. # 2-1 Basic register set The basic register set consists of the followings: data register for operations such as addition and subtraction, address register for pointers, extension register capable of general-purpose use, stack pointer, program pointer, processor status word, multiply/divide resister, loop instruction register, loop address register. It highly contributes to compressing the instruction code size and improving the performance, and enables programming by high-level languages such as C language. Especially, the data register and address register are comprised of banks and can have different registers between the user and supervisor levels. Total of 16 registers in the data register, address register and extension register can be used as flat general-purpose registers. (indicated as Rn for convenience in writing .) | | Address register (Bank 0) | | |----|---------------------------|---| | | A0 | | | | A1 | | | | A2 | | | | A3 | | | 31 | | 0 | | _ | Data register (Bank0) | | | | | | | | Data register (Danie) | , | |----|-----------------------|---| | | D0 | | | | D1 | | | | D2 | | | | D3 | | | 31 | | 0 | | Extension | register | |-----------|----------| |-----------|----------| | E0 | | |---------------------------|---| | EU | | | E1 | | | E2 | | | E3 | | | E4 | | | E5 | | | E6 | | | E7 | | | 31 | 0 | | Stack pointer(User level) | | | 31 | | 0 | |----|---------------------------|---| | | Program counter | | | | PC | | | 31 | | 0 | | | Multiply/divide register | | | | MDR | | | 31 | | 0 | | | Loop instruction register | | uSP | | Loop instruction register | | |----|---------------------------|---| | | LIR | | | 31 | | 0 | | | Loop address register | | | | LAR | | | | | | Address register (Bank0) | | A0 | | |----|----|---| | | A1 | | | | A2 | | | | A3 | | | 21 | | 0 | Data register (Bank0) | D0 | | |----|---| | D1 | | | D2 | | | D3 | | | 31 | 0 | | | 351 | | |----|-----------------------|---| | 31 | | 0 | | | Processor status word | | | | EPSW | | | 31 | | 0 | #### 2-1-1 Address register A0-A3: Address register This resister is mainly used as pointer of the address. In the operational instruction of AM31 compatibility, it can operate only through the instruction for calculating address (Addition and subtraction, comparison) It is used as address pointer to data in the transfer instruction of AM31 compatibility, and the transfer to the memory is always carried out at 32-bit length. It can be used as general-purpose register in the extending basic instruction. The substance of the register is comprised of the two banks that one of them is selected by nAR bit of EPSW. For the sake of convenience, the register bank, which is selected when nAR bit of EPSW is "0", is shown as Bank 0, and the register bank, which is selected when nAR bit of EPSW is "1", is shown as Bank 1. Normally Bank 0 is called "bank register", and Bank 1 is called "alternative bank register". The registers of Bank 0 and Bank 1 cannot be simultaneously accessed. #### 2-1-2 Data register D0-D3: Data register (32 bits x 4) This is an operational register can be used generally for all operations. Operations are carried out in 32-bit length. When using 8-bit or 16-bit data, changing the data size is performed through data transfer to memory or EXTB/EXTH instruction execution. The substance of the register is comprised of the two banks that one of them is selected by nAR bit of EPSW. For the sake of convenience, the register bank, which is selected when nAR bit of EPSW is "0", is shown as Bank 0, and the register bank, which is selected when nAR bit of EPSW is "1", is shown as Bank 1. Normally Bank 0 is called "bank register", and Bank 1 is called "alternative bank register". The registers of Bank 0 and Bank 1 cannot be simultaneously accessed. #### 2-1-3 Extension register E0-E7: Extension register (32 bits x 8) This is an general-purpose register to store a operation parameter and operation intermediate result. It is positioned as the extension register of data register (D0-D3) and address register (A0-A3)in the basic register set, and is used through the extension basic instruction, extension operational instruction, and DSP extension operational instruction. #### 2-1-4 Stack pointer uSP, sSP: Stack pointer This is a register to store a pointer indicating the start address of the stack area. The contents of the uSP at the user level and the sSP at the supervisor level are used as stack pointer. The execution of the instruction referring to this register is allowed only at the monitor and supervisor levels. Privileged levels Two kinds of status are defined at the privileged levels. The accessible memory space differs depending on each privileged level. #### 2-1-5 Program counter PC: Program counter (32 bits x 1) This is a register to store the address of the instruction currently being executed in CPU. #### 2-1-6 Processor status word PSW: Processor status word This is a register to show the status of CPU. It stores the flag of the operational result, interrupt mask level and etc. PSW of AM30 series microprocessor core is extended up to 32 bits and defined as EPSW in AM33 series microprocessor core. The lower 16 bits are shown as PSW and are identical to those in the AM30/AM31/AM32 microprocessor cores. The execution of the instruction referring directly to this register is allowed only at the monitor and supervisor levels. #### Z: Zero flag This bit indicates whether the result of an operation is "0" or not. For details, refer to the operational descriptions of the individual instructions. #### N: Negative flag This bit indicates whether the result of an operation is negative or not. For details, refer to the operational descriptions of the individual instructions. #### C: Carry flag This bit indicates whether the execution of an operation caused a carry out of the MSB/borrow to the MSB or not. For details, refer to the operational descriptions of the individual instructions. #### V: Overflow flag This bit indicates whether the execution of an operation caused an overflow as a value with a code or not. For details, refer to the operational descriptions of the individual instructions. ### IM2-0: Interrupt mask These bits store the current asynchronous interrupt mask level. When IE=1, maskable interrupts with a level higher than that indicated by the IM bits are accepted. If a maskable interrupt is accepted, these bits are changed to the level of the maskable interrupt that was accepted after the PSW is saved. #### IE: Interrupt enable This is used to enable the acceptance of asynchronous interrupts, except for nonmaskable interrupts and reset interrupts. When IE=1, maskable interrupts are accepted. If an asynchronous interrupt is accepted, IE is set to "0". (disabling maskable interrupts) #### S1-0: Software auxiliary bits These auxiliary bits can be used in any desired fashion by system software and etc. The application of these bits depend on the content of the software. #### T: Trace enable When T flag is set to 1, a single step interrupt is caused per execution of an instruction. This bit cannot be normally updated. 5 #### nSL: Supervisor level This indicates the current execution level. When nSL = 0, supervisor level is in effect; when nSL = 1, user level is in effect. When starting up after a reset in normal mode, nSL = 0 (i.e. supervisor level). If an asynchronous interrupt and a synchronous interrupt is generated, nSL is set to "0" after the EPSW is saved. After returning from the asynchronous interrupt/ synchronous interrupt and restoring the saved contents to the EPSW, the execution level in effect when the asynchronous interrupt/ synchronous interrupt was generated is restored. #### NMID: Nonmaskable interrupt disable This flag disables the acceptance of nonmaskable interrupts. When NMID = 0, nonmaskable interrupts are enabled. When starting up after a reset, NMID = 0, that is, nonmaskable interrupts are accepted. If a nonmaskable interrupt is accepted, NMID is set to "1" (disabling interrupts). #### nAR: Register bank control This indicates that the register of Bank 1 in the bank portion of the register file (A0-A3, D0-D3) is to be used. If an asynchronous interrupt/ synchronous interrupt is accepted, nAR is set to "0" after the EPSW is saved. #### ML: Monitor level This indicates the current execution level. ML = 1 is the monitor level and ML = 0 is non-monitor level. ML has priority over PSW.nSL. EPSW.ML is fixed to "0" in a normal mode. Accordingly, it cannot become to the monitor level. In a debug mode, if the monitor interrupts are caused, ML is set to "1" (monitor level) after the EPSW is saved. #### FE: FPU enable This enables the use of the FPU (floating-pint unit) and enables the execution of the floating-point operating instructions. When FE = 1, floating-point operating instructions can be executed. When FE = 0 and floating-point instructions are to be executed, FPU disable exceptions are generated. For the details of the floating-pint unit, refer to the chapter of "floating-point unit". #### reserved/rsv: Reserved field These are reserved for future functional extension. Reading theses fields always returns a value of "0". When writing theses fields, always write "0". #### 2-1-7 Loop instruction register #### LIR: Loop instruction register This register stores the first four bytes of the branch destination instruction stream when executing a LOOP instruction. This register is used to speed up the execution of LOOP instructions. This register is set by the SETLB instruction. This register can also be saved to and restored from the stack area by using the MOV instruction. #### 2-1-8 Loop address register #### LAR: Loop address register This register stores the leading address of the instruction stream subsequent to the instruction stream set in LIR; the jump address+4 of the LOOP instruction. #### 2-1-9 Multiply/divide register MDR: Multiply/divide register This register is provided for multiply/divide instructions. This register stores the upper 32 bits of a 64-bit multiplication result. For a division operation, this register stores the upper 32 bits of the divided and the remainder (32 bits). For details, refer to the operational descriptions of the individual instructions. ## 2-2 Extended register set The extended register set supports the extended operation instructions that are provided in the MN103E series. #### 2-2-1 Extended operation register MDRQ: Extended operation register This register is used by the multiply/divide. This stores the upper 32 bits of the 64-bit multiplication result in multiplication. This stores the 32 bits of the surplus in division. ## 2-2-2 Multiply-and-accumulate operation registers MCRH, MCRL: Multiply-and-accumulate operation registers These registers are provided as accumulators for the multiply-and-accumulate operation that is performed by the executed operation unit. MCRH stores the upper 32 bits of the 64-bit multiply-and accumulate operation result, and MCRL stores the lower 32 bits of the 64-bit multiply-and accumulate operation result. For details, refer to the description of the operation of the individual instructions. #### 2-2-3 Multiply-and-accumulate overflow flag MCVF: Multiply-and-accumulate overflow flag This register is used to store the result of overflow detection for the result produced by executing the multiply-and-accumulate operation instruction. For details, refer to the description of the operation of the individual instructions. ## 2-3 Floating-point register set The floating-point register set is used to execute the floating-point operation instruction in the floating-point operation unit. This consists of the 32-bit single-precision floating-point registers, FS0-FS31, and the floating-point unit control register (FPCR) having the operation control and flag information of the floating-point unit. These floating-point registers can be treated as sixteen 64-bit double-precision floating-point register, FD0-FD30. The floating-point register set can be access in the user level. | FS1 | | FS0 | | |------|----|------|---| | FS3 | | FS2 | | | FS5 | | FS4 | | | | | | | | FS29 | | FS28 | | | FS31 | | FS30 | | | 31 | 0 | 31 | 0 | | 63 | 32 | 31 | 0 | #### 2-3-1 Floating-point register FS0-FS31/FD0-FD30: Floating-point register This is a general-purpose floating-point register which stores the operation parameter and the floating-point operational intermediate result of the floating-point operations. This consists of the floating-point registers comprising 32-bit single-precision floating-point registers, FS0-FS31. These floating-point registers can be treated as sixteen 64-bit double-precision floating-point register, FD0-FD30. #### 2-3-2 Floating-point unit control register FPCR: Floating-point unit control register This is a control register which has the operation control of the floating-point unit and the flag information. It has the floating-point operation flag and floating-point operational exception flag as well as controls the rounding mode of the floating-point operation and the floating-point exceptional operations. # **Instruction functions** The instruction set is based on a simple instruction set. A C compiler will produce a generated code that is compact and optimized from this instruction set. As the result of that the basic instruction word length is one byte, the instruction set is a simple one that limits data transfers with memory to load and store operations and it is possible to minimize the increase in code size due to the assembler program. Furthermore, since the generated code is compact, more instructions can be placed in the limited cache memory space, resulting in an improved cache hit ratio and making it possible to minimize the degradation of performance that results from accessing external memory on the event of a miss-hit. The AM 33 microprocessor core instruction set consists of the following five instruction categories: basic instructions, extended basic instructions, extended operation instructions, LIW extended operation instructions, and floating-point operation instructions. The basic instructions are common throughout the entire AM 30 series; these instructions maintain compatibility between the different microprocessors in the series. The extended basic instructions are an extension of the basic instructions for the AM33 microprocessor core; these functions were added in order to enhance the interrupt functions and to support the extended registers. Functionally, these instructions are equivalent to basic instructions. The extended operation instructions provide compatibility with the extended instructions that were implemented in the AM31 microprocessor core. The LIW extended operation instructions support parallel operations on data. The floating-point operation instructions provide basic floating-point operations, such as arithmetic operations that handle single-precision floating-point numbers, multiply-and-accumulate operations. The instructions are all listed in the following chart. There are 47 basic instructions, 18 extended operation instructions, 70 LIW extended operation instructions, and 15 floating-point operation instructions. (Almost all of the extended basic instructions were implemented as operand extensions, as they have been included in the count of the basic instructions.) | Transfer instructions | MOV,MOVU,MOVHU,MOVBU,MOVM, EXT,EXTH,EXTHU,EXTB,EXTBU,CLR,DCPF | |------------------------------------|---------------------------------------------------------------| | Arithmetic operational instruction | ADD,ADDC,INC,INC4,SUB,SUBC,MUL,MULU,DIV,DIVU | | Compare instruction | CMP | | Logic operational instruction | AND,OR,XOR,NOT | | Shift instruction | ASR,LSR,ASL,ASL2,ROR,ROL | | Bit manipulation instruction | BTST,BSET,BCLR | | Branch instruction | Bcc,Lcc,SETLB,JMP,CALL,CALLS,TRAP, RET,RETF,RETS,RTI,SYSCALL | | Debug instruction | PI | | NOP instruction | NOP | | Extended operational instruction | DMULH,DMULHU,MAC,MACU,MACH,MACHU, MACB,MACBU,DMACH,DMACHU,SAT16,SAT24,MCSTE, BSCH,SWAP,SWAPH,SWHW | |---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LIW-typed extended operational instruction | ADD_ADD,ADD_SUB,ADD_CMP,ADD_MOV,ADD_ASR,ADD_LSR, ADD_ASL, SUB_ADD,SUB_SUB,SUB_CMP,SUB_MOV,SUB_ASR,SUB_LSR, SUB_ASL, CMP_ADD,CMP_SUB,CMP_MOV,CMP_ASR,CMP_LSR,CMP_ASL, MOV_ADD,MOV_SUB,MOV_CMP,MOV_MOV,MOV_ASR,MOV_LSR, MOV_ASL, AND_ADD,AND_SUB,AND_CMP,AND_MOV,AND_ASR,AND_LSR, AND_ASL, OR_ADD,OR_SUB,OR_CMP,OR_MOV,OR_ASR,OR_LSR,OR_ASL, XOR_ADD,XOR_SUB,XOR_CMP,XOR_MOV,XOR_ASR,XOR_LSR, XOR_ASL, DMACH_ADD,DMACH_SUB,DMACH_CMP,DMACH_MOV, DMACH_ASR,DMACH_LSR,DMACH_ASL, SAT16_ADD,SAT16_SUB,SAT16_CMP,SAT16_MOV,SAT16_ASR, SAT16_LSR,SAT16_ASL, SWHW_ADD,SWHW_SUB,SWHW_CMP,SWHW_MOV,SWHW_ASR, SWHW_LSR,SWHW_ASL, MOV_LCC | | UDF-typed instruction | UDF00,UDF01,UDF02,UDF03UDF05,UDF06,UDF07,UDF08,UDF09,<br>UDF12,UDF13,UDF15 | | Floating-point opera-<br>tional instruction | FMOV,FABS,FNEG,FCMP,FRSQRT,FADD,FSUB,FMUL,FDIV<br>FMADD,FMSUB,FNMADD,FNMSUB,<br>FBCC,FLCC | #### 3-1 Transfer instructions Transfer instructions are used to transfer data between registers, between memory and registers. Transfer instructions are grouped as MOV-typed instructions, EXT-typed instructions, and CLR-typed instructions. MOV-typed instructions provide data transfer functions using various addressing modes. Depending on the operation, displacement and immediate values also carry a sign extension. EXT-typed instructions provide transfer functions between registers with a sign extension. The CLR-typed instruction clears the contents of registers (by providing a function that transfer "0" into the registers.) Except for the CLR-typed instruction, none of these instructions generates any changes in flags. | | <u> </u> | |-------------|----------------------------------------------------------------------------------| | Instruction | Operation | | MOV | Word transfer between registers, Transfer of immediate values to registers | | | Word transfer between a register and memory (load/store) | | | Word transfer with post-increment between a register and memory (load/store) | | MOVU | Immediate value transfer to registers (immediate value with zero extension) | | MOVHU | Zero-extension and half-word transfer between a register and memory (load/store) | | | Zero-extension and half-word transfer with post-increment between a register and | | | memory (load/store) | | MOVBU | Zero-extension byte transfer between a register and memory (load/store) | | MOVM | Block transfer between multiple registers and memory (load/store) | | EXT | 64-bit signed extension for word data (processing between registers) | | EXTH | 32-bit signed extension for half-word data (processing between registers) | | EXTHU | 32-bit zero extension for half-word data (processing between registers) | | EXTB | 32-bit signed extension for byte data (processing between registers) | | EXTBU | 32-bit zero extension for byte data (processing between registers) | | CLR | Data clear (transfers 0 to registers) | # 3-2 Arithmetic operation instructions The arithmetic operation instructions perform arithmetic operations on source operands and store the results in a register. These instructions may cause changes in flags. The "+1" and "+4" addition instructions, which are frequently used for address calculation, have been established as separate instructions. | Instruction | Operation | |-------------|---------------------------------------------------------------------------------| | ADD | Addition between registers, addition between an immediate value and a register | | ADDC | Addition with carry between registers, addition with carry between an immediate | | | value and a register | | SUB | Subtraction between registers, subtraction between an immediate value and a | | | register | | SUBC | Substraction with borrow between registers, substraction with borrow between an | | | immediate value and a register | | MUL | Signed multiplication between registers, signed multiplication between an | | | immediate value and a register | | MULU | Unsigned multiplication between registers, unsigned multiplication between an | | | immediate value and a register | | DIV | Signed division between registers, signed division between an immediate value | | | and a register | | DIVU | Unsigned division between registers, unsigned division between an immediate value and a register | |------|--------------------------------------------------------------------------------------------------| | INC | Adds "1" to the value stored in a register | | INC4 | Adds "4" to the value stored in a register | # 3-3 Compare instruction The compare instruction compares the contents of two registers, or compares an immediate value with the content of a register. This instruction is primarily used ahead of a condition branch instruction. This instruction may cause changes in flags. | Instruction | Operation | ] | |-------------|------------------------------------------------------------------------------|---| | CMP | Comparison of the contents of two registers, or the contents of an immediate | | | | value and a register | | # 3-4 Logical operation instruction The logical operation instructions perform logical operations on source operands and store the results in a register. These instructions may cause changes in flags. | Instruction | Operation | |-------------|------------------------------------------------------------------------------| | AND | AND operation between registers, or AND operation between an immediate value | | | and a register | | OR | OR operation between registers, or OR operation between an immediate value | | | and a register | | XOR | Exclusive OR operation between registers, or exclusive OR operation between | | | an immediate value and a register | | NOT | Inversion of all bits in a register (one's complement processing) | ## 3-5 Bit manipulation instructions The bit manipulation instructions perform bit manipulation operations between immediate values and the contents of registers; between immediate values and the contents of memory, or between the contents of registers and the contents of memory. These instructions may cause changes in flags. | Instruction | Operation | |-------------|--------------------------------------------------------------------------| | BTST | Multiple bit test (between an immediate value and a register, between an | | | immediate value and memory) | | BSET | Multiple bit test and set (between a register and memory, between an | | | immediate value and memory | | BCLR | Multiple bit test and clear (between a register and memory, between an | | | immediate value and a register | #### 3-6 Shift instructions The shift instructions perform bit shifts of the specified amount. Regardless of the amount of the shift, the instructions can be performed in one cycle. These instructions may cause changes in flags. | Instruction | Operation | |-------------|-------------------------------------------| | ASR | Arithmetic shift right any number of bits | | LSR | Logic shift right any number of bits | | ASL | Arithmetic shift left any number of bits | | ASL2 | Arithmetic shift left two bits | | ROR | Rotate right one bit | | ROL | Rotate left one bit | ## 3-7 NOP instruction NOP instruction performs no operation. | Instruction | Operation | |-------------|--------------| | NOP | No operation | #### 3-8 Branch instructions Branch instructions are instructions that change the flow of program execution according to some conditions. There are two types of conditional branch instructions: normal conditional branch instructions and loop-only conditional branch instructions. The loop-only conditional branch instructions minimize the branching penalty and permit fast loop execution by using dedicated registers. Subroutine calls and returns are a highly functional method of manipulating the PC, saving /restoring multiple registers to/from the stack, and allocating/releasing stack area. | Instruction | Operation | |-------------|-------------------------------------------------------------------------------------| | Bcc | Conditional branch (branches to PC-relative address) | | Lcc | Loop-dedicated conditional branch (branches to start of loop set by SETLB) | | SETLB | Registration of loop start information | | JMP | Unconditional branch (PC relative, register indirect) | | CALL | Subroutine call (saves next PC and multiple registers to stack, and allocates stack | | | area) | | RET | Return from subroutine (restores stack contents and releases stack area) | | RETF | Return from subroutine (restores stack contents and releases stack area) | | RETS | Return from subroutine (restores PC only) | | RTI | Return from interrupt program | | TRAP | Subroutine call to a specific address | | SYSCALL | System call | # 3-9 Debug instruction This instruction is used by debuggers and is reserved for debuggers. | Instruction | Operation | |-------------|-------------------------------------------------------------------| | PI | This instruction is reserved by a debugger. | | | Normally, an unimplemented instruction exception occurs when this | | | instruction is executed. | | | | ## 3-10 Extended operation instructions Extended operation instructions are defined for an add-on typed extended operation unit. The instruction formats are predefined and the instruction map is also reserved. In addition to maintaining compatibility with the extended instructions that were implemented in the AM 31 microprocessor core, the AM 33 microprocessor core also supports dual multiplication/dual multiply-and-accumulate operations that multiply, in parallel, two 16-bit data values that are packed in word data. These functions accelerate audio data signal processing. | Instruction | Operation | |-------------|----------------------------------------------------------------------------------| | DMULH | Signed dual multiplication between registers, signed dual multiplication between | | | an immediate value and a register | | DMULHU | Unsigned dual multiplication between registers, unsigned dual multiplication | | | between an immediate value and a register | | DMACH | Signed dual sum-of-products operation between registers, signed dual | | | sum-of-products operation between an immediate value and a register | | DMACHU | Unsigned dual sum-of-products operation between registers, unsigned dual | | | sum-of-products operation between an immediate value and a register | | MAC | Signed sum-of-products operation between registers, signed sum-of-products | | | operation between an immediate value and a register | | MACU | Unsigned sum-of-products operation between registers, unsigned sum-of-products | | | operation between an immediate value and a register | | MACH | Signed half-word sum-of-products operation between registers, signed half-word | | | sum-of-products operation between an immediate value and a register | | MACHU | Unsigned half-word sum-of-products operation between registers, unsigned | | | half-word sum-of-products operation between an immediate value and a register | | MACB | Signed byte sum-of-products operation between registers, signed byte | | | sum-of-products operation between an immediate value and a register | | MACBU | Unsigned byte sum-of-products operation between registers, unsigned byte | | | sum-of-products operation between an immediate value and a register | | SWHW | Data ordering swap (half-word reordering within a word) | | SWAP | Data ordering swap (byte reordering within a word) | | SWAPH | Data ordering swap (byte reordering within a half-word) | | SAT16 | 16-bit saturation processing | | SAT24 | 24-bit saturation processing | | MCSTE | Sum-of-products operation result saturation processing | | BSCH | Bit search | # 3-11 LIW extended operation instructions The LIW extended operation instructions perform two operations in a single instruction. For details on each instruction, refer to the instruction specifications in chapter 2. | Instruction | Operation | |---------------------------------------------------------------|--------------------------------------------------------------------------------| | ADD_OP2 | Parallel execution of addition between registers, and OP2 | | | ADD_ADD, ADD_SUB, ADD_CMP, ADD_MOV, ADD_ASR, ADD_LSR, ADD_ASL | | SUB_OP2 | Parallel execution of subtraction between registers, and OP2 | | | SUB_ADD, SUB_SUB, SUB_CMP, SUB_MOV, SUB_ASR, SUB_LSR, AUB_ASL | | CMP_OP2 | Parallel execution of comparison between registers, and OP2 | | | CMP_ADD, CMP_SUB, CMP_MOV, CMP_ASR, CMP_LSR, CMP_ASL | | AND_OP2 | Parallel execution of AND operation between registers, and OP2 | | | AND_ADD, AND_SUB, AND_CMP, AND_MOV, AND_ASR, AND_LSR, AND_ASL | | OR_OP2 | Parallel execution of OR operation between registers, and OP2 | | | OR_ADD, OR_SUB, OR_CMP, OR_MOV, OR_ASR, OR_LSR, OR_ASL | | XOR_OP2 | Parallel execution of XOR operation between registers, and OP2 | | XOR_ADD, XOR_SUB, XOR_CMP, XOR_MOV, XOR_ASR, XOR_LSR, XOR_ASL | | | DMACH | Parallel execution of signed dual sum-of-products operation between registers, | | _OP2 | and OP2 | | | DMACH_ADD, DMACH_SUB, DMACH_CMP, DMACH_MOV, DMACH_ASR, | | | DMACH_LSR, DMACH_ASL | | SAT16 | Parallel execution of 16-bit saturation processing, and OP2 | | _OP2 | SAT16_ADD, SAT16_SUB, SAT16_CMP, SAT16_MOV, SAT16_ASR, | | | SAT16_LSR, SAT16_ASL | | SWHW | Parallel execution of half-word reordering within word, and OP2 | | OP2 | SWHW_ADD, SWHW_SUB, SWHW_CMP, SWHW_MOV, SWHW_ASR, | | _ | SWHW_LSR, SWHW_ASL | | | _ | ### 3-12 Floating-point operation instructions Floating -point operations are executed through using the floating-point operation unit. For details on each instruction, refer to the instruction specifications in chapter 2. | Instruction | Operation | |-----------------|----------------------------------------------------------------------------------------------------------| | FMOV | Data transfer between floating-point registers, transfer of immediate value to a floating-point register | | | Data transfer between a floating-point register and memory (load/store) | | | Data transfer with post-increment between a floating-point register and | | | memory (load/store) | | | Data transfer between a floating-point register and a register | | FABS | Absolute value operation between floating-point registers | | FNEG | Sign inversion operation between floating-point registers | | FRSQRT | Square root reciprocal operation between floating-point registers (1/√) | | FCMP | Compare operation between floating-point registers | | FADD | Addition between floating-point registers, addition between an immediate value | | | and a floating-point register | | FSUB | Subtraction between floating-point registers, subtraction between an immediate | | | value and a floating-point register | | FMUL | Multiplication between floating-point registers, multiplication between an | | | immediate value and a floating-point register | | FDIV | Division between floating-point registers, division between an immediate value | | EMADD | and a floating-point register Compound multiplication and addition operation between floating-point | | FMADD | registers | | FNMADD | Compound multiplication and subtraction operation between floating-point | | FMSUB<br>FNMSUB | registers | | FBCC | | | FBCC | Conditional branch by determining the floating-point conditions. (Branch of the | | | PC relative address) | | FLCC | Loop-only conditional branch by determining the floating-point conditions. | | | (Branch to the loop head set by SETLB) | ### **Memory space** #### Address space when using an MMU (logical address space) The AM33 microprocessor core supports a 32-bit logical address space, and can access a 4 GB logical address space. The logical address space is divided into the following six areas: SU0, SU1, S2, S3, S4, and M0. The SU0 space (0x00000000 to 0x3FFFFFFF: 1 GB) and the SU1 space (0x40000000 to 0x7FFFFFFF: 1 GB) can both be used at the user level and the supervisor level, and are mapped onto the physical address space in page units according to the content of the address translation table. Caching control for the SU0 space and the SU1 space is controlled as follows, according to the value of the MMUCTR.CE (Cacheable bit Enable) bit: 1. When the MMUCTR.CE bit is set to "0" SU0 space: Cacheable SU1 space: Uncacheable 2. When the MMUCTR.CE bit is set to "1" SU0 space: Whether each page is cacheable or uncacheable can be individually controlled through the status of the PTE.C bit. SU1 space: Whether each page is cacheable or uncacheable can be individually controlled through the status of the PTE.C bit. The physical address spaces onto which the SU0 and SU1 spaces can be mapped are 0x40000000 to 0xBFFFFFFF in external memory for instruction accesses, 0x40000000 to 0xBFFFFFFF in external memory and 0x0xD00000000 to 0xDFFFFFFF in the internal I/O space for data accesses. The S2 (0x80000000 to 0x9FFFFFFF: 0.5 GB) and S3 (0xA0000000 to 0xBFFFFFFF: 0.5 GB) spaces are supervisor level-only spaces; the logical addresses are mapped to physical addresses 0x80000000 to 0x9FFFFFFF in a fixed manner. The S4 (0xC0000000 to 0xDFFFFFFF: 0.5 GB) space is a supervisor level-only space; the logical addresses are mapped to the internal I/O space 0xC0000000 to 0xDFFFFFFF in a fixed manner. The M0 (0xE0000000 to 0xFFFFFFFF: 0.5 GB) space is a reserved space and cannot be accessed. Logical addresses cannot be mapped to the control register space, which is the space with addresses from 0xC0000000 to 0xCFFFFFFF in the internal I/O space. This space can be accessed through the S4 area at the privileged level or higher. Pages must be aligned by the page size. The hardware cannot convert addresses properly if page sizes other than those described above are assigned. The instruction MMU cannot map the internal I/O space to the SU0/SU1 areas. #### Address space when not using an MMU The AM33 microprocessor core supports a 32-bit address space, and is upwardly compatible with the AM30/AM31/AM32 microprocessor core and memory map. As shown in the below figure, the addresses are mapped to the physical address space in a fixed manner. In order to maintain compatibility with the AM30/AM31/AM32 microprocessor core, the internal I/O space 0x20000000 to 0x3FFFFFFF is mirrored on 0xC0000000 to 0xDFFFFFFF. ### **Addressing mode** There are the following six addressing modes that are frequently used by the compiler. Data transfer instructions permit the use of six different addressing modes: register direct, immediate, register indirect, register relative indirect, absolute, and index qualifier register indirect. Register operation instructions permit the use of two addressing mods: register direct and immediately. Register indirect with indexed addressing is used to efficiently access data in an array, etc. | Addressing mode | | Address calculation | Logical address | |----------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------|------------------| | Register direct | Rm/Rn/XRm/XRn<br>MDR/PSW/EPSW/SP | | | | Immediate value | imm8/regs,imm16<br>imm24,imm32<br>imm40,imm48 | | | | Register indirect | (Rm)/(Rn)<br>(Rm+)/(Rn+) | Rm / Rm+ / Rn / Rn+ 31 0 | 32-bit address 0 | | Register relative indirect | (d8,Rm)/(d8,Rn)<br>(d16,Am)/(d16,An)<br>(d24,Rm)/(d24,Rn)<br>(d32,Rm)/(d32,Rn)<br>d8,d16,d24 : Sign extension | Rm / Am / Rn / An | 32-bit address 0 | | | (d8,PC)<br>(d16,PC)<br>(d32,PC)<br>d8,d16 : Sign extension<br>(used only for the branch<br>instructions) | PC 31 0 + C C C C C C C C C C C C C C C C C C | 32-bit address 0 | | | (d8,SP)<br>(d16,SP)<br>(d24,SP)<br>(d32,SP)<br>d8,d16,d24 : Zero extension | SP 0 + C C C C C C C C C C C C C C C C C C | 32-bit address 0 | | Absolute | (abs8),(abs16)<br>(abs24),(abs32)<br>d8,d16,d24 : Zero extension | abs32 / 24 / 16 / 8 | 32-bit address 0 | | Indexed register inc | direct<br>(Ri,Rm)/(Ri,Rn) | Rm / Rn 31 + 0 Ri 31 0 | 32-bit address 0 | ### 5-1 Register direct The register-direct addressing mode specifies a register directly. Registers which can be specified are as follows: Rm/Rn: XRm/XRn: MDR: Multiply/divide register (32 bits) PSW: Processor status word (16 bits) EPSW: Processor status word (32 bits) SP: Stack pointer (32 bits) #### 5-2 Immediate The immediate addressing mode directly specifies transferred values through operand value added to instruction codes, mask value, and multiple registers to be transferred (regs). The immediate sizes are 8 bits (imm8), 16 bits (imm16), 24 bits (imm24), 32 bits (imm32), 40 bits (imm40), and 48 bits (imm48). As shown below, regs (8-bit immediate) can specify the registers of D2, D3, A2, and A3, and other registers (other, EXREG0, EXREG1, EXOTHER) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|-------|--------|--------|---------| | D2 | D3 | A2 | A3 | other | EXREG0 | EXREG1 | EXOTHER | other: D0, D1, A0, A1, MDR, LIR, LAR EXREG0: E2, E3 EXREG1: E4, E5, E6, E7 EXOTHER: E0, E1, MDRQ, MCRH, MCRL, MCVF ### 5-3 Register indirect The 32-bit address which is shown by the address register (An/Am) is effective in the register-indirect addressing mode. Register-indirect description: (Rm) / (Rn)(Rm+) / (Rn+) ### 5-4 Register relative indirect The register relative-indirect addressing mode is addressing shown by addition of the address register (An/Am) or program counter (PC), stack pointer (SP) and displacement. The displacement sizes are 8 bits, 16 bits, and 32 bits. Address computations are carried out for the address register (Am/An) or program counter (PC) and sign-extended 8/16 or 32-bit displacement, and for the stack pointer (SP) and zero-extended 8/16 or 32-bit displacement. ``` Register relative-indirect description: (d8, Rm) / (d8, Rn) : d8 is code-extended. \frac{(d16, Am) / (d16, An)}{(d16, An)} : d16 \text{ is code-extended.} \frac{(d24, Rm) / (d24, Rn)}{(d32, Rn)} : d24 \text{ is code-extended.} \frac{(d32, Rm) / (d32, Rn)}{(d32, Rn)} : d8 \text{ is zero-extended.} \frac{(d16, SP)}{(d24, SP)} : d16 \text{ is zero-extended.} \frac{(d24, SP)}{(d32, SP)} : d24 \text{ is zero-extended.} ``` #### 5-5 Absolute The absolute addressing mode specifies directly a 32-bit address through the 16, 24, and 32-bit operand value added to the instruction code. ``` Absolute description: (abs 16): abs 16 is zero-extended. (abs 24): abs 24 is zero-extended. (abs 32): ``` ### 5-6 Register indirect with indexed addressing The register indirect with indexed addressing is addressing shown by the address register (Rm/Rn) and data register (Ri). The 32-bit contents of the address registers (Rm/Rn) and data registers (Ri) are added. Description of the register indirect with indexed addressing: (RI, Rm) / (Ri, Rn) # 6 Instruction formats There are 14 instruction formats. The instruction set has a variable word length in which the basic word length is one byte, and the instruction length can vary in units of one byte. The shortest format is S0 format, which is one-byte long. The longest formats are S6 format, D5 format, and T4 format, each of which is seven-byte long. | | | 1 | | | |-----------|----|-----------|----------|-----------------| | Format S0 | OP | | | | | Format S1 | OP | imm8/d8 | ] | | | Format S2 | OP | imm16/d16 | 3/abs16 | | | Format S4 | OP | imm32/d32 | 2/abs32 | | | Format S6 | OP | imm48 | | | | Format D0 | OP | OP | ] | | | Format D1 | OP | OP | imm8/d8 | | | Format D2 | OP | OP | imm16/d1 | 6/abs16 | | Format D3 | OP | OP | imm24 | | | Format D4 | OP | OP | imm32/d3 | 32/abs32 | | Format D5 | OP | OP | imm40 | | | Format T0 | OP | OP | OP | | | Format T1 | OP | OP | OP | imm8/d8 | | Format T3 | OP | OP | OP | imm24/d24/abs24 | | Format T4 | OP | OP | OP | imm32/d32/abs32 | | Format Q0 | OP | OP | OP | OP | | | | | | | 23 Normally, the opecode is followed by an 8-, 16-, or 32-bit immediate value, displacement value, or absolute value. However, in instructions with formats S2, S4, S6, D2, and D5, the opecode is followed by two or more immediate values, displacement values, or absolute values; theses are noted as a whole as 16-bit immediate values (imm 16), 24-bit immediate values (imm 24), 32-bit immediate values (imm 32), 40-bit immediate values (imm 40), and 48-bit immediate values (imm 48). According to these notations, the following instructions accept 16-, 24-, 32-, 40, or 48-bit immediate values. | imm16: | RET | regs, imm8 | |--------|------|-----------------------| | | RETF | regs, imm8 | | | BTST | imm8, (d8, An) | | | BSET | imm8, (d8, An) | | | BCLR | imm8, (d8, An) | | imm24: | BTST | imm8, (abs16) | | | BSET | imm8, (abs16) | | | BCLR | imm8, (abs16) | | imm32: | CALL | (d16, PC), regs, imm8 | | imm40: | BTST | imm8, (abs32) | | | BSET | imm8, (abs32) | | | BCLR | imm8, (abs32) | | imm48: | CALL | (d32, PC), regs, imm8 | #### 6-1 Data formats There are four data types for integer data: bit, byte, half-word, and word. Byte data, half-word data, and word data can all be handled as either signed data or unsigned data. In the case of signed data, the MSB is the sign bit. For floating-point values, there are two formats: single precision floating-point values and double-precision floating-point values. | | | Bit (n=0-31) | |---------------------------------|--------------------------|--------------------------------------------------------| | | | Unsigned byte Signed byte | | | | Unsigned half-word Signed half-word Signed half-word | | | Unsigned word | | | | Signed word | 31 30 0<br>S | | | precision floating-point | 31 30 24 23 | | Double-precision floating-point | 63 62 52 51 | 0 0 | Integer data in memory must be aligned properly. In short, the two bits on the LSB side of an address where word data is stored must be "00" (i.e. the address is a multiple of 4), and the one bit on the LSB side of an address where half-word data is stored must be "0" (i.e. the address is a multiple of 2). If data that is not properly aligned is accessed, a misalignment exception is generated. Floating-point data in memory must also be aligned in a similar fashion. In short, the two bits on the LSB side of an address where single-precision floating-point data is stored must be "00" (i.e. the address is a multiple of 4). When double-precision floating-point data is stored in memory and the double-precision floating-point load/store instruction (FMOV) is being used to access memory, the three bits on the LSB side of the address must be "000" (i.e. the address is a multiple of 8). When using two single-precision floating-point load/store instructions to access data, the two bits on the LSB side of the address must be "00" (i.e. the address is a multiple of 4). | Bit No. | 31 24 | 23 16 | 15 8 | 7 0 | |----------------|----------------|----------------|----------------|--------------| | Memory address | (4n+3) | (4n+2) | (4n+1) | (4n) | | Word data | | Address : | 4n | | | Half-word data | Address : 4n+2 | | Address : | 4n | | Byte data | Address : 4n+3 | Address : 4n+2 | Address : 4n+1 | Address : 4n | #### 6-2 Endian The bytes are positioned according to Little Endian format. Therefore, the address of the byte data that is on the MSB side of half-word data is one greater than the address of the byte data that is on the LSB side of the half-word data. The address of the byte data that is on the MSB side of word data is three greater than the address of the byte data that is on the LSB side of the word data. Concerning bit numbers, in the case of that the bit on the LSB side is regarded as "bit 0", the bit numbers increase sequentially towards the MSB. When 16-bit immediate/displacement/absolute (imm16/d16/abs16) and 32-bit immediate/displacement/absolute (imm32/d32/abs32) follow the opecode, the bytes are partitioned per 8 bits from the lowest, and positioned in the order from the lower address to higher address. (Little Endian) [e.g.] 32-bit immediate value, 0x1234567 is arrayed on the memory in the Little Endian format. | Address n | 0x67 | |-------------|------| | Address n+1 | 0x45 | | Address n+2 | 0x23 | | Address n+3 | 0x01 | However, the instructions of S2, S4, S6, D2, D3, and D5 in the instruction formats have above-2 immediate, displacement, and absolute values connected after the opecode, and compose as a whole 16-bit immediate values (imm16), 24-bit immediate values (imm24), 32-bit immediate values (imm32), 40-bit immediate values (imm40), and 48-bit immediate values (imm48). They are shown below. The 16-bit displacement (d16) and 32-bit displacement/absolute values (d32/abs32) in the below figures are positioned in the Little Endian format as same as the above example. RET regs, imm8 / RETF regs, imm8 | Address n | RET/RETF | Opecode of RET or RETF | |-------------|----------|------------------------| | Address n+1 | regs | | | Address n+2 | imm8 | | BTST imm8,(d8,An) / BSET imm8,(d8,An) / BCLR imm8,(d8,An) BTST imm8,(abs16) / BSET imm8,(abs16) / BCLR imm8,(abs16) ### CALL (d16,PC), regs, imm8 | Address n | CALL | Opecode of CALL | |-------------|-----------|-----------------| | Address n+1 | ala a 4 C | | | Address n+2 | abs16 | | | Address n+3 | reg | | | Address n+4 | imm8 | | BTST imm8,(abs32) / BSET imm8,(abs32) / BCLR imm8,(abs32) | Address n | | า | |-------------|----------------|-------------------------------| | Address n+1 | BTST/BSET/BCLR | Opecode of BTST, BSET or BCLR | | Address n+2 | | | | Address n+3 | abs32 | | | Address n+4 | ab332 — | | | Address n+5 | | | | Address n+6 | imm8 | | ### CALL (d32, PC), regs, imm8 | Address n | CALL | Opecode of CALL | |-------------|-----------|-----------------| | Address n+1 | | • | | Address n+2 | -h -00 | | | Address n+3 | abs32 ——— | | | Address n+4 | | | | Address n+5 | regs | | | Address n+6 | imm8 | | ### **Notations** The symbols used in the instruction description are shown below. op1,op2,op3 : Instruction operation Reg1,Reg2,Reg3,Reg4 :Register (used as the general meaning) Am, An :Address register (m, n = 3-0)Dm, Dn,Di :Data register (m, n, i = 3-0) Rm,Rn,Rd,Rd1,Rd2 :CPU general register A0-A3: Address register D0-D3: Data register E0-E7: Extension register MDR :Multiply divide register EPSW :Processor status word (32 bits) PSW :Processor status word (lower 16 bits) PSW[15:0] = EPSW[15:0] MSP :Monitor-level stack pointer SSP :Supervisor-level stack pointer USP :User-level stack pointer SP :Stack pointer (In other words, SP refers to USP when the current level is the user level, to SSP when it is the supervisor level, and to MSP when it is monitor level.) PC :Program counter nPC :Next instruction PC LIR :Loop instruction register LAR :Loop address register MDRQ :Extension multiply register MCRH :Multiply-accumulate upper 32-bit register MCRL :Multiply-accumulate lower 32-bit register MCVF :Multiply-accumulate overflow flag register TMP :Temporary register {MCRH,MCRL} :64-bit multiply-accumulate register (The upper 32 bits consists of MCRH, the lower 32 bit consistes of MCRL.) FSm,FSm1,FSm2,FSm3,FSn:FPU single precision register FDm,FDn :FPU double precision register Mem :Memory (used as general meaning) imm :immediate value (used as general meaning) imm4:4-bit immediate valueimm8:8-bit immediate valueimm16:16-bit immediate valueimm24:24-bit immediate valueimm32:32-bit immediate value disp:diaplacementd8:8-bit displacementd16:16-bit displacementd24:24-bit displacementd32:32-bit displacement abs8 :8-bit absolute abs16 :16-bit absolute abs24 :24-bit absolute abs32 :32-bit absolute () :Indirect addressing For details, refer to Chapter 1, Instruction description, 5. Addressing mode. regs :Multiple register definition 0x . . . : hexadecimal (The numbers following 0x indicates hexadecimal.) .bpn :Bit position (n indicates the bit positions 0-31.) [n] :Bit position (n indicates the bit position.) .lsb :Bit position (Bit 0) .msb :Bit position (Bit 31) + :Addition - :Subtraction \* :Multiplication / :Division Sqrt :Square root % :Surplus & :Logical product | :Logical sum ^ :Exclusive logical sum : Reflection of operation results (sign\_ext):Sign extension(zero\_ext):Zero extensionlabel:AddressVF:OverflowflagCF:Carry flagNF:Negative flagZF:Zero flag mem8(xxx) :8-bit data within the memory addressed by xxx mem16(xxx) :16-bit data within the memory addressed by xxx mem32(xxx) :32-bit data within the memory addressed by xxx mem\_cline(xxx) :Data cache line data within the memory addressed by xxx Code Size : Code size of assembler nmemonic #### Chapter 2 Instruction description The symbols used in the flag change tables are shown below. ("Flag" is used generically for the lower 4 bits (V, C, N and Z) in PSW.) Δ :With flag change - :With no flag change 0 :Always "0" 1 :Always "1" ? :Undefined \* :Defined by user : The instruction with this mark is implemented in AM33-1. :The instruction with this mark is implemented in AM33-2. :The instruction with this mark is implemented in AM33-2A. :The instruction with this mark is implemented in AM34-1. ## MOV Transfer ### MOV Reg1, Reg2 Operation Reg1 -> Reg2 This instruction transfers the contents of Reg1 to Reg2. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|--------------------------|---|---|---|---|------| | mov Am, An | n=m cannot be specified. | _ | _ | _ | _ | 1 | | mov Dm, Dn | n=m cannot be specified. | _ | _ | _ | _ | 1 | | mov Am, Dn | | _ | _ | _ | _ | 2 | | mov Dm, An | | - | - | _ | - | 2 | | mov Am, Rn | | _ | _ | _ | _ | 2 | | mov Rm, An | | _ | _ | _ | - | 2 | | mov Dm, Rn | | _ | _ | _ | _ | 2 | | mov Rm, Dn | | _ | _ | _ | _ | 2 | | mov Rm, Rn | | _ | _ | _ | - | 3 | | | | | | | | | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV imm, Reg Operation imm -> Reg This instruction transfers imm to Reg. | c Note | V | С | N | Ζ | Size | |-------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | imm8 is zero-extended. | _ | - | - | _ | 2 | | imm16 is zero-extended. | _ | - | - | _ | 3 | | | _ | - | - | _ | 6 | | imm8 is zero-extended. | _ | - | - | _ | 2 | | imm16 is zero-extended. | _ | - | _ | _ | 3 | | | _ | _ | _ | _ | 6 | | imm8 is zero-extended. | _ | _ | _ | _ | 4 | | imm24 is zero-extended. | _ | - | - | _ | 6 | | | _ | - | - | _ | 7 | | | imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. | imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. imm8 is zero-extended. | imm8 is zero-extended. — — imm16 is zero-extended. — — imm8 is zero-extended. — — imm16 is zero-extended. — — imm8 is zero-extended. — — | imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. imm8 is zero-extended. | imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. imm16 is zero-extended. imm8 is zero-extended. imm8 is zero-extended. | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV MSP, An <Privileged instruction> Operation MSP -> An In the monitor level, this instruction transfers the contents of the monitor-level stack pointer (MSP) to the address register (An). | Assemble | er mnemonic | Note | V | С | Ν | Ζ | Size | |------------|-------------|------|---|---|---|---|------| | mov MSP, A | n | | _ | _ | _ | _ | 2 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor level. When the instruction is used in the supervisor and user levels, a system exception, priviledged instruction execution exception, occurs. ### MOV Am, MSP < Privileged instruction> Operation Am -> MSP In the monitor level, this instruction transfers the contents of the address register (Am) to the monitor-level stack pointer (MSP). | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | mov Am, MSP | | ı | _ | _ | _ | 2 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor level. ### MOV SSP, An <Privileged instruction> Operation SSP -> An In the monitor or supervisor level, this instruction transfers the contents of the supervisor-level stack pointer (SSP) to the address register (An). | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov SSP, An | | _ | _ | _ | _ | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor or supervisor level. When the instruction is used in the user level, a system exception, priviledged instruction execution exception, occurs. ### MOV Am, SSP < Privileged instruction> Operation Am -> SSP In the monitor or supervisor level, this instruction transfers the contents of the address register (Am) to the supervisor-level stack pointer (SSP). | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | mov Am, SSP | | _ | _ | _ | _ | 1 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor or supervisor level. ### MOV USP, An <Privileged instruction> ### Operation USP -> An In the monitor or supervisor level, this instruction transfers the contents of the user-level stack pointer (USP) to the address register (An). | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | mov USP, An | | _ | _ | - | - | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor or supervisor level. When the instruction is used in the user level, a system exception, priviledged instruction execution exception, occurs. ### MOV Am, USP < Privileged instruction> #### Operation Am ->USP In the monitor or supervisor level, this instruction transfers the contents of the address register (Am) to the user-level stack pointer (USP). | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | mov Am, USP | | ı | _ | _ | _ | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor or supervisor level. ### MOV EPSW, Dn <Privileged instruction> Operation EPSW -> Dn In the monitor or supervisor level, this instruction transfers the contents of the processor-status-word (EPSW) to the data register (Dn). | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov EPSW, Dn | | _ | _ | ı | _ | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor or supervisor level. When the instruction is used in the user level, a system exception, priviledged instruction execution exception, occurs. ### MOV Dm, EPSW <Privileged instruction> Operation Dm -> EPSW In the monitor or supervisor level, this instruction transfers the contents of the data register (Dm) to the processor-status-word (EPSW). | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov Dm, EPSW | | • | • | • | • | 2 | #### Flag change VF: Bit 3 of Dm. CF: Bit 2 of Dm. NF: Bit 1 of Dm. ZF: Bit 0 of Dm. This instruction is valid only in the monitor or supervisor level. ### MOV PSW, Dn < Privileged instruction> Operation PSW[15:0] -> Dn[15:0] 0x0000 -> Dn[31:16] In the monitor or supervisor level, this instruction transfers the zero-extended 16-bit processor-status-word (PSW) to the data register (Dn). | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | mov PSW, Dn | | _ | _ | - | - | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction is valid only in the monitor or supervisor level. When the instruction is used in the user level, a system exception, priviledged instruction execution exception, occurs. ### MOV Dm, PSW < Privileged instruction> Operation Dm[15:0] -> EPSW In the monitor or supervisor level, this instruction transfers the lower 16 bits of the data register (Dm) to the processor-status-word (PSW). (The upper 16 bits are ignored.) | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | mov Dm, PSW | | • | • | • | • | 2 | Flag change VF: Bit 3 of Dm. CF: Bit 2 of Dm. NF: Bit 1 of Dm. ZF: Bit 0 of Dm. This instruction is valid only in the monitor or supervisor level. ### MOV MDR, Dn Operation MDR -> Dn This instruction transfers the contents of the multiply/divide register (MDR) to the data register (Dn). Size Assembler mnemonic С Ζ Note mov MDR, Dn 2 Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. | MOV Dm, MDR | | | | | | | | | | |-------------|----------------------------------------------------------------------------------------------------------|-------------|---|---|---|---|------|--|--| | Operation | peration Dm -> MDR | | | | | | | | | | | This instruction transfers the contents of the data register (Dm) to the multiply/divide register (MDR). | | | | | | | | | | Assembl | ler mnemonic | Note | ٧ | С | N | Z | Size | | | | mov Dm, M | IDR | | - | _ | _ | - | 2 | | | | | | Flag change | | | | | | | | | | his is not changed.<br>his is not changed. | | | | | | | | | | NF: TI | his is not changed. | | | | | | | | | | ZF: Th | his is not changed. | | | | | | | | | ### MOV SP, Reg Operation SP -> Reg This instruction transfers the contents of the stack pointer (SP) to the register (Reg). | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | mov SP, An | | _ | _ | _ | | 1 | | mov SP, Rn | | _ | _ | _ | _ | 3 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV Reg, SP Operation Reg -> SP This instruction transfers the contents of Reg to SP. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov Am, SP | | _ | _ | _ | _ | 2 | | mov Rm, SP | | _ | _ | _ | _ | 3 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV imm, SP Operation imm -> SP This instruction transfers imm to SP. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | mov imm8, SP | imm8 is zero-extended. | _ | _ | _ | _ | 4 | | mov imm24, SP | imm24 is zero-extended. | ı | _ | - | _ | 6 | | mov imm32, SP | | 1 | _ | _ | _ | 7 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV MDRQ, Rn Operation MDRQ -> Rn This instruction transfers the contents of the extended multiply register (MDRQ) to Rn. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | mov MDRQ, Rn | | 0 | 0 | Δ | Δ | 3 | Flag change VF: Always 0. CF: Always 0. NF: 1 when MSB of the transfer result is 1, 0 in all other cases. ZF: 1 when the transfer result is 0, 0 in all other cases. ### MOV Rm, MDRQ Operation Rm -> MDRQ This instruction transfers the contents of Rm to MDRQ. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov Rm, MDRQ | | _ | _ | _ | - | 3 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV imm, MDRQ Operation imm -> MDRQ This instruction transfers imm to MDRQ. | Assembler | mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------|----------|-------------------------|---|---|---|---|------| | mov imm8, MD | DRQ | imm8 is zero-extended. | - | _ | _ | | 4 | | mov imm24, M | IDRQ | imm24 is zero-extended. | - | - | - | 1 | 6 | | mov imm32, M | IDRQ | | - | _ | - | | 7 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV MCRH, Rn ### Operation MCRH -> Rn MCVF -> EPSW.V This instruction transfers the contents of the upper 32 bits in the multiply-and-accumulate operation register (MCRH) to the Register (Rn). This transfers the contents of the multiply-and-accumulate overflow flag (MCVF) to the overflow flag of the processor status word (EPSW.V). | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | mov MCRH, Rn | | Δ | 0 | ? | ? | 3 | #### Flag change VF: 1 when MCVF is 1, 0 in all other cases. CF: Always 0. NF: Undefined. ZF: Undefined. ### MOV Rm, MCRH ### Operation Rm -> MCRH EPSW.V -> MCVF This instruction transfers the contents of the Register (Rm) to the upper 32 bits in the multiply-and-accumulate operation register (MCRH). This transfers the contents of the overflow flag of the processor status word (EPSW.V) to the multiply-and-accumulate overflow flag (MCVF). | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov Rm, MCRH | | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV imm, MCRH #### Operation imm -> MCRH EPSW.V -> MCVF This instruction transfers imm to the upper 32 bits in the multiply-and-accumulate operation register (MCRH). This transfers the contents of the overflow flag of the processor status word (EPSW.V) to the multiply-and-accumulate overflow flag (MCVF). | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | mov imm8, MCRH | imm8 is zero-extended. | _ | _ | - | - | 4 | | mov imm24, MCRH | imm24 is zero-extended. | _ | _ | - | 1 | 6 | | mov imm32, MCRH | | _ | _ | - | | 7 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV MCRL, Rn #### Operation MCRL -> Rn MCVF -> EPSW.V This instruction transfers the contents of the lower 32 bits in the multiply-and-accumulate operation register (MCRL) to the Register (Rn). This transfers the contents of the multiply-and-accumulate overflow flag (MCVF) to the overflow flag of the processor status word (EPSW.V). | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | mov MCRL, Rn | | Δ | 0 | ? | ? | 3 | #### Flag change VF: 1 when MCVF is 1, 0 in all other cases. CF: Always 0. NF: Undefined. ZF: Undefined. ### MOV Rm, MCRL ### Operation Rm -> MCRL EPSW.V -> MCVF This instruction transfers the contents of the Register (Rm) to the lower 32 bits in the multiply-and-accumulate operation register (MCRL). This transfers the contents of the overflow flag of the processor status word (EPSW.V) to the multiply-and-accumulate overflow flag (MCVF). | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov Rm, MCRL | | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOV imm, MCRL #### Operation imm -> MCRL EPSW.V -> MCVF This instruction transfers imm to the lower 32 bits in the multiply-and-accumulate operation register (MCRL). This transfers the contents of the overflow flag of the processor status word (EPSW.V) to the multiply-and-accumulate overflow flag (MCVF). | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | mov imm8, MCRL | imm8 is zero-extended. | 1 | _ | - | _ | 4 | | mov imm24, MCRL | imm24 is zero-extended. | _ | - | _ | - | 6 | | mov imm32, MCRL | | 1 | _ | - | 1 | 7 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. | MOV MCVF, Rn | | | | | | | | | | |--------------------------|---------------------------------|------------------------------------------------------------|-------|------|-------|----|--------|--|--| | Operation | ation MCVF -> Rn[0] | | | | | | | | | | | 0x00000000 -> | Rn[31:1] | | | | | | | | | | This instruction | n transfers the contents of the multiply-and-accumulate ov | erflo | ow f | lag ( | MC | VF) to | | | | | the bit 0 of the register (Rn). | | | | | | | | | | Assem | bler mnemonic | Note | ٧ | С | Ν | Z | Size | | | | mov MCV | F, Rn | | _ | _ | _ | - | 3 | | | | | | Flag change | | | | | | | | | VF: | This is not changed | | | | | | | | | | CF: 7 | This is not changed | | | | | | | | | | NF: This is not changed. | | | | | | | | | | | ZF: This is not changed. | | | | | | | | | | | MOV Rm, MDRQ | | | | | | | | | |--------------|-----------------------------------------------------------------|-------------|---|---|---|------|--|--| | Operation | ion Rm[0] -> MCVF | | | | | | | | | | This instruction transfers the contents of bit 0 of Rm to MCVF. | | | | | | | | | Assem | bler mnemonic | Note V | С | Ν | Ζ | Size | | | | mov Rm, I | MCVF | - | _ | _ | - | 3 | | | | | | Flag change | | | | | | | | VF: | This is not changed | | | | | | | | | CF: 7 | This is not changed | | | | | | | | | NF: | NF: This is not changed. | | | | | | | | | ZF: | ZF: This is not changed. | | | | | | | | | MOV imm, MCVF | | | | | | | | | | | |--------------------------------------------------|--------------------------|---|---|---|---|------|--|--|--|--| | Operation imm[0] -> | Operation imm[0] -> MCVF | | | | | | | | | | | This instruction transfers bit 0 of imm to MCVF. | | | | | | | | | | | | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | | | | | | mov imm8, MCVF | | | _ | - | _ | 4 | | | | | | mov imm24, MCVF | | _ | _ | _ | _ | 6 | | | | | | mov imm32, MCVF | | _ | _ | _ | - | 7 | | | | | | | Flag change | · | | | | | | | | | | VF: This is not change | d. | | | | | | | | | | | CF: This is not change | CF: This is not changed. | | | | | | | | | | | NF: This is not changed. | | | | | | | | | | | | ZF: This is not changed. | | | | | | | | | | | | MOV PC, An | | | | | | | | | | |---------------------------|------------------------------------------------------------------------------------------------------|-------------|---|---|---|---|------|--|--| | Operation | n PC -> An | | | | | | | | | | | This instruction transfers the program counter (PC) of the current instruction to the register (An). | | | | | | | | | | Assembler mnemonic Note V | | | | С | Ν | Ζ | Size | | | | mov PC, | An | | ı | ı | _ | _ | 2 | | | | | | Flag change | | | | | | | | | VF: | This is not changed | | | | | | | | | | CF: 7 | CF: This is not changed. | | | | | | | | | | NF: This is not changed. | | | | | | | | | | | ZF: | ZF: This is not changed. | | | | | | | | | ### MOV Mem, Reg Operation MOV (Reg1), Reg2 mem32(Reg1) -> Reg2 MOV (disp, Reg1), Reg2 mem32(Reg1+disp) -> Reg2 MOV (Reg1, Reg2), Reg3 mem32(Reg1+Reg2) -> Reg3 MOV (abs), Reg1 mem32(abs) -> Reg1 MOV (disp, SP), Reg1 mem32(SP+disp) -> Reg1 This instruction performs the word-data transfer of the content of Mem to Reg. MOV (disp+Reg1), SP mem32(Reg1) -> SP This instruction performs the word-data transfer of the content of Mem to the stack pointer (SP). Size Assembler mnemonic С Ν Ζ V Note mov (Am),Dn mov (Am),An 2 mov (Rm),Rn 3 \_ mov (d8,Am),Dn d8 is sign-extended. \_ 3 mov (d16,Am),Dn 4 d16 is sign-extended. \_ mov (d32,Am),Dn 6 mov (d8,Am),An 3 d8 is sign-extended. mov (d16,Am),An 4 d16 is sign-extended. mov (d32,Am),An 6 \_ mov (d8,Rm),Rn 4 d8 is sign-extended. mov (d24,Rm),Rn d24 is sign-extended. 6 mov (d32,Rm),Rn 7 mov (Di,Am),Dn 2 \_ mov (Di,Am),An 2 mov (Ri,Rm),Rn 4 mov (abs16),Dn abs16 is zero-extended. 3 mov (abs32),Dn \_ 6 mov (abs16),An 4 abs16 is zero-extended. mov (abs32),An \_ \_ 6 abs8 is zero-extended. mov (abs8),Rn 4 abs24 is zero-extended. mov (abs24),Rn \_ \_ 6 mov (abs32),Rn 7 mov (d8,SP),Dn d8 is zero-extended. 2 d16 is zero-extended. mov (d16,SP),Dn 4 mov (d32,SP),Dn 6 d8 is zero-extended. mov (d8,SP),An d16 is zero-extended. mov (d16,SP),An 4 | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|-----------------------|---|---|---|---|------| | mov (d32,SP),An | | _ | _ | _ | _ | 6 | | mov (SP),Rn | | _ | _ | _ | _ | 3 | | mov (d8,SP),Rn | d8 is zero-extended. | _ | _ | _ | - | 4 | | mov (d24,SP),Rn | d24 is zero-extended. | _ | _ | _ | _ | 6 | | mov (d32,SP),Rn | | _ | - | _ | _ | 7 | | mov (d8,Am),SP | d8 is sign-extended. | _ | _ | _ | _ | 3 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 4, a system exception (address misalignment exception) occurs. ### MOV Reg, Mem Operation MOV Reg1, (Reg2) $Reg1 \rightarrow mem32(Reg2)$ MOV Reg1, (disp, Reg2) Reg1 -> mem32(Reg2+disp) MOV Reg1, (Reg2, Reg3) $Reg1 \rightarrow mem32(Reg2+Reg3)$ MOV Reg1, (abs) Reg1 -> mem32(abs) MOV Reg1, (disp, SP) Reg1 -> mem32(SP+disp) This instruction performs the word-data transfer of the content of Reg to Mem. MOV SP, (disp+Reg1) SP -> mem32(Reg1+disp) This instruction performs the word-data transfer of the content of the stack pointer (SP) to Mem. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|-------------------------|---|---|---|---|------| | mov Dm,(An) | | _ | _ | - | - | 1 | | mov Am,(An) | | _ | _ | _ | - | 2 | | mov Rm,(Rn) | | _ | _ | _ | - | 3 | | mov Dm,(d8,An) | d8 is sign-extended. | _ | _ | _ | - | 3 | | mov Dm,(d16,An) | d16 is sign-extended. | _ | _ | - | - | 4 | | mov Dm,(d32,An) | | _ | _ | _ | - | 6 | | mov Am,(d8,An) | d8 is sign-extended. | _ | _ | - | - | 3 | | mov Am,(d16,An) | d16 is sign-extended. | _ | _ | _ | _ | 4 | | mov Am,(d32,An) | | - | _ | - | - | 6 | | mov Rm,(d8,Rn) | d8 is sign-extended. | _ | _ | _ | - | 4 | | mov Rm,(d24,Rn) | d24 is sign-extended. | - | _ | - | - | 6 | | mov Rm,(d32,Rn) | | _ | _ | _ | - | 7 | | mov Dm,(Di,An) | | _ | _ | _ | - | 2 | | mov Am,(Di,An) | | _ | _ | _ | _ | 2 | | mov Rm,(Ri,Rn) | | _ | _ | _ | - | 4 | | mov Dm,(abs16) | abs16 is zero-extended. | _ | _ | _ | - | 3 | | mov Dm,(abs32) | | _ | _ | _ | _ | 6 | | mov Am,(abs16) | abs16 is zero-extended. | _ | _ | _ | - | 4 | | mov Am,(abs32) | | _ | _ | _ | _ | 6 | | mov Rm,(abs8) | abs8 is zero-extended. | _ | _ | _ | _ | 4 | | mov Rm,(abs24) | abs24 is zero-extended. | _ | _ | _ | _ | 6 | | mov Rm,(abs32) | | _ | _ | _ | _ | 7 | | mov Dm,(d8,SP) | d8 is zero-extended. | _ | _ | _ | _ | 2 | | mov Dm,(d16,SP) | d16 is zero-extended. | _ | _ | _ | _ | 4 | | mov Dm,(d32,SP) | | | _ | _ | _ | 6 | | mov Am,(d8,SP) | d8 is zero-extended. | _ | _ | _ | _ | 2 | | mov Am,(d16,SP) | d16 is zero-extended. | _ | _ | _ | _ | 4 | | | | | | | | | | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|-----------------------|---|---|---|---|------| | mov Am,(d32,SP) | | _ | _ | _ | _ | 6 | | mov Rm,(SP) | | _ | _ | _ | _ | 3 | | mov Rm,(d8,SP) | d8 is zero-extended. | _ | _ | _ | _ | 4 | | mov Rm,(d24,SP) | d24 is zero-extended. | _ | _ | _ | _ | 6 | | mov Rm,(d32,SP) | | _ | _ | _ | _ | 7 | | mov SP,(d8,An) | d8 is sign-extended. | _ | _ | _ | _ | 3 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 4, a system exception (address misalignment exception) occurs. ### MOV (Rm+,imm), Rn Operation mem32(Rm) -> Rn Rm + imm -> Rm This instruction loads the data specified by Rm from Mem, and stores them in Rn. Moreover, it adds Rm to imm, and stores the result in Rm. | Assembler mnemonic | Note | V | С | Ζ | Ζ | Size | |----------------------|-------------------------|---|---|---|---|------| | mov (Rm+, imm8), Rn | imm8 is sign-extended. | _ | _ | _ | - | 4 | | mov (Rm+, imm24), Rn | imm24 is sign-extended. | _ | _ | _ | 1 | 6 | | mov (Rm+, imm32), Rn | | _ | _ | _ | 1 | 7 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 4, a system exception (address misalignment exception) occurs. When Rm=Rn is specified, the operations are not guaranteed. ### MOV (Rm+), Rn Operation $mem32(Rm) \rightarrow Rn$ $Rm + 4 \rightarrow Rm$ This instruction loads the data specified by Rm from Mem, and stores them in Rn. Moreover, it adds Rm to 4, and stores the result in Rm. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mov (Rm+), Rn | | - | _ | _ | - | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 4, a system exception (address misalignment exception) occurs. When Rm=Rn is specified, the operations are not guaranteed. ### MOV Rm, (Rn+,imm) Operation $Rm \rightarrow mem32(Rn)$ Rn + imm -> Rn This instruction stores the contents of Rm in the memory specified by Rn. Moreover, it adds Rn to imm, and stores the result in Rn. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |----------------------|-------------------------|---|---|---|---|------| | mov Rm, (Rn+, imm8) | imm8 is sign-extended. | _ | _ | _ | _ | 4 | | mov Rm, (Rn+, imm24) | imm24 is sign-extended. | _ | - | _ | Ī | 6 | | mov Rm, (Rn+, imm32) | | - | _ | _ | _ | 7 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 4, a system exception (address misalignment exception) occurs. ### MOV Rm, (Rn+) Operation $Rm \rightarrow mem32(Rn)$ $Rn + 4 \rightarrow Rn$ This instruction stores the contents of Rn in the memory specified by Rn. Moreover, it adds Rn to 4, and stores the result in Rn. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | mov Rm, (Rn+) | | _ | _ | _ | - | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 4, a system exception (address misalignment exception) occurs. ### Unsigned word transfer ### MOVU imm, Reg Operation imm -> Reg This instruction transfers imm to Reg. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | movu imm8, Rn | imm8 is zero-extended. | _ | _ | _ | _ | 4 | | movu imm24, Rn | imm24 is zero-extended. | _ | - | _ | - | 6 | | movu imm32, Rn | | _ | _ | _ | _ | 7 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. # MOVHU Unsigned half-word transfer ### MOVHU Mem, Reg Operation ``` MOVHU (Reg1), Reg2 mem16(Reg1) -> Reg2[15:0] 0x0000 \rightarrow Reg2[31:16] MOVHU (disp, Reg1), Reg2 mem16(Reg1+disp) -> Reg2[15:0] 0x0000 \rightarrow Reg2[31:16] MOVHU (Reg1, Reg2), Reg3 mem16(Reg1+Reg2) -> Reg3[15:0] 0x0000 -> Reg3[31:16] MOVHU (abs), Reg1 mem16(abs) -> Reg1[15:0] 0x0000 \rightarrow Reg1[31:16] MOVHU (disp, SP), Reg1 mem16(SP+disp) -> Reg1[15:0] 0x0000 -> Reg1[31:16] This instruction performs the half-word transfer of the content of Mem to Reg. (16 bits -> 32 bits: Zero-extension) ``` | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | movhu (Am),Dn | | - | - | _ | _ | 2 | | movhu (Rm),Rn | | - | _ | _ | _ | 3 | | movhu (d8,Am),Dn | d8 is sign-extended. | - | _ | - | _ | 3 | | movhu (d16,Am),Dn | d16 is sign-extended. | - | _ | _ | _ | 4 | | movhu (d32,Am),Dn | | - | - | - | _ | 6 | | movhu (d8,Rm),Rn | d8 is sign-extended. | - | _ | _ | _ | 4 | | movhu (d24,Rm),Rn | d24 is sign-extended. | _ | _ | _ | _ | 6 | | movhu (d32,Rm),Rn | | - | _ | _ | _ | 7 | | movhu (Di,Am),Dn | | - | _ | _ | _ | 2 | | movhu (Ri,Rm),Rn | | - | _ | _ | _ | 4 | | movhu (abs16),Dn | abs16 is zero-extended. | - | _ | _ | _ | 3 | | movhu (abs32),Dn | | - | _ | _ | _ | 6 | | movhu (abs8),Rn | abs8 is zero-extended. | - | _ | _ | _ | 4 | | movhu (abs24),Rn | abs24 is zero-extended. | - | _ | _ | _ | 6 | | movhu (abs32),Rn | | - | _ | _ | - | 7 | | movhu (d8,SP),Dn | d8 is zero-extended. | _ | _ | _ | _ | 3 | | movhu (d16,SP),Dn | d16 is zero-extended. | - | _ | _ | _ | 4 | | movhu (d32,SP),Dn | | - | _ | _ | _ | 6 | | movhu (SP),Rn | | - | _ | _ | _ | 3 | | movhu (d8,SP),Rn | d8 is zero-extended. | _ | _ | _ | _ | 4 | | movhu (d24,SP),Rn | d24 is zero-extended. | _ | _ | _ | _ | 6 | | movhu (d32,SP),Rn | | _ | _ | _ | _ | 7 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. # MOVHU Reg, Mem #### Operation MOVHU Reg1 (Reg2) Reg1[15:0] ->mem16(Reg2) MOVHU Reg1, (disp, Reg2) Reg1[15:0] -> mem16(Reg2+disp) MOVHU Reg1, (Reg2, Reg3) Reg1[15:0] -> mem16(Reg2+Reg3) MOVHU Reg1, (abs) Reg1[15:0] -> mem16(abs) MOVHU Reg1, (disp, SP) Reg1[15:0] -> mem16(SP+disp) This instruction performs the half-word transfer of the content of Reg to Mem. The upper 16 bits of Reg are ignored. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | movhu Dm,(An) | | _ | - | _ | _ | 2 | | movhu Rm,(Rn) | | _ | - | _ | _ | 3 | | movhu Dm,(d8,An) | d8 is sign-extended. | _ | _ | - | _ | 3 | | movhu Dm,(d16,An) | d16 is sign-extended. | _ | _ | _ | _ | 4 | | movhu Dm,(d32,An) | | - | _ | - | _ | 6 | | movhu Rm,(d8,Rn) | d8 is sign-extended. | _ | _ | _ | _ | 4 | | movhu Rm,(d24,Rn) | d24 is sign-extended. | _ | _ | _ | _ | 6 | | movhu Rm,(d32,Rn) | | _ | _ | - | _ | 7 | | movhu Dm,(Di,An) | | _ | _ | _ | _ | 2 | | movhu Rm,(Ri,Rn) | | _ | _ | - | _ | 4 | | movhu Dm,(abs16) | abs16 is zero-extended. | _ | - | _ | _ | 3 | | movhu Dm,(abs32) | | _ | _ | _ | _ | 6 | | movhu Rm,(abs8) | abs8 is zero-extended. | _ | _ | - | _ | 4 | | movhu Rm,(abs24) | abs24 is zero-extended. | _ | _ | _ | _ | 6 | | movhu Rm,(abs32) | | - | _ | _ | _ | 7 | | movhu Dm,(d8,SP) | d8 is zero-extended. | _ | _ | _ | _ | 3 | | movhu Dm,(d16,SP) | d16 is zero-extended. | _ | _ | _ | _ | 4 | | movhu Dm,(d32,SP) | | _ | _ | _ | _ | 6 | | movhu Rm,(SP) | | _ | _ | _ | _ | 3 | | movhu Rm,(d8,SP) | d8 is zero-extended. | _ | _ | _ | _ | 4 | | movhu Rm,(d24,SP) | d24 is zero-extended. | _ | _ | _ | _ | 6 | | movhu Rm,(d32,SP) | | _ | _ | _ | _ | 7 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. # MOVHU (Rm+, imm), Rn Operation mem16(Rm) -> Rn[15:0] $0x0000 \rightarrow Rn[31:16]$ Rm + imm -> Rm This instruction loads the 16-bit data from Mem specified by Rm, and transfers them in Moreover, it adds Rm to imm, and stores the result in Rm. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |------------------------|-------------------------|---|---|---|---|------| | movhu (Rm+, imm8), Rn | imm8 is sign-extended. | _ | _ | _ | _ | 4 | | movhu (Rm+, imm24), Rn | imm24 is sign-extended. | _ | _ | - | 1 | 6 | | movhu (Rm+, imm32), Rn | | _ | _ | _ | 1 | 7 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 2, a system exception (address misalignment exception) occurs. ### MOVHU (Rm+), Rn Operation mem16(Rm) -> Rn[15:0] $0x0000 \rightarrow Rn[31:16]$ $Rm + 2 \rightarrow Rm$ This instruction loads the data specified by Rm from Mem, and stores them in Rn. Moreover, it adds Rm to 4, and stores the result in Rm. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | movhu (Rm+), Rn | | _ | - | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MOVHU Rm, (Rn+, imm) Operation Rm[15:0] -> mem16(Rn) $Rn + imm \rightarrow Rn$ This instruction stores the lower 16 bits of the Rm in the Mem specified by Rn. Moreover, it adds Rn to imm, and stores the result in Rn. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |----------------------|-------------------------|---|---|---|---|------| | movhu Rm(Rn+, imm8) | imm8 is sign-extended. | _ | _ | _ | _ | 4 | | movhu Rm(Rn+, imm24) | imm24 is sign-extended. | _ | - | _ | _ | 6 | | movhu Rm(Rn+, imm32) | | _ | - | _ | _ | 7 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the Mem address is not a multiple of 2, a system exception (address misalignment exception) occurs. # MOVHU (Rm+), Rn Operation Rm[15:0] -> mem16(Rm) $Rn + 2 \rightarrow Rn$ This instruction stores the lower 16 bits of Rn in the Mem specified by Rn. Moreover, it adds Rm to 2, and stores the result in Rn. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | movhu Rm, (Rn+) | | _ | _ | _ | - | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. # MOVBU Unsigned byte transfer ### MOVBU Mem, Reg Operation MOVBU (Reg1), Reg2 $mem8(Reg1) \rightarrow Reg2[7:0]$ $0x0000000 \rightarrow Reg2[31:8]$ MOVBU (disp, Reg1), Reg2 mem8(Reg1+disp) -> Reg2[7:0] $0x0000000 \rightarrow Reg2[31:8]$ MOVBU (Reg1, Reg2), Reg3 $mem8(Reg1+Reg2) \rightarrow Reg3[7:0]$ $0x0000000 \rightarrow Reg3[31:8]$ MOVBU (abs), Reg1 mem8(abs) -> Reg1[7:0] $0x0000000 \rightarrow Reg1[31:8]$ MOVBU (disp, SP), Reg1 $mem8(SP+disp) \rightarrow Reg1[7:0]$ $0x0000000 \rightarrow Reg1[31:8]$ This instruction performs the byte-data transfer of the content of Mem to Reg. (8 bits -> 32 bits: Zero-extension) | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | movbu (Am),Dn | | _ | _ | _ | _ | 2 | | movbu (Rm),Rn | | _ | _ | _ | - | 3 | | movbu (d8,Am),Dn | d8 is sign-extended. | _ | _ | _ | _ | 3 | | movbu (d16,Am),Dn | d16 is sign-extended. | _ | - | ı | ı | 4 | | movbu (d32,Am),Dn | | _ | - | _ | _ | 6 | | movbu (d8,Rm),Rn | d8 is sign-extended. | _ | _ | _ | _ | 4 | | movbu (d24,Rm),Rn | d24 is sign-extended. | _ | _ | _ | - | 6 | | movbu (d32,Rm),Rn | | - | _ | _ | - | 7 | | movbu (Di,Am),Dn | | - | _ | _ | Ī | 2 | | movbu (Ri,Rm),Rn | | - | _ | _ | _ | 4 | | movbu (abs16),Dn | abs16 is zero-extended. | _ | _ | _ | _ | 3 | | movbu (abs32),Dn | | - | _ | - | Ī | 6 | | movbu (abs8),Rn | abs8 is zero-extended. | _ | _ | - | ı | 4 | | movbu (abs24),Rn | abs24 is zero-extended. | - | - | _ | Ţ | 6 | | movbu (abs32),Rn | | _ | _ | _ | - | 7 | | movbu (d8,SP),Dn | d8 is zero-extended. | _ | _ | _ | _ | 3 | | movbu (d16,SP),Dn | d16 is zero-extended. | _ | _ | _ | - | 4 | | movbu (d32,SP),Dn | | _ | _ | _ | - | 6 | | movbu (SP),Rn | | _ | _ | _ | - | 3 | | movbu (d8,SP),Rn | d8 is zero-extended. | _ | _ | _ | - | 4 | | movbu (d24,SP),Rn | d24 is zero-extended. | _ | _ | _ | _ | 6 | | movbu (d32,SP),Rn | | _ | _ | _ | _ | 7 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ## MOVBU Reg, Mem Operation MOVBU Reg1 (Reg2) Reg1[7:0] ->mem8(Reg2) MOVBU Reg1, (disp, Reg2) $Reg1[7:0] \rightarrow mem8(Reg2+disp)$ MOVBU Reg1, (Reg2, Reg3) $Reg1[7:0] \rightarrow mem8(Reg2+Reg3)$ MOVBU Reg1, (abs) Reg1[7:0] -> mem8(abs) MOVBU Reg1, (disp, SP) Reg1[7:0] -> mem8(SP+disp) This instruction performs the byte-data transfer of the content of Reg to Mem. (32 bits -> 8 bits): The upper bits are rounded down.) | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|-------------------------|---|---|---|---|------| | movbu Dm,(An) | | - | _ | _ | _ | 2 | | movbu Rm,(Rn) | | _ | - | _ | _ | 3 | | movbu Dm,(d8,An) | d8 is sign-extended. | - | _ | _ | _ | 3 | | movbu Dm,(d16,An) | d16 is sign-extended. | _ | _ | _ | - | 4 | | movbu Dm,(d32,An) | | _ | _ | _ | _ | 6 | | movbu Rm,(d8,Rn) | d8 is sign-extended. | _ | _ | - | 1 | 4 | | movbu Rm,(d24,Rn) | d24 is sign-extended. | _ | _ | _ | 1 | 6 | | movbu Rm,(d32,Rn) | | _ | _ | _ | 1 | 7 | | movbu Dm,(Di,An) | | - | _ | _ | _ | 2 | | movbu Rm,(Ri,Rn) | | - | _ | _ | _ | 4 | | movbu Dm,(abs16) | abs16 is zero-extended. | _ | _ | _ | _ | 3 | | movbu Dm,(abs32) | | _ | _ | _ | _ | 6 | | movbu Rm,(abs8) | abs8 is zero-extended. | _ | _ | _ | - | 4 | | movbu Rm,(abs24) | abs24 is zero-extended. | - | - | - | _ | 6 | | movbu Rm,(abs32) | | _ | _ | _ | _ | 7 | | movbu Dm,(d8,SP) | d8 is zero-extended. | _ | _ | _ | 1 | 3 | | movbu Dm,(d16,SP) | d16 is zero-extended. | - | _ | _ | _ | 4 | | movbu Dm,(d32,SP) | | _ | _ | _ | _ | 6 | | movbu Rm,(SP) | | _ | _ | _ | - | 3 | | movbu Rm,(d8,SP) | d8 is zero-extended. | _ | _ | _ | - | 4 | | movbu Rm,(d24,SP) | d24 is zero-extended. | _ | | _ | _ | 6 | | movbu Rm,(d32,SP) | | _ | _ | _ | _ | 7 | Flag change ### MOVM (SP), regs (SP relative) #### Operation When all registers are specified, regs=[ALL] mem32(SP+92) -> E2, mem32(SP+88) -> E3, mem32(SP+84) -> E4 mem32(SP+80) -> E5, mem32(SP+76) -> E6, mem32(SP+72) -> E7 mem32(SP+68) -> E0, mem32(SP+64) -> E1, mem32(SP+60) -> MDRQ mem32(SP+56) -> MCRH, mem32(SP+52) -> MCRL, mem32(SP+48) -> MCVF mem32(SP+44) -> D2, mem32(SP+40) -> D3, mem32(SP+36) -> A2 mem32(SP+32) -> A3, mem32(SP+28) -> D0, mem32(SP+24) -> D1 mem32(SP+20) -> A0, mem32(SP+16) -> A1, mem32(SP+12) -> MDR mem32(SP+8) -> LIR, mem32(SP+4) -> LAR, SP+96 -> SP This instruction restores the multiple registers saved in the memory indicated by SP. The multiple registers to transfer data are specified by regs, and D2, D3, A2, A3 and other reisters are specified as followings. OTHER: D0,D1,A0,A1,MDR,LIR,LAR EXREG0: E2,E3 EXREG1: E4,E5,E6,E7 EXOTHER: E0,E1,MDRQ,MCRH,MCRL,MCVF When all of the above-mentioned registers are specified, ALL is used. ALL: D2,D3,A2,A3,OTHER,EXREG0,EXREG1,EXOTHER | Assembler mnemonic | Note | V | С | N | Z | Size | |--------------------------------|------|---|---|---|---|------| | movm (SP), [reg1, reg2,,,regn] | | _ | _ | _ | - | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction can be executed at any level, and refers to SP at the present. That is, it refers to USP when the present level is the user level, SSP when it is the supervisor one, and MSP when it is the monitor one Bit allocation of the multiple registers (regs) is shown below. When you specify all of these, use ALL. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|-------|--------|--------|----------------| | D2 | D3 | A2 | A3 | OTHER | EXREG0 | EXREG1 | <b>EXOTHER</b> | Data is transferred from the higher addresses in the order of E2, E3, E4, E5, E6, E7, E0, E1,MDRQ, MCRH, MCRL, MCVF, D2, D3, A2, A3, D0, D1, A0, A1, MDR, LIR and LAR. Note that when "OTHER" is specified, a dummy area (4 bytes) is allocated (transfer operation is not actually performed) at the end in order to simplify calculation of the transfer area (4 bytes x 8). When "OTHER" is not specified, this dummy area is not allocated. When reg=0 is specified (when "movm (SP),[]" is executed), nothing is transferred. When the Mem address indicated by the stack pointer (SP) is not a multiple of 4, system exception (Address misalignment exception) occurs. The memory status when all registers are specified is shown below. | | Low address | Restore Order | Offset from SP | |------------------------|--------------|---------------|----------------| | SP before execution -> | Dummy area | (-) | 0 | | | LAR | (23) | +4 | | | LIR | (22) | +8 | | | MDR | (21) | +12 | | | A1 | (20) | +16 | | | A0 | (19) | +20 | | | D1 | (18) | +24 | | | D0 | (17) | +28 | | | A3 | (16) | +32 | | | A2 | (15) | +36 | | | D3 | (14) | +40 | | | D2 | (13) | +44 | | | MCVF | (12) | +48 | | | MCRL | (11) | +52 | | | MCRH | (19) | +56 | | | MDRQ | (9) | +60 | | | E1 | (8) | +64 | | | E0 | (7) | +68 | | | E7 | (6) | +72 | | | E6 | (5) | +76 | | | E5 | (4) | +80 | | | E4 | (3) | +84 | | | E3 | (2) | +88 | | | E2 | (1) | +92 | | SP after execution -> | | | +96 | | | High address | | | # MOVM regs, (SP) (SP relative) #### Operation When all registers are specified, regs=[ALL] E2 -> mem32(SP-4), E3 -> mem32(SP-8), E4 -> mem32(SP-12), E5 -> mem32(SP-16), E6 -> mem32(SP-20), E7 -> mem32(SP-24), $E0 \rightarrow mem32(SP-28), E1 \rightarrow mem32(SP-32), MDRQ \rightarrow mem32(SP-36),$ MCRH -> mem32(SP-40), MCRL-> mem32(SP-44), MCVF -> mem32(SP-48), $D2 \rightarrow mem32(SP-52)$ , $D3 \rightarrow mem32(SP-56)$ , $A2 \rightarrow mem32(SP-60)$ , A3 -> mem32(SP-64),D0 -> mem32(SP-68),D1 -> mem32(SP-72), $A0 \rightarrow mem32(SP-76), A1 \rightarrow mem32(SP-80), MDR \rightarrow mem32(SP-84),$ LIR-> mem32(SP-88),LAR -> mem32(SP-92), SP-96 -> SP This instruction restores the multiple registers saved in the memory indicated by SP. The multiple registers to transfer data are specified by regs, and D2, D3, A2, A3 and other reisters are specified as followings. OTHER: D0,D1,A0,A1,MDR,LIR,LAR EXREG0 : E2,E3 EXREG1 : E4,E5,E6,E7 EAREGT . E4,E5,E0,E7 $EXOTHER: E0,\!E1,\!MDRQ,\!MCRH,\!MCRL,\!MCVF$ When all of the above-mentioned registers are specified, ALL is used. ALL: D2, D3, A2, A3, OTHER, EXREG0, EXREG1, EXOTHER | Assembler mnemonic | Note | V | С | N | Z | Size | |--------------------------------|------|---|---|---|---|------| | movm [reg1, reg2,,,regn], (SP) | | _ | _ | _ | _ | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction can be executed at any level, and refers to SP at the present. That is, it refers to USP when the present level is the user level, SSP when it is the supervisor one, and MSP when it is the monitor one Bit allocation of the multiple registers (regs) is shown below. When you specify all of these, use ALL. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|-------|--------|--------|----------------| | D2 | D3 | A2 | A3 | OTHER | EXREG0 | EXREG1 | <b>EXOTHER</b> | Data is transferred from the higher addresses in the order of E2, E3, E4, E5, E6, E7, E0, E1,MDRQ, MCRH, MCRL, MCVF, D2, D3, A2, A3, D0, D1, A0, A1, MDR, LIR and LAR. Note that when "OTHER" is specified, a dummy area (4 bytes) is allocated (transfer operation is not actually performed) at the end in order to simplify calculation of the transfer area (4 bytes x 8). When "OTHER" is not specified, this dummy area is not allocated. When reg=0 is specified (when "movm,[], (SP)" is executed), nothing is transferred. When the Mem address indicated by the stack pointer (SP) is not a multiple of 4, system exception (Address misalignment exception) occurs. The memory status when all registers are specified is shown below. | | Low address | Restore Order | Offset from SP | |------------------------|--------------|---------------|----------------| | SP after execution -> | Dummy area | (-) | -96 | | | LAR | (23) | -94 | | | LIR | (22) | -88 | | | MDR | (21) | -84 | | | A1 | (20) | -80 | | | A0 | (19) | -76 | | | D1 | (18) | -72 | | | D0 | (17) | -68 | | | A3 | (16) | -64 | | | A2 | (15) | -60 | | | D3 | (14) | -56 | | | D2 | (13) | -52 | | | MCVF | (12) | -48 | | | MCRL | (11) | -44 | | | MCRH | (19) | -40 | | | MDRQ | (9) | -36 | | | E1 | (8) | -32 | | | E0 | (7) | -28 | | | E7 | (6) | -24 | | | E6 | (5) | -20 | | | E5 | (4) | -16 | | | E4 | (3) | -12 | | | E3 | (2) | -8 | | | E2 | (1) | -4 | | SP before execution -> | | | -0 | | | High address | | | ### MOVM (USP), regs (USP relative<Privileged instruction>) #### Operation When all registers are specified, regs=[ALL] mem32(USP+92) -> E2, mem32(USP+88) -> E3, mem32(USP+84) -> E4 mem32(USP+80) -> E5, mem32(USP+76) -> E6, mem32(USP+72) -> E7 mem32(USP+68) -> E0, mem32(USP+64) -> E1, mem32(USP+60) -> MDRQ mem32(USP+56) -> MCRH, mem32(USP+52) -> MCRL, mem32(USP+48) -> MCVF mem32(USP+44) -> D2, mem32(USP+40) -> D3, mem32(USP+36) -> A2 mem32(USP+32) -> A3, mem32(USP+28) -> D0, mem32(USP+24) -> D1 mem32(USP+20) -> A0, mem32(USP+16) -> A1, mem32(USP+12) -> MDR mem32(USP+8) -> LIR, mem32(USP+4) -> LAR, USP+96 -> USP This instruction restores the multiple registers saved in the memory indicated by USP. The multiple registers to transfer data are specified by regs, and D2, D3, A2, A3 and other reisters are specified as followings. OTHER: D0,D1,A0,A1,MDR,LIR,LAR EXREG0: E2,E3 EXREG1: E4,E5,E6,E7 EXOTHER: E0,E1,MDRQ,MCRH,MCRL,MCVF When all of the above-mentioned registers are specified, ALL is used. ALL: D2,D3,A2,A3,OTHER,EXREG0,EXREG1,EXOTHER | Assembler mnemonic | Note | V | С | N | Z | Size | |--------------------------------|------|---|---|---|---|------| | movm (USP),[reg1, reg2,,,regn] | | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction can be executed at the monitor and supervisor levels, and refers to USP in any level. When an instruction is to be carried out in the user level, a system exception (priviledged instruction execution exception) occurs. Bit allocation of the multiple registers (regs) is shown below. When you specify all of these, use ALL. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|-------|--------|--------|----------------| | D2 | D3 | A2 | A3 | OTHER | EXREG0 | EXREG1 | <b>EXOTHER</b> | Data is transferred from the higher addresses in the order of E2, E3, E4, E5, E6, E7, E0, E1,MDRQ, MCRH, MCRL, MCVF, D2, D3, A2, A3, D0, D1, A0, A1, MDR, LIR and LAR. Note that when "OTHER" is specified, a dummy area (4 bytes) is allocated (transfer operation is not actually performed) at the end in order to simplify calculation of the transfer area (4 bytes x 8). When "OTHER" is not specified, this dummy area is not allocated. When reg=0 is specified (when "movm (USP),[]" is executed), nothing is transferred. When the Mem address indicated by the stack pointer (USP) is not a multiple of 4, system exception (Address misalignment exception) occurs. Although MOVM using a stack pointer (SP) is a 2-byte instruction, this instruction is a 3-byte one. The memory status when all registers are specified is shown below. | | Low address | Restore Order | Offset from USP | |-------------------------|--------------|---------------|-----------------| | USP before execution -> | Dummy area | (-) | 0 | | | LAR | (23) | +4 | | | LIR | (22) | +8 | | | MDR | (21) | +12 | | | A1 | (20) | +16 | | | A0 | (19) | +20 | | | D1 | (18) | +24 | | | D0 | (17) | +28 | | | A3 | (16) | +32 | | | A2 | (15) | +36 | | | D3 | (14) | +40 | | | D2 | (13) | +44 | | | MCVF | (12) | +48 | | | MCRL | (11) | +52 | | | MCRH | (19) | +56 | | | MDRQ | (9) | +60 | | | E1 | (8) | +64 | | | E0 | (7) | +68 | | | E7 | (6) | +72 | | | E6 | (5) | +76 | | | E5 | (4) | +80 | | | E4 | (3) | +84 | | | E3 | (2) | +88 | | | E2 | (1) | +92 | | USP after execution -> | | | +96 | | | High address | | | ### MOVM regs,(USP)(USP relative<Privileged instruction>) #### Operation When all registers are specified, regs=[ALL] E2 -> mem32(USP-4), E3 -> mem32(USP-8), E4 -> mem32(USP-12), E5 -> mem32(USP-16), E6 -> mem32(USP-20), E7 -> mem32(USP-24), E0 -> mem32(USP-28), E1-> mem32(USP-32), MDRQ -> mem32(USP-36), MCRH -> mem32(USP-40), MCRL-> mem32(USP-44), MCVF -> mem32(USP-48), $D2 \rightarrow mem32(USP-52)$ , $D3 \rightarrow mem32(USP-56)$ , $A2 \rightarrow mem32(USP-60)$ , A3 -> mem32(USP-64),D0 -> mem32(USP-68), D1 -> mem32(USP-72), A0 -> mem32(USP-76),A1 -> mem32(USP-80),MDR -> mem32(USP-84), LIR-> mem32(USP-88),LAR -> mem32(USP-92), USP-96 -> USP This instruction saves the multiple registers in the memory indicated by USP. The multiple registers to transfer data are specified by regs, and D2, D3, A2, A3 and other reisters are specified as followings. OTHER: D0,D1,A0,A1,MDR,LIR,LAR EXREG0 : E2,E3 EXREG1 : E4,E5,E6,E7 EXOTHER: E0,E1,MDRQ,MCRH,MCRL,MCVF When all of the above-mentioned registers are specified, ALL is used. ALL: D2,D3,A2,A3,OTHER,EXREG0,EXREG1,EXOTHER | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |---------------------------------|------|---|---|---|---|------| | movm [reg1, reg2,,,regn], (USP) | | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. This instruction can be executed at the monitor and supervisor levels, and refers to USP in any level. When an instruction is to be carried out in the user level, a system exception (priviledged instruction execution exception) occurs. Bit allocation of the multiple registers (regs) is shown below. When you specify all of these, use ALL. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|-------|--------|--------|---------| | D2 | D3 | A2 | A3 | OTHER | EXREG0 | EXREG1 | EXOTHER | Data is transferred from the higher addresses in the order of E2, E3, E4, E5, E6, E7, E0, E1,MDRQ, MCRH, MCRL, MCVF, D2, D3, A2, A3, D0, D1, A0, A1, MDR, LIR and LAR. Note that when "OTHER" is specified, a dummy area (4 bytes) is allocated (transfer operation is not actually performed) at the end in order to simplify calculation of the transfer area (4 bytes x 8). When "OTHER" is not specified, this dummy area is not allocated. When reg=0 is specified (when "movm [], (USP)" is executed), nothing is transferred. When the Mem address indicated by the stack pointer (USP) is not a multiple of 4, system exception (Address misalignment exception) occurs. Although MOVM using a stack pointer (SP) is a 2-byte instruction, this instruction is a 3-byte one. The memory status when all registers are specified is shown below. | | Low address | Restore Order | Offset from USP | |------------------------|--------------|---------------|-----------------| | SP after execution -> | Dummy area | (-) | -96 | | | LAR | (23) | -94 | | | LIR | (22) | -88 | | | MDR | (21) | -84 | | | A1 | (20) | -80 | | | A0 | (19) | -76 | | | D1 | (18) | -72 | | | D0 | (17) | -68 | | | A3 | (16) | -64 | | | A2 | (15) | -60 | | | D3 | (14) | -56 | | | D2 | (13) | -52 | | | MCVF | (12) | -48 | | | MCRL | (11) | -44 | | | MCRH | (19) | -40 | | | MDRQ | (9) | -36 | | | E1 | (8) | -32 | | | E0 | (7) | -28 | | | E7 | (6) | -24 | | | E6 | (5) | -20 | | | E5 | (4) | -16 | | | E4 | (3) | -12 | | | E3 | (2) | -8 | | | E2 | (1) | -4 | | SP before execution -> | | | -0 | | | High address | | | ### **EXT Reg** Operation When Reg[31]=0, 0x000000000 -> MDRWhen Reg[31]=1, 0xFFFFFFFF -> MDR This instruction sign-extends Reg to 64 bits, and transfers the upper 32 bits to MDR. The contents of Reg are not changed. | Assembler mnemonic | Note | ٧ | С | Z | Z | Size | |--------------------|------|---|---|---|---|------| | ext Dn | | _ | _ | _ | _ | 2 | | ext Rn | | _ | _ | _ | _ | 3 | #### Flag change ### 32-bit sign-extension of half-word data ### **EXTH Reg** Operation When Reg[15]=0, Regt & $0x0000FFFF \rightarrow Reg$ When Reg[15]=1, Reg | $0xFFFF0000 \rightarrow Reg$ This instruction sign-extends the lower 16 bits of Reg to 32 bits, and stores them in Reg. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | exth Dn | | _ | _ | _ | - | 1 | | exth Rn | | _ | _ | _ | _ | 3 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the instruction has an operand register consisting of other than data register (Dn) for 1 operand operation, it is implemented by instruction swapping and the assembler constitutes the following instruction. exth Rn, Rn ### EXTH Reg1, Reg2 Operation When Reg1[15]=0, Reg1 & 0x0000FFFF -> Reg2 When Reg1[15]=1, Reg1 | 0xFFFF0000 -> Reg2 This instruction sign-extends the lower 16 bits of Reg1 to 32 bits, and stores them into Reg2. The contents of Reg1 are not changed. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | exth Rm, Rn | | - | _ | _ | _ | - | #### Flag change ### **EXTHU Reg** Operation When Reg[15]=0, Reg & 0x0000FFFF -> Reg When Reg[15]=1, $Reg \mid 0xFFFF0000 \rightarrow Reg$ This instruction sign-extends the lower 16 bits of Reg to 32 bits, and stores them in Reg. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | exthu Dn | | _ | _ | _ | _ | 1 | | exthu Rn | | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the instruction has an operand register consisting of other than data register (Dn) for 1 operand operation, it is implemented by instruction swapping and the assembler constitutes the following instruction. exthu Rn, Rn ### EXTHU Reg1, Reg2 Operation When Reg1[15]=0, Reg1 & 0x0000FFFF -> Reg2 When Reg1[15]=1, $Reg1 \mid 0xFFFF0000 \rightarrow Reg2$ This instruction zero-extends the lower 16 bits of Reg1 to 32 bits, and stores them into Reg2. The contents of Reg1 are not changed. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | exthu Rm, Rn | | _ | _ | _ | _ | - | #### Flag change #### 32-bit sign-extension of byte data ### EXTB Reg Operation When Rn[7]=0, Reg & $0x000000FF \rightarrow Reg$ When Rn[7]=1, Reg | $0xFFFFFFF00 \rightarrow Reg$ This instruction sign-extends the lower 8 bits of Reg to 32 bits, and stores them in Reg. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | extb Dn | | _ | _ | _ | 1 | 1 | | extb Rn | | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the instruction has an operand register consisting of other than data register (Dn) for 1 operand operation, it is implemented by instruction swapping and the assembler constitutes the following instruction. extb Rn, Rn ### EXTB Reg1, Reg2 Operation When Reg1[7]=0, Reg1 & 0x000000FF -> Reg2 When Reg1[7]=1, Reg1 | 0xFFFFFF00 -> Reg2 This instruction zero-extends the lower 8 bits of Reg1 to 32 bits, and stores them into Reg2. The contents of Reg1 are not changed. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | extb Rm, Rn | | _ | _ | ١ | _ | - | #### Flag change #### **EXTBU** Reg Operation Reg & 0x000000FF -> Rn This instruction zero-extends the lower 8 bits of Reg to 32 bits, and stores them in Reg. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | extbu Dn | | _ | _ | _ | _ | 1 | | extbu Rn | | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the instruction has an operand register consisting of other than data register (D) for 1 operand operation, it is implemented by instruction swapping and the assembler constitutes the following instruction. extbu Rn, Rn ### EXTBU Reg1, Reg2 Operation Reg1 & 0x000000FF -> Reg2 This instruction zero-extends the lower 8 bits of Reg1 to 32 bits, and stores them into Reg2. The contents of Reg1 are not changed. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | extbu Rm, Rn | | _ | _ | _ | - | - | #### Flag change ZF: Always1. ### Data clear | EXT | BU Reg | | | | | | | | | |-----------|-------------------------------------|-------------------------------|-------|---|---|------|--|--|--| | Operation | Operation Reg & 0x000000FF -> Rn | | | | | | | | | | | This instruction | n clears the contents of Reg. | | | | | | | | | Assem | bler mnemonic | Note | / C | N | Z | Size | | | | | clr Dn | | - | - - | - | 1 | 1 | | | | | clr Rn | | - | - - | _ | 1 | 3 | | | | | | | Flag change | | | | | | | | | CF: | Always 0.<br>Always 0.<br>Always 0. | | | | | | | | | ### Data cache pre-fetch ### DCPF Mem Operation DCPF (Reg) mem\_cline(Reg) -> [Data Cache] DCPF (Ri, Rm) mem\_cline(Ri + Rm) -> [Data Cache] DCPF (disp, Reg) mem\_cline(Reg + disp) -> [Data Cache] DCPF (SP) mem\_cline(SP) -> [Data Cache] | Ass | embler mnemonic | Note | V | С | Ν | Z | Size | |---------|-----------------|-----------------------|---|---|---|---|------| | dcpf (F | Rm) | | ı | _ | ı | | 3 | | dcpf (F | Ri, Rm) | | ١ | _ | ١ | - | 4 | | dcpf (d | 18, Rm) | d8 is sign-extended. | _ | _ | _ | _ | 4 | | dcpf (d | l24, Rm) | d24 is sign-extended. | ı | _ | ı | - | 6 | | dcpf (d | l32, Rm) | | _ | _ | - | 1 | 7 | | dcpf ( | SP) | | _ | - | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. The contents of the register are not updated through executing DCPF instruction. DCPF instruction do not cause illegal memory access exception, address alignment exception and MMU exception. Addition ### ADD Reg1, Reg2 #### Operation Reg1 + Reg2 -> Reg2 This instruction adds the contents of Reg1 and Reg2 to each other, and stores the result in Reg2. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | add Dm, Dn | | Δ | Δ | Δ | Δ | 1 | | add Dm, An | | Δ | Δ | Δ | Δ | 2 | | add Am, Dn | | Δ | Δ | Δ | Δ | 2 | | add Am, An | | Δ | Δ | Δ | Δ | 2 | | add Rm, Rn | | Δ | Δ | Δ | Δ | 3 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the operation results are 0; 0 in all other cases ### ADD Reg1, Reg2, Reg3 #### Operation Reg1 + Reg2 -> Reg3 This instruction adds the contents of Reg1 and Reg2 to each other, and stores the result in Reg3. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | add Rm, Rn, Rd | | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the operation results are 0; 0 in all other cases ### ADD imm, Reg Operation (sign\_ext)imm + Reg -> Reg This instruction adds imm and Reg to each other, and stores the result in Reg. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | add imm8, Dn | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 2 | | add imm16, Dn | imm16 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | add imm32, Dn | | Δ | Δ | Δ | Δ | 6 | | add imm8, An | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 2 | | add imm16, An | imm16 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | add imm32, An | | Δ | Δ | Δ | Δ | 6 | | add imm8, Rn | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | add imm24, Rn | imm24 is sign-extended. | Δ | Δ | Δ | Δ | 6 | | add imm32, Rn | | Δ | Δ | Δ | Δ | 7 | Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the operation results are 0; 0 in all other cases ### ADD imm, SP Operation (sign\_ext)imm + SP -> SP This instruction adds imm and SP to each other, and stores the result in SP. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|-------------------------|---|---|---|---|------| | add imm8, SP | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 3 | | add imm16, SP | imm16 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | add imm32, SP | | Δ | Δ | Δ | Δ | 6 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### Addition with a carry ### ADDC Reg1, Reg2 Operation Reg1 + Reg2 + EPSW.C -> Reg2 This instruction adds the contents of Reg1 and Reg2 to the C flag, and stores the result in Reg2. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | addc Dm, Dn | | Δ | Δ | Δ | Δ | 2 | | addc Rm, Rn | | Δ | Δ | Δ | Δ | 3 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the Z flag before the operation is 1 and the operation results are 0;0 in all other cases. ### ADDC Reg1, Reg2, Reg3 Operation $Reg1 + Reg2 + EPSW.C \rightarrow Reg3$ This instruction adds the contents of Reg1 and Reg2 to the C flag, and stores the result in Reg3. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | addc Rm, Rn, Rd | | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the Z flag before the operation is 1 and the operation results are 0;0 in all other cases. ### ADDC imm, Reg Operation (sign\_ext)imm + Reg + EPSW.C -> Reg This instruction adds imm and Reg to the C flag, and stores the result in Reg. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|-------------------------|---|---|---|---|------| | addc imm8, Rn | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 2 | | addc imm24, Rn | imm24 is sign-extended. | Δ | Δ | Δ | Δ | 3 | | addc imm32, Rn | | Δ | Δ | Δ | Δ | 1 | Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the Z flag before the operation is 1 and the operation results are 0;0 in all other cases. Subtraction ### SUB Reg1, Reg2 Operation Reg2 - Reg1 -> Reg2 This instruction subtracts the contents of Reg1 from Reg2 to each other, and stores the result in Reg2. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | sub Dm, Dn | | Δ | Δ | Δ | Δ | 2 | | sub Dm, An | | Δ | Δ | Δ | Δ | 2 | | sub Am, Dn | | Δ | Δ | Δ | Δ | 2 | | sub Am, An | | Δ | Δ | Δ | Δ | 2 | | sub Rm, Rn | | Δ | Δ | Δ | Δ | 3 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the operation results are 0; 0 in all other cases ### SUB Reg1, Reg2, Reg3 Operation Reg2 - Reg1 -> Reg3 This instruction subtracts the contents of Reg1 from Reg2, and stores the result in Reg3. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | sub Rm, Rn, Rd | | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the operation results are 0; 0 in all other cases ### SUB imm, Reg ### Operation Reg - (sign\_ext)imm -> Reg This instruction subtracts the sign-extended imm from Reg, and stores the result in Reg. | • | | | | | | | |--------------------|-------------------------|---|---|---|---|------| | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | | sub imm32, Dn | | Δ | Δ | Δ | Δ | 6 | | sub imm32, An | | Δ | Δ | Δ | Δ | 6 | | sub imm8, Dn | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | sub imm24, An | imm24 is sign-extended. | Δ | Δ | Δ | Δ | 6 | | sub imm32, Rn | | Δ | Δ | Δ | Δ | 7 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the operation results are 0; 0 in all other cases #### Subtraction with a carry ### SUBC Reg1, Reg2 #### Operation Reg2 - Reg2 - EPSW.C -> Reg2 This instruction subtracts the contents of Reg1 including the C flag from Reg2, and stores the result in Reg2. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | subc Dm, Dn | | Δ | Δ | Δ | Δ | 2 | | subc Rm, Rn | | Δ | Δ | Δ | Δ | 3 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the Z flag before the operation is 1 and the operation results are 0;0 in all other cases. ### SUBC Reg1, Reg2, Reg3 #### Operation Reg2 - Reg1 - EPSW.C -> Reg3 This instruction subtracts the contents of Reg1 including the C flag from Reg2, and stores the result in Reg3. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | subc Rm, Rn, Rd | | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the Z flag before the operation is 1 and the operation results are 0;0 in all other cases. # SUBC imm, Reg ### Operation Reg - (sign\_ext)imm - EPSW.C -> Reg This instruction subtracts the sign-extended imm and the C flag from Reg, and stores the result in Reg. | Assembler mnemonic | Note | V | С | Ζ | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | subc imm8, Rn | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | subc imm24, Rn | imm24 is sign-extended. | Δ | Δ | Δ | Δ | 6 | | subc imm32, Rn | | Δ | Δ | Δ | Δ | 7 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ZF: 1 when the Z flag before the operation is 1 and the operation results are 0;0 in all other cases. #### Signed multiplication ### MUL Reg1, Reg2 Operation Reg1 \* Reg2 -> {MDR, Reg2} The contents of Reg1 (signed 32-bit integer: multiplicand) and Reg2 (signed 32-bit integer: multiplier) are multiplied, and the upper 32 bits of the result (64 bits) are written into MDR and the lower 32 bits into Reg2. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | mul Dm, Dn | | ? | ? | Δ | Δ | 2 | | mul Rm, Rn | | ? | ? | Δ | Δ | 3 | Flag change VF: Undefined CF: Undefined NF: 1 when bit 31 of the lower32 bits of the operation result is 1; 0 in all other cases ZF: 1 when the lower 32 bits of the operation result is 0 and the operation results are 0; 0 in all other cases ### MUL Reg1, Reg2, Reg3, Reg4 Operation Reg1 \* Reg2 -> { Reg3, Reg4 } The contents of Reg1 (signed 32-bit integer: multiplicand) and Reg2 (signed 32-bit integer: multiplier) are multiplied, and the upper 32 bits of the result (64 bits) are written into Reg3 and the lower 32 bits into Reg4. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |----------------------|------------------------------|---|---|---|---|------| | mul Rm, Rn, Rd1, Rd2 | Rd1=Rd2 cannot be specified. | Δ | Δ | Δ | Δ | 4 | Flag change VF: Undefined CF: Undefined NF: 1 when the MSB of the operation result (64 bits) is 1; 0 in all other cases ZF: 1 when the operation result (64 bits) is 0; 0 in all other cases When Rd1=Rd2 is specified, the operation result is not guaranteed. ### MUL imm, Reg ### Operation (sign\_ext)imm \* Reg -> { MDR , Reg } imm (signed 32-bit integer: multiplicand) and the contents of Reg (signed 32-bit integer: multiplier) are multiplied, and the upper 32 bits of the result (64 bits) are written into MDR and the lower 32 bits into Reg. | Assembler mnemonic | Note | ٧ | C | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | mul imm8, Rn | imm8 is sign-extended. | ? | ? | Δ | Δ | 4 | | mul imm24, Rn | imm24 is sign-extended. | ? | ? | Δ | Δ | 6 | | mul imm32, Rn | | ? | ? | Δ | Δ | 7 | #### Flag change VF: Undefined CF: Undefined NF: 1 when bit 31 of the lower32 bits of the operation result is 1; 0 in all other cases ZF: 1 when the lower 32 bits of the operation result is 0; 0 in all other cases ### Unsigned multiplication ### MULU Reg1, Reg2 Operation Reg1 \* Reg2 -> {MDR, Reg2} The contents of Reg1 (unsigned 32-bit integer: multiplicand) and Reg2 (unsigned 32-bit integer: multiplier) are multiplied, and the upper 32 bits of the result (64 bits) are written into MDR and the lower 32 bits into Reg2. | Assembler mnemonic | Note | ٧ | С | Ζ | Ζ | Size | |--------------------|------|---|---|---|---|------| | mulu Dm, Dn | | ? | ? | Δ | Δ | 2 | | mulu Rm, Rn | | ? | ? | Δ | Δ | 3 | Flag change VF: Undefined CF: Undefined NF: 1 when bit 31 of the lower32 bits of the operation result is 1; 0 in all other cases ZF: 1 when the lower 32 bits of the operation result is 0 and the operation results are 0; 0 in all other cases ### MULU Reg1, Reg2, Reg3, Reg4 Operation Reg1 \* Reg2 -> { Reg3, Reg4 } The contents of Reg1 (signed 32-bit integer: multiplicand) and Reg2 (signed 32-bit integer: multiplier) are multiplied, and the upper 32 bits of the result (64 bits) are written into Reg3 and the lower 32 bits into Reg4. | Assembler mnemonic | Note | / | С | Ν | Ζ | Size | |-----------------------|------------------------------|---|---|---|---|------| | mulu Rm, Rn, Rd1, Rd2 | Rd1=Rd2 cannot be specified. | ? | ? | Δ | Δ | 4 | Flag change VF: Undefined CF: Undefined NF: 1 when the MSB of the operation result (64 bits) is 1; 0 in all other cases ZF: 1 when the operation result (64 bits) is 0; 0 in all other cases When Rd1=Rd2 is specified, the operation result is not guaranteed. ## MULU imm, Reg ### Operation (sign\_ext)imm \* Reg -> Reg imm (unsigned 32-bit integer: multiplicand) and Reg (unsigned 32-bit integer: multiplier) are multiplied, and the upper 32 bits of the result (64 bits) are written into MDR and the lower 32 bits into Reg. | Assembler mnemonic | Note | ٧ | C | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | mulu imm8, Rn | imm8 is sign-extended. | ? | ? | Δ | Δ | 4 | | mulu imm24, Rn | imm24 is sign-extended. | ? | ? | Δ | Δ | 6 | | mulu imm32, Rn | | ? | ? | Δ | Δ | 7 | #### Flag change VF: Undefined CF: Undefined NF: 1 when bit 31 of the lower32 bits of the operation result is 1; 0 in all other cases ZF: 1 when the lower 32 bits of the operation result is 0; 0 in all other cases #### Signed divide ### DIV Reg1, Reg2 #### Operation { MDR , Reg2 / Reg1 -> Reg2 { MDR , Reg2 } % Reg1 -> MDR The signed 64-bit integer obtained by linking MDR (upper 32 bits of the dividend) and Reg2 (lower 32 bits of the dividend) is divided by Reg1 (signed 32-bit integer: divisor), and the remainder (32 bits) is written into MDR and the quotient (32 bits) into Reg2. When the quotient cannot be expressed as a 32-bit signed number, the V flag is set to 1 and MDR and Reg2 are undefined. In addition, the V flag also is set to 1 when zero division (divisor = 0) is performed | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | div Dm, Dn | | ? | ? | Δ | Δ | 2 | | div Rm, Rn | | ? | ? | Δ | Δ | 3 | #### Flag change Normal (Operation finishes normally) VF: Always 0. This indicates that the quotient is a 32-bit signed integer without overflow. CF: Undefined NF: 1 when MSB of the quotient (32 bits) is 1; 0 in all other cases ZF: 1 when the quotient (32 bits) is 0; 0 in all other cases When the quatient cannot be indicated as a 32-bit signed value, or when in zero divide. VF: Always 1. CF: Undefined NF: Undefined ZF: Undefined This instruction is a multi-cycle instruction, and the number of cycles differs depending on the significant number of bytes of the dividend (64bits). The significant number of bytes from the LSB of the dividend is judged (note that MDR is judged in word units), and the operation is only performed for the range containing these significant values. Consequently the fewer significant number of bytes of the dividend, the faster operation result can be obtained. Refer to the instruction list for the number of cycles. [Example] the dividend significant number of bytes 0x0000000000001112 bytes 0xFFFFFFFFFF80000 3 bytes #### Unsigned divide ### DIVU Reg1, Reg2 Operation { MDR, Reg2} / Reg1 -> Reg2 { MDR, Reg2 } % Reg1 -> MDR The unsigned 64-bit integer obtained by linking MDR (upper 32 bits of the dividend) and Reg2 (lower 32 bits of the dividend) is divided by Reg1 (unsigned 32-bit integer: divisor), and the remainder (32 bits) is written into MDR and the quotient (32 bits) into Reg2. When the quotient cannot be expressed as a 32-bit unsigned number, the V flag is set to 1 and MDR and Reg2 are undefined. In addition, the V flag also is set to 1 when zero division (divisor = 0) is performed. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | divu Dm, Dn | | ? | ? | Δ | Δ | 2 | | divu Rm, Rn | | ? | ? | Δ | Δ | 3 | #### Flag change Normal (Operation finishes normally) VF: Always 0. This indicates that the quotient is a 32-bit signed integer without overflow. CF: Undefined NF: 1 when MSB of the quotient (32 bits) is 1; 0 in all other cases ZF: 1 when the quotient (32 bits) is 0; 0 in all other cases When the quatient cannot be indicated as a 32-bit signed value, or when in zero divide. VF: always 1. This indicates that the quotient has overflowed. CF: Undefined NF: Undefined ZF: Undefined This instruction is a multi-cycle instruction, and the number of cycles differs depending on the significant number of bytes of the dividend (64bits). The significant number of bytes from the LSB of the dividend is judged (note that MDR is judged in word units), and the operation is only performed for the range containing these significant values. Consequently the fewer significant number of bytes of the dividend, the faster operation result can be obtained. Refer to the instruction list for the number of cycles. [Example] the dividend significant number of bytes 0x0000000000001112 bytes 0xFFFFFFFFFF80000 3 bytes ### Increment by 1 ## INC Reg #### Operation $Reg + 1 \rightarrow Reg$ 1 is added to Reg, and the result is stored in Reg. | Assembler mnemonic | Note | ٧ | C | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | inc Dn | | Δ | Δ | Δ | Δ | 1 | | inc An | | - | - | ı | - | 1 | | inc Rn | | Δ | Δ | Δ | Δ | 3 | #### Flag change inc An VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. #### All other cases VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ### Increment by 4 ### INC4 Reg #### Operation Reg + 4 -> Reg 4 is added to Reg, and the result id stored in Reg. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | inc4 An | | _ | _ | - | _ | 1 | | inc4 Rn | | Δ | Δ | Δ | Δ | 3 | #### Flag change inc An VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. #### All other cases VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ### CMP Reg1, Reg2 Operation Reg2 - Reg1: EPSW This instruction subtracts the contents of Reg1 from Reg2, and reflects the result to the flag. The contents of Reg1 and Reg2 are not changes before and after execution. | l l | | | | | | | |--------------------|--------------------------|---|---|---|---|------| | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | | cmp Dm, Dn | m=n cannot be specified. | Δ | Δ | Δ | Δ | 1 | | cmp Dm, An | | Δ | Δ | Δ | Δ | 2 | | cmp Am, Dn | | Δ | Δ | Δ | Δ | 2 | | cmp Am, An | m=n cannot be specified. | Δ | Δ | Δ | Δ | 1 | | cmp Rm, Rn | | Δ | Δ | Δ | Δ | 3 | #### Flag change VF: 1 when overflow occurs as a 32-bit signed number; 0 in all other cases CF: 1 when carry from bit 31 occurs; 0 in all other cases NF: 1 when bit 31 of the operation results is 1; 0 in all other cases ### CMP imm, Reg #### Operation Rn2 - imm : EPSW This instruction subtracts imm from Reg, and reflects the result to the flag. The contents of Reg1 and Reg2 are not changes before and after execution. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | cmp imm8, Dn | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 2 | | cmp imm16, Dn | imm16 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | cmp imm32, Dn | | Δ | Δ | Δ | Δ | 6 | | cmp imm8, An | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 2 | | cmp imm16, An | imm16 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | cmp imm32, An | | Δ | Δ | Δ | Δ | 6 | | cmp imm8, Rn | imm8 is sign-extended. | Δ | Δ | Δ | Δ | 4 | | cmp imm24, Rn | imm24 is sign-extended. | Δ | Δ | Δ | Δ | 6 | | cmp imm32, Rn | | Δ | Δ | Δ | Δ | 7 | #### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ### Logical product ### AND Reg1, Reg2 Operation Reg1 & Reg2 -> Reg2 This instruction takes the logical product between Reg1 and Reg2, and stores the result in Reg2. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | and Dm, Dn | | 0 | 0 | Δ | Δ | 2 | | and Rm, Rn | | 0 | 0 | Δ | Δ | 3 | #### Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ZF: 1 when the operation result is 0, 0 in all other cases. ### AND Reg1, Reg2, Reg3 Operation Reg1 & Reg2 -> Reg2 This instruction takes the logical product between Reg1 and Reg2, and stores the result in Reg2. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | and Rm, Rn, Rd | | 0 | 0 | Δ | Δ | 4 | Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ### AND imm, Reg Operation (zero\_ext)imm & Reg -> Reg This instruction takes the logical product between zero-extended imm and Reg, and stores the result in Reg. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|-------------------------|---|---|---|---|------| | and imm8, Dn | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 3 | | and imm16, Dn | imm16 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | and imm32, Dn | | 0 | 0 | Δ | Δ | 6 | | and imm8, Rn | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | and imm24, Rn | imm24 is zero-extended. | 0 | 0 | Δ | Δ | 6 | | and imm32, Rn | | 0 | 0 | Δ | Δ | 7 | Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ### AND imm16, PSW (Privileged instruction) #### Operation imm16 & EPSW[15:0] -> EPSW[15:0] This instruction takes the logical product between imm16 and the lower 16 bits of EPSW, and stores the result in the lower 16 bits of EPSW. The upper 16 bits of EPSW (EPSW[32:16]) are not changed. This instruction is a privileged instruction, and can be executed at the supervisor and monitor levels. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | and imm16, PSW | | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: The bit 3 of the operation result is set. CF: The bit 2 of the operation result is set. NF: The bit 1 of the operation result is set. ZF: The bit 0 of the operation result is set. If this instruction is executed at user level, system exception (privileged instruction execution exception) occurs. ### AND imm32, EPSW (Privileged instruction) #### Operation imm32(SP) & EPSW -> EPSW This instruction takes the logical product between imm32 and EPSW, and stores the result in EPSW. This instruction is a privileged instruction, and can be executed at the supervisor and monitor levels. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | and imm32, EPSW | | Δ | Δ | Δ | Δ | 6 | #### Flag change VF: The bit 3 of the operation result is set. CF: The bit 2 of the operation result is set. NF: The bit 1 of the operation result is set. ZF: The bit 0 of the operation result is set. If this instruction is executed at user level, system exception (privileged instruction execution exception) occurs. ### Logical sum ### OR Reg1, Reg2 Operation $Reg1 \mid Reg2 \rightarrow Reg2$ This instruction takes the logical sum between Reg1 and Reg2, and stores the result in Reg2. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | or Dm, Dn | | 0 | 0 | Δ | Δ | 2 | | or Rm, Rn | | 0 | 0 | Δ | Δ | 3 | #### Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ZF: 1 when the operation result is 0, 0 in all other cases. ### OR Reg1, Reg2, Reg3 Operation $Reg1 \mid Reg2 \rightarrow Reg2$ This instruction takes the logical sum between Reg1 and Reg2, and stores the result in Reg3. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | and Rm, Rn, Rd | | 0 | 0 | Δ | Δ | 4 | Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ### OR imm, Reg #### Operation (zero\_ext)imm | Reg -> Reg This instruction takes the logical sum between zero-extended imm and Reg, and stores the result in Reg. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | or imm8, Dn | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 3 | | or imm16, Dn | imm16 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | or imm32, Dn | | 0 | 0 | Δ | Δ | 6 | | or imm8, Rn | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | or imm24, Rn | imm24 is zero-extended. | 0 | 0 | Δ | Δ | 6 | | or imm32, Rn | | 0 | 0 | Δ | Δ | 7 | #### Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ### OR imm16, PSW (Privileged instruction) #### Operation imm16 | EPSW[15:0] -> EPSW[15:0] This instruction takes the logical sum between imm16 and the lower 16 bits of EPSW, and stores the result in the lower 16 bits of EPSW. The upper 16 bits of EPSW (EPSW[32:16]) are not changed. This instruction is a privileged instruction, and can be executed at the supervisor and monitor levels. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | or imm16, PSW | | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: The bit 3 of the operation result is set. CF: The bit 2 of the operation result is set. NF: The bit 1 of the operation result is set. ZF: The bit 0 of the operation result is set. If this instruction is executed at user level, system exception (privileged instruction execution exception) occurs. ### OR imm32, EPSW (Privileged instruction) #### Operation imm32(SP) | EPSW -> EPSW This instruction takes the logical sum between imm32 and EPSW, and stores the result in EPSW. This instruction is a privileged instruction, and can be executed at the supervisor and monitor levels. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | or imm32, EPSW | | Δ | Δ | Δ | Δ | 6 | #### Flag change VF: The bit 3 of the operation result is set. CF: The bit 2 of the operation result is set. NF: The bit 1 of the operation result is set. ZF: The bit 0 of the operation result is set. If this instruction is executed at user level, system exception (privileged instruction execution exception) occurs. ### XOR Reg1, Reg2 Operation Reg1^ Reg2 -> Reg2 This instruction takes the exclusive logical sum between Reg1 and Reg2, and stores the result in Reg2. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | xor Dm, Dn | | 0 | 0 | Δ | Δ | 2 | | xor Rm, Rn | | 0 | 0 | Δ | Δ | 3 | #### Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ZF: 1 when the operation result is 0, 0 in all other cases. ### XOR Reg1, Reg2, Reg3 Operation $Reg1^{Reg2} \rightarrow Reg2$ This instruction takes the exclusive logical sum between Reg1 and Reg2, and stores the result in Reg3. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | xor Rm, Rn, Rd | | 0 | 0 | Δ | Δ | 4 | Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ### XOR imm, Reg #### Operation (zero\_ext)imm ^ Reg -> Reg This instruction takes the exclusive logical sum between zero-extended imm and Reg, and stores the result in Reg. | Assembler mnemonic | Note | / | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | xor imm16, Dn | imm16 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | xor imm32, Dn | | 0 | 0 | Δ | Δ | 6 | | xor imm8, Rn | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | xor imm24,Rn | imm24 is zero-extended. | 0 | 0 | Δ | Δ | 6 | | xor imm32, Rn | | 0 | 0 | Δ | Δ | 7 | #### Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. | NOT | Reg | |-----|-----| |-----|-----| Operation $Reg \ ^{\wedge} \ 0xFFFFFFFF \ \text{--} > Reg$ This instruction reverses all bits of Reg, and stores the result in Reg. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | not Dn | | 0 | 0 | Δ | Δ | 2 | | not Rn | | 0 | 0 | Δ | Δ | 3 | Flag change VF: Always 0. CF: Always 0. NF: 1 when bit 31 of the operation result is 1, 0 in all other cases. ## **BTST** #### Multiple bit test ### BTST imm, Reg Operation (zero ext)imm & Reg: EPSW The logical product of the zero-extended imm and Reg is executed, and the result is reflected to the flag. | - | | | | _ | | | | |------|--------------------|-------------------------|---|---|---|---|------| | | Assembler mnemonic | Note | V | C | N | Z | Size | | btst | imm8, Dn | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 3 | | btst | imm16, Dn | imm16 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | btst | imm32, Dn | | 0 | 0 | Δ | Δ | 6 | | btst | imm8, Rn | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 4 | | btst | imm24, Rn | imm24 is zero-extended. | 0 | 0 | Δ | Δ | 6 | | btst | imm32, Rn | | 0 | 0 | Δ | Δ | 7 | Flag change VF : Always "0" CF : Always "0" NF: 1 when bit 31 of the operation result is 1; 0 in all other cases ZF: 1 when the operation result is 0; 0 in all other cases ### BTST imm, Mem Operation BTST imm, (disp, Reg) Mem8(disp, Reg) -> TMP[7:0] $0x0000000 \rightarrow TMP[31:8]$ imm & TMP: EPSW BTST imm, (abs) Mem8(abs) -> TMP[7:0] $0x0000000 \rightarrow TMP[31:8]$ imm & TMP: EPSW The logical product of imm and the contents (byte data) of Mem zero-extended to 32 bits is executed, and the result is reflected to the flag. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |---------------------|----------------------------------------------------|---|---|---|---|------| | btst imm8, (d8, An) | imm8 is zero-extended, and d8 is sign-extended. | 0 | 0 | Δ | Δ | 4 | | btst imm8, (abs16) | imm8 is zero-extended, and abs16 is zero-extended. | 0 | 0 | Δ | Δ | 5 | | btst imm8, (abs32) | imm8 is zero-extended. | 0 | 0 | Δ | Δ | 7 | Flag change VF : Always "0" CF : Always "0" NF: 1 when bit 31 of the operation result is 1; 0 in all other cases ZF: 1 when the operation result is 0; 0 in all other cases btst imm8, (abs16) implements AM33-2, AM33-2A, AM34-1. #### Multiple bit tests and sets ### BSET Reg, Mem #### Operation BSET Reg1, (Reg2) $Mem8(Reg2) \rightarrow TMP[7:0]$ $0x0000000 \rightarrow TMP[31:8]$ TMP & Reg1: EPSW $(TMP \mid Reg1)[7:0] \rightarrow Mem8(Reg2)$ - 1. The contents (byte data) of Mem are zero-extended to 32 bits and loaded into the internal temporary register (TMP). - 2. The logical product of the contents of the temporary register (TMP) and the contents of Reg is taken and the operation flag results are reflected to EPSW. - 3. The logical product of the contents of the temporary register (TMP) and the contents of Reg is taken and the lower 8 bits of the result are stored in Mem. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-------------|---|---|---|---|------| | bset Dm, (An) | | 0 | 0 | 0 | Δ | 2 | | | Flag change | | | | | | VF: Always 0. CF: Always 0. NF: Always 0. ZF: "1" when the operation result is "0", "0" in all other cases. All operations for this instruction are executed in the bus-lock and interrupt prohibited condition. ### BSET imm, Mem #### Operation BTST imm, (disp, Reg) $Mem8(Reg + disp) \rightarrow TMP[7:0]$ 0x000000 -> TMP[31:8] TMP & imm: EPSW (TMP | imm) [7:0] -> mem8(Reg + disp) BTST imm, (abs) Mem8(abs) -> TMP[7:0] 0x000000 -> TMP[31:8] TMP & imm: EPSW (TMP | imm) [7:0] -> mem8(abs) - 1. The contents (byte data) of Mem are zero-extended to 32 bits and loaded into the internal temporary register (TMP). - 2. The logical product of the contents of the temporary register (TMP) and imm is taken and the operation flag results are reflected to PSW. - 3. The logical product of the contents of the temporary register (TMP) and imm is taken and the lower 8 bits of the result are stored in Mem. | Assembler mnemonic | Note | < | O | Z | Ζ | Size | |---------------------|----------------------------------------------------|---|---|---|---|------| | bset imm8, (d8, An) | imm8 is zero-extended, and d8 is sign-extended. | 0 | 0 | 0 | Δ | 4 | | bset imm8, (abs16) | imm8 is zero-extended, and abs16 is zero-extended. | 0 | 0 | 0 | Δ | 5 | | bset imm8, (abs32) | imm8 is zero-extended. | 0 | 0 | 0 | Δ | 7 | Flag change VF : Always "0" CF : Always "0" NF : Always "0" $ZF:\ 1$ when the operation result is 0; 0 in all other cases All operations for this instruction are executed in the bus-lock and interrupt prohibited condition. bset imm8, (abs16) implements AM33-2, AM33-2A, AM34-1. #### Multiple bit tests and clearing ### BCLR Reg, Mem #### Operation BCLR Reg1, (Reg2) $mem8(Reg2) \rightarrow TMP[7:0]$ $0x0000000 \rightarrow TMP[31:8]$ TMP & Reg1: EPSW (TMP &(Reg ^ 0xFFFFFFFF))[7:0] -> mem8(Reg2) - 1. The contents (byte data) of Mem are zero-extended to 32 bits and loaded into the internal temporary register (TMP). - 2. The logical product of the contents of the temporary register (TMP) and the contents of Reg1 is taken and the operation flag results are reflected to EPSW. - 3. The logical product of the contents of the temporary register (TMP) and the logically inverted contents of Reg1 is taken and the lower 8 bits of the result are stored in Mem. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|-------------|---|---|---|---|------| | bclr Dm, (An) | | 0 | 0 | 0 | Δ | 2 | | | Flag change | | | | | | VF: Always 0. CF: Always 0. NF: Always 0. ZF: "1" when the operation result is "0", "0" in all other cases. All operations for this instruction are executed in the bus-lock and interrupt prohibited condition. ### BCLR imm, Mem #### Operation BCLR imm, (disp, Reg) $mem8(Reg + disp) \rightarrow TMP[7:0]$ 0x000000 -> TMP[31:8] TMP & imm: EPSW (TMP & (imm ^ 0xFFFFFFFF)) -> mem8(Reg + disp) BCLR imm, (abs) mem8(abs2) -> TMP[7:0] 0x000000 -> TMP[31:8] TMP & imm: EPSW (TMP & (imm ^ 0xFFFFFFFF)) -> mem8(abs) - 1. The contents (byte data) of Mem are zero-extended to 32 bits and loaded into the internal temporary register (TMP). - 2. The logical product of the contents of the temporary register (TMP) and imm is taken and the operation flag results are reflected to EPSW. - 3. The logical product of the contents of the temporary register (TMP) and the logically inverted data of imm is taken and the lower 8 bits of the result are stored in Mem. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |---------------------|----------------------------------------------------|---|---|---|---|------| | bclr imm8, (d8, An) | imm8 is zero-extended, and d8 is sign-extended. | 0 | 0 | 0 | Δ | 4 | | bclr imm8, (abs16) | imm8 is zero-extended, and abs16 is zero-extended. | 0 | 0 | 0 | Δ | 5 | | bclr imm8, (abs32) | imm8 is zero-extended. | 0 | 0 | 0 | Δ | 7 | Flag change VF : Always "0" CF : Always "0" NF : Always "0" ZF: 1 when the operation result is 0; 0 in all other cases All operations for this instruction are executed in the bus-lock and interrupt prohibited condition. bclr imm8, (abs16) implements AM33-2, AM33-2A, AM34-1. #### Arbitrary-bit arithmetic shift right ### ASR Reg1, Reg2 #### Operation If (Reg1 & 0x0000001F)is not "0" $Reg2[0] \rightarrow EPSW.C$ (sign-ext)(Reg2 >> (Reg1 & 0x0000001F)) -> Reg2 If (Reg1 & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg2 are arithmetically shifted to the right by the number of bits specified by Reg1, and the result is written into Reg2. When (Reg1 & 0x0000001F) are 0, shift operation is not performed. Only the lower 5 bits of Reg1 are effective and the upper bits are ignored. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-----------------------------------------------------------|---|---|---|---|------| | asr Dm, Dn | The contents of the lower 5 bits in Dm are other than "0" | ? | Δ | Δ | Δ | 2 | | | The contents of the lower 5 bits in Dm are "0" | ? | ? | Δ | Δ | | | asr Rm, Rn | The contents of the lower 5 bits in Rm are other than "0" | ? | Δ | Δ | Δ | 3 | | ,,,,, | The contents of the lower 5 bits in Rm are "0" | ? | ? | Δ | Δ | | #### Flag change When (Reg1 & 0x00001F) is not "0" VF: Undefined CF: Reflects the value of the bit initially shifted out NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (Reg1 & 0x00001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg2) is "1", and "0" in all other cases. ZF: "1" when the register (Reg2) is "0", and "0" in all other cases. ### ASR Reg1, Reg2, Reg3 #### Operation If (Reg1 & 0x0000001F) is not "0" Reg2[0] -> EPSW.C (sign-ext)(Reg2 >> (Reg1 & 0x0000001F)) -> Reg2 If (Reg1 & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg2 are arithmetically shifted to the right by the number of bits specified by Reg1, and the result is written into Reg2. When (Reg1 & 0x0000001F) are 0, shift operation is not performed. Only the lower 5 bits of Reg1 are effective and the upper bits are ignored. | | | | _ | l | | C: | |--------------------|-----------------------------------------------------------|---|---|---|---|------| | Assembler mnemonic | Note | V | C | N | Z | Size | | asr Rm. Rn. Rd | The contents of the lower 5 bits in Rm are other than "0" | ? | Δ | Δ | Δ | 4 | | , , , | The contents of the lower 5 bits in Rm are "0" | ? | ? | Δ | Δ | | #### Flag change When (Reg1 & 0x00001F) is not "0" VF: Undefined CF: Reflects the value of the bit initially shifted out NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (Reg1 & 0x00001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg2) is "1", and "0" in all other cases. ZF: "1" when the register (Reg2) is "0", and "0" in all other cases. ### ASR imm, Reg #### Operation If (imm & 0x0000001F)is not "0" $Reg2[0] \rightarrow EPSW.C$ (sign-ext)(Reg2 >> (imm & 0x0000001F)) -> Reg If (imm & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg are arithmetically shifted to the right by the number of bits specified by the lower 5 bits of imm, and the result is written into Reg. When the imm lower 5 bits are 0, shift operation is not performed. Only the lower 5 bits in imm are effective and the upper bits are ignored. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|-----------------------------------|---|---|---|---|------| | asr imm8, Dn | When (imm& 0x0000001F) is not "0" | ? | Δ | Δ | Δ | 3 | | | When (imm& 0x0000001F) is "0" | ? | ? | Δ | Δ | | | asr imm8, Rn | When (imm& 0x0000001F) is not "0" | ? | Δ | Δ | Δ | 4 | | | When (imm& 0x0000001F) is "0" | ? | ? | Δ | Δ | | | asr imm24, Rn | When (imm& 0x0000001F) is not "0" | ? | Δ | Δ | Δ | 6 | | | When (imm& 0x0000001F) is "0" | ? | ? | Δ | Δ | | | asr imm32, Rn | When (imm& 0x0000001F) is not "0" | ? | Δ | Δ | Δ | 7 | | asi iiiiii32, iXii | When (imm& 0x0000001F) is "0" | ? | ? | Δ | Δ | | #### Flag change When (imm & 0x0000001F) is not "0" VF: Undefined CF: Reflects the value of the bit initially shifted out NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (imm & 0x0000001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg) is "1", and "0" in all other cases. ZF: "1" when the register (Reg) is "0", and "0" in all other cases. ### Arbitrary-bit logical shift right ### LSR Reg1, Reg2 #### Operation If (Reg1 & 0x0000001F)is not "0" $Reg2[0] \rightarrow EPSW.C$ (zero-ext)(Reg2 >> (Reg1 & 0x0000001F)) -> Reg2 If (Reg1 & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg2 are logically shifted to the right by the number of bits specified by the lower 5 bits of Reg1, and the result is written into Reg2. When the contents of the lower 5 bits in Reg1 are 0, shift operation is not performed. Only the lower 5 bits of Reg1 are effective and the upper bits are ignored. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-----------------------------------------------------------|---|---|---|---|------| | Isr Dm, Dn | The contents of the lower 5 bits in Dm are other than "0" | ? | Δ | Δ | Δ | 2 | | | The contents of the lower 5 bits in Dm are "0" | ? | ? | Δ | Δ | | | Isr Rm, Rn | The contents of the lower 5 bits in Rm are other than "0" | ? | Δ | Δ | Δ | 3 | | | The contents of the lower 5 bits in Rm are "0" | ? | ? | Δ | Δ | | #### Flag change When (Reg1 & 0x0000001F) is not "0" VF: Undefined CF: Reflects the value of the bit initially shifted out NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (Reg1 & 0x0000001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg2) is "1", and "0" in all other cases. ZF: "1" when the register (Reg2) is "0", and "0" in all other cases. ### LSR Reg1, Reg2, Reg3 #### Operation If (Reg1 & 0x0000001F) is not "0" $Reg2[0] \rightarrow EPSW.C$ (zero-ext)(Reg2 >> (Reg1 & 0x0000001F)) -> Reg3 If (Reg1 & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg2 are logically shifted to the right by the number of bits specified by the lower 5 bits of Reg1, and the result is written into Reg3. When the lower 5 bits of Reg 1 are 0, shift operation is not performed. Only the lower 5 bits of Reg1 are effective and the upper bits are ignored. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-----------------------------------------------------------|---|---|---|---|------| | lsr Rm, Rn, Rd | The contents of the lower 5 bits in Rm are other than "0" | ? | Δ | Δ | Δ | 4 | | | The contents of the lower 5 bits in Rm are "0" | ? | ? | Δ | Δ | | #### Flag change When (Reg1 & 0x0000001F) is not "0" VF: Undefined CF: Reflects the value of the bit initially shifted out NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (Reg1 & 0x0000001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg2) is "1", and "0" in all other cases. ZF: "1" when the register (Reg2) is "0", and "0" in all other cases. ### LSR imm, Reg #### Operation If (imm & 0x0000001F)is not "0" $Reg[0] \rightarrow EPSW.C$ (zero-ext)(Reg2 >> (imm & 0x0000001F)) -> Reg If (imm & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg are arithmetically shifted to the right by the number of bits specified by the lower 5 bits of imm, and the result is written into Reg. When the imm lower 5 bits are 0, shift operation is not performed. Only the lower 5 bits in imm are effective and the upper bits are ignored. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|---------------------------------------|---|---|---|---|------| | Isr imm8, Dn | When the imm lower 5 bits are not "0" | ? | Δ | Δ | Δ | 3 | | | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | | Isr imm8, Rn | When the imm lower 5 bits are not "0" | ? | Δ | Δ | Δ | 4 | | | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | | lsr imm24, Rn | When the imm lower 5 bits are not "0" | ? | Δ | Δ | Δ | 6 | | | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | | lsr imm32, Rn | When the imm lower 5 bits are not "0" | ? | Δ | Δ | Δ | 7 | | 131 11111132, 1411 | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | Flag change When (imm & 0x0000001F) is not "0" VF: Undefined CF: Reflects the value of the bit initially shifted out NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (imm & 0x0000001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg) is "1", and "0" in all other cases. ZF: "1" when the register (Reg) is "0", and "0" in all other cases. #### Arbitrary-bit arithmetic shift left ### ASL Reg1, Reg2 #### Operation If (Reg1 & 0x0000001F)is not "0" $(Reg2 \le (Reg1 \& 0x0000001F)) -> Reg2$ If (Reg1 & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg 2 are arithmetically shifted to the left by the number of bits specified by the lower 5 bits of Reg1, and the result is written into Reg 2. When the contents of the lower 5 bits in Reg 1 are 0, shift operation is not performed. Only the lower 5 bits of Reg1 are effective and the upper bits are ignored. "0" is input to the LSB side. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-----------------------------------------------------------|---|---|---|---|------| | asl Dm, Dn | The contents of the lower 5 bits in Dm are other than "0" | ? | ? | Δ | Δ | 2 | | | The contents of the lower 5 bits in Dm are "0" | ? | ? | Δ | Δ | | | asl Rm, Rn | The contents of the lower 5 bits in Rm are other than "0" | ? | ? | Δ | Δ | 3 | | , | The contents of the lower 5 bits in Rm are "0" | ? | ? | Δ | Δ | | #### Flag change When (Reg1 & 0x00001F) is not "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (Reg1 & 0x0000001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg2) is "1", and "0" in all other cases. ZF: "1" when the register (Reg2) is "0", and "0" in all other cases. ### ASL Reg1, Reg2, Reg3 #### Operation If (Reg1 & 0x0000001F) is not "0" $(Reg2 \le (Reg1 \& 0x0000001F)) -> Reg3$ If (Reg1 & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg 2 are arithmetically shifted to the left by the number of bits specified by the lower 5 bits of Reg1, and the result is written into Reg 3. When the contents of the lower 5 bits in Reg 1 are 0, shift operation is not performed. Only the lower 5 bits of Reg1 are effective and the upper bits are ignored. "0" is input to the LSB side. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-----------------------------------------------------------|---|---|---|---|------| | asl Rm, Rn, Rd | The contents of the lower 5 bits in Rm are other than "0" | ? | ? | Δ | Δ | 4 | | doi raii, rai, ra | The contents of the lower 5 bits in Rm are "0" | ? | ? | Δ | Δ | | #### Flag change When (Reg1 & 0x0000001F) is not "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (Reg1 & 0x0000001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg2) is "1", and "0" in all other cases. ZF: "1" when the register (Reg2) is "0", and "0" in all other cases. ### ASL imm, Reg #### Operation If (imm & 0x0000001F) is not "0" (Reg << (imm & 0x0000001F)) -> Reg If (imm & 0x0000001F) is "0" PC + Code Size -> PC The contents of Reg are arithmetically shifted to the left by the number of bits specified by the lower 5 bits of imm, and the result is written into Reg 3. When the imm lower 5 bits are 0, shift operation is not performed. Only the imm lower 5 bits are effective and the upper bits are ignored. "0" is input to the LSB side. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|---------------------------------------|---|---|---|---|------| | acl imm8 Dn | When the imm lower 5 bits are not "0" | ? | ? | Δ | Δ | 3 | | asl imm8, Dn | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | | asl imm8, Rn | When the imm lower 5 bits are not "0" | ? | ? | Δ | Δ | 4 | | asi illillo, Kii | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | | and image 24. Do | When the imm lower 5 bits are not "0" | ? | ? | Δ | Δ | 6 | | asl imm24, Rn | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | | ael imm?? Pn | When the imm lower 5 bits are not "0" | ? | ? | Δ | Δ | 7 | | asl imm32, Rn | When the imm lower 5 bits are "0" | ? | ? | Δ | Δ | | #### Flag change When (imm & 0x0000001F) is not "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the operation result is "1", and "0" in all other cases. ZF: "1" when the operation result is "0", and "0" in all other cases. When (imm & 0x0000001F) is "0" VF: Undefined CF: Undefined NF: "1" when bit 31 of the register (Reg) is "1", and "0" in all other cases. ZF: "1" when the register (Reg) is "0", and "0" in all other cases. #### 2-bit arithmetic shift left ### ASL2 Reg #### Operation Reg << 2 -> Reg The contents of Reg $\,$ are arithmetically shifted to the left by only 2 bits, and the result is written into Reg $\,$ . | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | asl2 Dn | | ? | ? | Δ | Δ | 1 | | asl2 Rn | | ? | ? | Δ | Δ | 3 | #### Flag change VF: Undefined. CF: Undefined. NF:"1" when the bit 31 of the operation result is "1"; "0" in all other cases. #### 1-bit rotate right ## ROR Reg #### Operation $\{EPSW.C, Reg[31:0]\} \rightarrow \{Reg[31:0], EPSW.C\}$ Reg and the C flag are linked and rotated 1 bit to the right, and the result is written into Reg. C flag previously set reflects to MSB. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | ror Dn | | 0 | Δ | Δ | Δ | 2 | | ror Rn | | 0 | Δ | Δ | Δ | 3 | #### Flag change VF: Always 0. CF: Reflects the value of the bit shifted out by the operation NF: 1 when bit 31 of the operation result is 1; 0 in all other cases # ROL #### 1-bit rotate left ### **ROL** Reg ### Operation $\{ Reg[31:0], EPSW.C \} \rightarrow \{ EPSW.C, Reg[31:0] \}$ Reg and the C flag are linked and rotated 1 bit to the left, and the result is written into Reg. C flag previously set reflects to LSB. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | rol Dn | | 0 | Δ | Δ | Δ | 2 | | rol Rn | | 0 | Δ | Δ | Δ | 3 | #### Flag change VF: Always 0. CF: Reflects the value of the bit shifted out by the operation NF:1 when bit 31 of the operation result is 1; 0 in all other cases ### Conditional branch ### Bcc (d8, PC) #### Operation When branch is taken, PC (current instruction address) + (sign\_ext) d8 -> nPC (next instruction PC) 8-bit displacement (d8) is sign-extended and added to the PC, and the result is written into the PC. Even if the addition result overflows, this overflow is ignored and the result is written into the PC. When branch is not taken, PC (current instruction address) + CodeSize -> nPC (next instruction PC) The next instruction is executed. | As | ssembler mnemonic | | Note | V | С | Ν | Ζ | Size | |------|-------------------|----------------|-------------------------------------|---|---|---|---|------| | beq | label | Z | Branch when $Z = 1$ or $Z$ flag set | - | - | _ | _ | 2 | | bne | label | ~Z | Branch when Z ≠ 1 or Z flag cleared | - | - | - | _ | 2 | | bgt | label | ~(Z (N ^ V)) | Branch when < (signed) | _ | _ | _ | _ | 2 | | bge | label | ~(N ^ V) | Branch when ≤ (signed) | _ | - | _ | _ | 2 | | ble | label | Z (N ^ V) | Branch when ≥ (signed) | - | - | _ | - | 2 | | blt | label | N ^ V | Branch when > (signed) | _ | _ | _ | _ | 2 | | bhi | label | ~(C Z) | Branch when < (unsigned) | _ | - | _ | _ | 2 | | bcc | label | ~C | Branch when ≤or C flag cleared | - | - | - | - | 2 | | | | | (unsigned) | | | | | | | blsq | label | C Z | Branch when ≥ (unsigned) | _ | _ | _ | _ | 2 | | bcs | label | С | Branch when > or C flag set | _ | - | _ | _ | 2 | | | | | (unsigned) | | | | | | | bvc | label | ~V | Branch when V flag cleared | _ | - | _ | _ | 3 | | bvs | label | V | Branch when V flag set | _ | - | _ | _ | 3 | | bnc | label | ~N | Branch when N flag cleared | _ | _ | _ | _ | 3 | | bns | label | N | Branch when N flag set | _ | _ | _ | _ | 3 | | bra | label | None | Unconditional branch | _ | _ | _ | _ | 2 | | | | • | | | | | | | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. # Lcc ## Loop-only conditional branch ### Lcc #### Operation When branch is taken LAR - 4 -> nPC (next instruction PC) The instruction loaded from the loop instruction register (LIR) is executed and instruction fetch starts for the address loaded to the loop address register (LAR). At the same time, 4 is subtracted from the loop address register (LAR) and the result is written into the PC. Even if the subtract result overflows, this overflow is ignored and the result is written into the PC. When Lcc is not coordinated with SETLB, execution cannot be assured. This is used with SETLB in order to speed up the loop executionl, and performs conditional branch to the top of the loop set by SETLB. When branch is not taken PC (current instruction address) + 1 -> nPC (next instruction PC) The next instruction is executed. | Assembler mnemonic | | Note | ٧ | С | Ν | Ζ | Size | |--------------------|----------------|-------------------------------------|---|---|---|---|------| | leq label | Z | Branch when $Z = 1$ or $Z$ flag set | - | _ | _ | _ | 1 | | lne label | ~Z | Branch when Z ≠ 1 or Z flag cleared | - | - | _ | _ | 1 | | lgt label | ~(Z (N ^ V)) | Branch when < (signed) | - | - | _ | - | 1 | | lge label | ~(N ^ V) | Branch when ≤ (signed) | - | _ | _ | _ | 1 | | lle label | Z (N ^ V) | Branch when ≥ (signed) | - | _ | _ | _ | 1 | | llt label | N ^ V | Branch when > (signed) | ı | - | _ | ı | 1 | | lhi label | ~(C Z) | Branch when < (unsigned) | - | _ | _ | _ | 1 | | lcc label | ~C | Branch when ≤or C flag cleared | - | _ | _ | - | 1 | | | | (unsigned) | | | | | | | lls label | C Z | Branch when ≥ (unsigned) | _ | _ | _ | _ | 1 | | Ics label | С | Branch when > or C flag set | _ | _ | _ | _ | 1 | | | | (unsigned) | | | | | | | Ira label | None | Unconditional flag | - | _ | _ | _ | 1 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. Set loop buffer ### **SETLB** Operation $mem32(PC+1) \rightarrow LIR$ , $PC + 5 \rightarrow LAR$ The 4-byte instruction string and 5th-byte address following to SETLB are stored to LIR and LAR respectively. SETLB is used together with Lcc in order to speed up the loop (the inner most loop) execution. The top of the loop is set by SETLB just before the loop entrance. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | setlb | | _ | _ | _ | _ | 1 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When the instruction row subsequent to the SETLB instruction is as follows: **SETLB** В С D :A,B,C,D are 1-byte instructions. These are stored in the LIR as shown below. LIR[31] [0] When LAR = 4n С В Α В Α D When LAR = 4n+1 С When LAR = 4n+2D D When LAR = 4n+3В ### Unconditional branch ### JMP (An) Operation An -> nPC (next instruction PC) This stores the contents of the An register in PC. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | jmp (An) | | _ | _ | _ | _ | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### JMP (d16, PC) Operation When the displacement from PC to label can be represented within 16 bits, PC (current instruction address) + ((sign-extended) d16) -> nPC (next instruction PC) This sign-extends the 16-bit displacement (d16) and adds it to PC, and stores the result in PC. Even if the additon result overflows, the overflow is ignored and the result is stored in PC. | Assembler mnemonic | Branch condition | | С | Ν | Z | Size | |--------------------|------------------------------------------------------|---|---|---|---|------| | jmp label | When the displacement from PC to label can be repre- | - | _ | - | _ | 3 | | | sented within 16 bits | | | | | | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### JMP (d32, PC) #### Operation When the displacement from PC to label can be represented within 32 bits, PC (current instruction address) + ((sign-extended) d32) -> nPC (next instruction PC) This sign-extends the 32-bit displacement (d32) and adds it to PC, and stores the result in PC. Even if the addition result overflows, the overflow is ignored and the result is stored in PC. | Assembler mnemonic | Branch condition | ٧ | С | N | Z | Size | |--------------------|------------------------------------------------------|---|---|---|---|------| | jmp label | When the displacement from PC to label can be repre- | _ | _ | - | _ | 5 | | | sented within 32 bits | | | | | | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### Subroutine call ### CALL (d16, PC), regs, imm8 #### Operation PC (current instruction address) + (sign-ext) d16 -> nPC (next instruction PC) PC (current instruction address) + CodeSize -> mem32(SP) PC (current instruction address) + CodeSize -> MDR Multiple registers specified by regs -> Lower address memory following (SP - 4) SP - (zero-ext) imm8 -> SP This instruction branches to the specified address after saving PC and the multiple registers to the stack and allocating the stack area. d16 is sign-extended and added to the PC, and the result is written into the PC. Even if the addition result overflows, this overflow is ignored and the result is written into the PC. The multiple registers to be saved are specified by regs, and the area to be allocated (number of bytes) by imm8 (zero-extended). (See MOVM for a detailed description of regs.) CALL is used together with RET or RETF in order to save and restore registers and allocate and deallocate the stack area quickly during subroutine call. The stack frame status after executing the CALL instruction is shown below. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |------------------------|------|---|---|---|---|------| | call label, regs, imm8 | | _ | _ | _ | _ | 2 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. The three operands of d16, regs and imm8 are used for the bit assignment. Normally, the multiple registers to be saved and the amount of area to be allocated are not specified (regs, imm8) directly by the assembler. Instead, these items are specified indirectly with a pseudo instruction in the callee and ultimately resolved by the linker. For details, refer to MN10300-series cross assembler user's manual. When the memory address (SP) is not a multiple of 4, a system exception (address misalignment exception) occurs. ### CALL (d32, PC), regs, imm8 #### Operation PC (current instruction address) + (sign-ext) d32 -> nPC (next instruction PC) PC (current instruction address) + CodeSize -> mem32(SP) PC (current instruction address) + CodeSize -> MDR Multiple registers specified by regs -> Lower address memory following (SP - 4) SP - (zero-ext) imm8 -> SP This instruction branches to the specified address after saving PC and the multiple registers to the stack and allocating the stack area. d32 is sign-extended and added to the PC, and the result is written into the PC. Even if the addition result overflows, this overflow is ignored and the result is written into the PC. The multiple registers to be saved are specified by regs, and the area to be allocated (number of bytes) by imm8 (zero-extended). (See MOVM for a detailed description of regs.) CALL is used together with RET or RETF in order to save and restore registers and allocate and deallocate the stack area quickly during subroutine call. The stack frame status after executing the CALL instruction is shown below. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |------------------------|------|---|---|---|---|------| | call label, regs, imm8 | | _ | _ | _ | _ | 5 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. The three operands of d16, regs and imm8 are used for the bit assignment. Normally, the multiple registers to be saved and the amount of area to be allocated are not specified (regs, imm8) directly by the assembler. Instead, these items are specified indirectly with a pseudo instruction in the callee and ultimately resolved by the linker. For details, refer to MN10300-series cross assembler user's manual. When the memory address (SP) is not a multiple of 4, a system exception (address misalignment exception) occurs. ## CALLS (An) ### Operation An -> nPC (next instruction PC) PC (current instruction address) + CodeSize -> mem32(SP) PC (current instruction address) + CodeSize -> MDR This instruction branches to the specified address after saving the return address (PC (current instruction address) + CodeSize) to the stack. CALLS is used together with RETS in order to maintain compatibility in the case of registers to be saved and the stack area to be allocated are unclear. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | calls (An) | | _ | _ | _ | _ | 2 | #### Flag change ### CALLS (d16, PC) #### Operation PC (current instruction address) + (sign-ext) d16 -> nPC (next instruction PC) PC (current instruction address) + CodeSize -> mem32(SP) PC (current instruction address) + CodeSize -> MDR This instruction branches to the specified address after saving the return address (PC (current instruction address) + CodeSize) to the stack. d16 is sign-extended and added to the PC(current instruction address), and the result is written into the nPC (next instruction PC). Even if the addition result overflows, this overflow is ignored and the result is written into the nPC (next instruction PC). CALLS is used together with RETS in order to maintain compatibility in the case of registers to be saved and the stack area to be allocated are unclear. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | calls label | | - | 1 | - | | 4 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### CALLS (d32, PC) #### Operation PC (current instruction address) + (sign-ext) d32 -> nPC (next instruction PC) PC (current instruction address) + CodeSize -> mem32(SP) PC (current instruction address) + CodeSize -> MDR This instruction branches to the specified address after saving the return address (PC (current instruction address) + CodeSize) to the stack. d32 is sign-extended and added to the PC(current instruction address), and the result is written into the nPC (next instruction PC). Even if the addition result overflows, this overflow is ignored and the result is written into the nPC (next instruction PC). CALLS is used together with RETS in order to maintain compatibility in the case of registers to be saved and the stack area to be allocated are unclear. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | calls label | | _ | _ | _ | - | 6 | #### Flag change ### Subroutine call ### RET regs, imm8 #### Operation mem32(SP + (zero-ext) imm8) -> nPC (next instruction PC) Lower address memory following mem32(SP + (zero-ext) imm8 - 4) -> Multiple registers specified by regs SP + (zero-ext) imm8 -> SP This instruction branches to the return address stored in the stack after restoring the saved multiple registers from the stack and deallocating the stack area. The multiple registers to be restored are specified by regs, and the area to be deallocated (number of bytes) are specified by imm8 (zero-extended). (Refer to MOVM for a detailed description of regs.) RET is used together with CALL to save and restore registers and allocate and deallocate the stack area quickly during returning from subroutine. When a subroutine doesn't update MDR, RETF makes returning operation from the subroutine faster. | Assembler mnemonic | V | С | Ν | Ζ | Size | |--------------------|---|---|---|---|------| | ret | _ | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. The two operands of regs and imm8 are used for the bit assignment. Normally, the multiple registers to be restored and the amount of area to be deallocated are not specified (regs, imm8) directly by the assembler. Instead, these items are specified indirectly with a pseudo instruction in the callee and ultimately resolved by the linker. For details, refer to MN103-series cross assembler user's manual. When the Mem address (SP) is not a multiple of 4, system exception (Address misalignment exception) occurs. ### RETF #### Operation MDR -> nPC (next instruction PC) Lower address memory following mem32(SP + (zero-ext) imm8 - 4) -> Multiple registers specified by regs SP + (zero-ext) imm8 -> SP This instruction branches to the return address stored in MDR after restoring the saved multiple registers to the stack and deallocating the stack area. The multiple registers to be restored are specified by regs, and the area to be deallocated (number of bytes) are specified by imm8 (zero-extended). (Refer to MOVM for a detailed description of regs.) RETF is used together with CALL in order to save and restore registers and allocate and deallocate the stack area quickly during returning from subroutine. When a subroutine doesn't update MDR, return operation from the subroutine cannot be assured (use RET). | Assembler mnemonic | V | С | Ν | Z | Size | |--------------------|---|---|---|---|------| | retf | _ | _ | _ | - | 3 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. The two operands of regs and imm8 are used for the bit assignment. Normally, the multiple registers to be restored and the amount of area to be deallocated are not specified (regs, imm8) directly by the assembler. Instead, these items are specified indirectly with a pseudo instruction in the callee and ultimately resolved by the linker. For details, refer to MN103-series cross assembler user's manual. ### Return from subroutine Operation mem32(SP) -> nPC (next instruction PC) This branches to the return address stored in the stack. RETS is used together with CALLS. This is also used in order to maintain compatibility (used in RTS). | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | rets | | _ | _ | _ | _ | 2 | Flag change ### Return from interrupt ### RTI (Privileged instruction) Operation mem32(SP) -> EPSW $mem32(SP + 4) \rightarrow nPC$ (next instruction PC) $SP + 8 \rightarrow SP$ This instruction returns from the interrupt, and branches to the return address stored in the stack after restoring the EPSW contained in the stack. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | rti | | Δ | Δ | Δ | Δ | 2 | Flag change VF: The V flag of the saved EPSW.V CF: The C flag of the saved EPSW.C NF: The N flag of the saved EPSW.N ZF: The Z flag of the saved EPSW.Z Interrupt control register TBR is set to 0x40000000 at reset. This instruction is a privileged instruction. If this instruction is executed at user level, system exception (privileged instruction execution exception) occurs. Access to EPSW[31:16] is possible only with EPSW at privilege level. EPSW.ML is set to 1 by restoring EPSW, when EPSW.ML=1 before restoring. ### Subroutine call to a specified address ### **TRAP** ### Operation { TBR[31:24], 0x000010 } -> nPC (next instruction PC) PC (current instruction address) + CodeSize -> mem32(SP) This instruction branches to the specified address (Base address set in TBR $\pm$ 0x10) after saving the PC of the next instruction to the stack. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | trap | | _ | _ | _ | _ | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. Interrupt control register TBR is set to 0x40000000 at reset. The privileged level has no change in this instruction. The priviledged level has no change in this instruction. When the priviledged level is changed from the user to supervisor levels, refer to SYSCALL. | NOP | | | | | | | | |-----------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------|---|---|---|---|------| | Operation | PC + CodeSize | -> PC | | | | | | | | No operations | are performed, and then the next instruction is executed. | | | | | | | Assemb | ler mnemonic | Note | ٧ | С | Ν | Ζ | Size | | nop | | | _ | _ | _ | _ | 1 | | | | Flag change | | | | | | | CF: Th<br>NF: T | his is not changed. This is not changed. This is not changed. This is not changed. | | | | | | | # SYSCALL System call instruction ### SYSCALL imm4 ### Operation PC (current instruction address) + CodeSize -> mem32(SP-4) $EPSW \rightarrow mem32(SP-8)$ SP - 8 -> SP { TBR[31:24], (0x000300 + imm4 x 8) } -> nPC (next instruction PC)Starts After nPC (the next instruction address) and EPSW are stored on to stack, it branches to specified address (Base address set in TBR + 0x300 +imm4 x 8). This instruction is used as system call (OS and library calling). | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | syscall imm4 | | _ | _ | _ | - | 2 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. Interrupt control register TBR is set to 0x40000000 at reset. The level is changed to the supervisor level after executing this instruction. Access to EPSW [31:16] is possible only with EPSW at the privileged level. ### Debug instruction | PI | | | | | | | | |-----------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---|---|---|---|------| | Operation | EPSW -> mem32(SF<br>SP - 8 -> SP<br>{ TBR[31:24], 0x00<br>This instruction is re | 0008 } -> nPC (next instruction PC) eserved by a debugger. Hemented instruction exception occurs when this | | | | | | | Assemble | r mnemonic | Note | V | С | N | Z | Size | | pi | | 1,000 | | - | - | - | 1 | | | | Flag change | ' | | 1 | | | | CF: This | s is not changed. s is not changed. is is not changed. s is not changed. | | | | | | | Interrupt control register TBR is set to 0x40000000 at reset. The level is changed to the supervisor level after executing this instruction. Access to EPSW [31:16] is possible only with EPSW at the privileged level. ### Extension operation instruction ## **DMULH** ## Signed dual multiplication operation ### DMULH Rm, Rn ### Operation (sign\_ext)Rm[31:16] \* (sign\_ext)Rn[31:16] -> MDRQ (sign\_ext)Rm[15:0] \* (sign\_ext)Rn[15:0] -> Rn This instruction multiplies the upper 16 bits of Rm (signed) by the upper 16 bits of Rn (signed), and the lower 16 bits of Rm(signed) by the lower 16bits of Rn (signed), and stores the result (32 bits) of multiplication of the upper 16 bits into MDRQ and the result (32 bits) of multiplication of the lower 16 bits into Rn. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmulh Rm, Rn | | - | _ | ı | _ | 3 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### DMULH Rm, Rn, Rd1, Rd2 #### Operation (sign\_ext)Rm[31:16] \* (sign\_ext)Rn[31:16] -> Rd1 (sign\_ext)Rm[15:0] \* (sign\_ext)Rn[15:0] -> Rd2 This instruction multiplies the upper 16 bits of Rm (signed) by the upper 16 bits of Rn (signed), and the lower 16 bits of Rm(signed) by the lower 16bits of Rn (signed), and stores the result (32 bits) of multiplication of the upper 16 bits into Rd1 and the result (32 bits) of multiplication of the lower 16 bits into Rd2. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------|-------------------------------|---|---|---|---|------| | dmulh Rm, Rn, Rd1, Rd2 | Rd1=Rd2 can not be specified. | _ | _ | _ | _ | 4 | Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When Rd1=Rd2 is specified, the operation result is undefined. ### DMULH imm, Rn ### Operation (sign\_ext)imm[31:16] \* (sign\_ext)Rn[31:16] -> MDRQ (sign\_ext)imm[15:0] \* (sign\_ext)Rn[15:0] -> Rn This instruction multiplies the upper 16 bits of imm (signed) by the upper 16 bits of Rn (signed), and the lower 16 bits of imm(signed) by the lower 16bits of Rn (signed), and stores the result (32 bits) of multiplication of the upper 16 bits into MDRQ and the result (32 bits) of multiplication of the lower 16 bits into Rn. | Assembler mnemonic | Note | ٧ | С | Ζ | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmulh imm32, Rn | | _ | _ | - | 1 | 7 | #### Flag change # Unsigned dual multiplication operation ### DMULHU Rm, Rn ### Operation (zero\_ext)Rm[31:16] \* (zero\_ext)Rn[31:16] -> MDRQ (zero\_ext)Rm[15:0] \* (zero\_ext)Rn[15:0] -> Rn This instruction multiplies the upper 16 bits of Rm (unsigned) by the upper 16 bits of Rn (unsigned), and the lower 16 bits of Rm(unsigned) by the lower 16bits of Rn (unsigned), and stores the result (32 bits) of multiplication of the upper 16 bits into MDRQ and the result (32 bits) of multiplication of the lower 16 bits into Rn. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmulhu Rm, Rn | | _ | _ | - | _ | 3 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### DMULHU Rm, Rn, Rd1, Rd2 #### Operation (zero\_ext)Rm[31:16] \* (zero\_ext)Rn[31:16] -> Rd1 (zero\_ext)Rm[15:0] \* (zero\_ext)Rn[15:0] -> Rd2 This instruction multiplies the upper 16 bits of Rm (unsigned) by the upper 16 bits of Rn (unsigned), and the lower 16 bits of Rm(unsigned) by the lower 16bits of Rn (unsigned), and stores the result (32 bits) of multiplication of the upper 16 bits into Rd1 and the result (32 bits) of multiplication of the lower 16 bits into Rd2. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-------------------------|-------------------------------|---|---|---|---|------| | dmulhu Rm, Rn, Rd1, Rd2 | Rd1=Rd2 can not be specified. | _ | _ | _ | - | 4 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When Rd1=Rd2 is specified, the operation result is undefined. ### DMULHU imm, Rn ### Operation (zero\_ext)imm[31:16] \* (zero\_ext)Rn[31:16] -> MDRQ $(zero\_ext)imm[15:0] * (zero\_ext)Rn[15:0] -> Rn$ This instruction multiplies the upper 16 bits of imm (unsigned) by the upper 16 bits of Rn (unsigned), and the lower 16 bits of imm(unsigned) by the lower 16bits of Rn (unsigned), and stores the result (32 bits) of multiplication of the upper 16 bits into MDRQ and the result (32 bits) of multiplication of the lower 16 bits into Rn. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmulhu imm32, Rn | | _ | - | _ | _ | 7 | #### Flag change ## Signed dual multiply-and-accumulate operation ### DMACH Rm, Rn #### Operation (sign\_ext)Rm[31:16] \* (sign\_ext)Rn[31:16] + (sign\_ext)Rm[15:0] \* (sign\_ext)Rn[15:0] + MCRL -> MCRL This instruction multiplies the upper 16 bits of Rm (signed) by the upper 16 bits of Rn (signed), and the lower 16 bits of Rm (signed) by the lower 16bits of Rn (signed). And then, it adds the result (32 bits) of multiplication of the upper 16 bits, the result (32 bits) of the lower 16 bits and the cumulative sum (32 bits) which is stored in MCRL, and stores the operation result into MCRL. When that operation result overflows, MCVF is set to 1. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | dmach Rm, Rn | | ı | _ | _ | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### DMACH Rm, Rn, Rd ### Operation (sign\_ext)Rm[31:16] \* (sign\_ext)Rn[31:16] +(sign\_ext)Rm[15:0] \* (sign\_ext)Rn[15:0] & 0x0000FFFF)-> Rd This instruction multiplies the upper 16bits of Rm (signed) by the upper 16 bits of Rn (signed), and the lower 16 bits of Rm (signed) by the lower 16bits of Rn (signed). And then, it adds the result (32 bits) of multiplication of the upper 16 bits, the result (32 bits) of the lower 16 bits and the cumulative sum (32 bits) which is stored in Rd, and the operation result into Rd. When that operation result overflows, MCVF is set to 1. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmach Rm, Rn, Rd | | Δ | _ | _ | - | 4 | ### Flag change VF: If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, this is set to 1. In all other cases, it keeps the previous condition. CF: This is not changed. NF: This is not changed. ZF: This is not changed. DMACH 141 ## DMACH imm, Rn ### Operation $(sign_ext)imm32[31:16] * (sign_ext)Rn[31:16] + (sign_ext)imm32[15:0] *$ $(sign_ext)Rn[15:0] + MCRL \rightarrow MCRL$ This instruction multiplies the upper 16bits of imm(signed) by the upper 16 bits of Rn (signed), and the lower 16 bits of imm (signed) by the lower 16bits of Rn (signed). And then, it adds the result (32 bits) of multiplication of the upper 16 bits, the result (32 bits) of the lower 16 bits and the cumulative sum (32 bits) which is stored in MCRL, and the operation result into MCRL. When that operation result overflows, MCVF is set to 1. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmach imm32, Rn | | - | - | _ | _ | 7 | ### Flag change ## and-accumulate operation ### DMACHU Rm, Rn #### Operation (zero ext)Rm[31:16] \* (zero ext)Rn[31:16] + (zero\_ext)Rm[15:0] \* (zero\_ext)Rn[15:0] + MCRL -> MCRL This instruction multiplies the upper 16 bits of Rm (unsigned) by the upper 16 bits of Rn (unsigned), and the lower 16 bits of Rm (unsigned) by the lower 16bits of Rn (unsigned). And then, it adds the result (32 bits) of multiplication of the upper 16 bits, the result (32 bits) of the lower 16 bits and the cumulative sum (32 bits) which is stored in MCRL, and stores the operation result into MCRL. When that operation result overflows, MCVF is set to 1. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmachu Rm, Rn | | _ | _ | - | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### DMACHU Rm, Rn, Rd #### Operation (zero ext)Rm[31:16] \* (zero ext)Rn[31:16] +(zero ext)Rm[15:0] \* (zero ext)Rn[15:0] + Rd -> Rd This instruction multiplies the upper 16bits of Rm (unsigned) by the upper 16 bits of Rn (unsigned), and the lower 16 bits of Rm (unsigned) by the lower 16bits of Rn (unsigned). And then, it adds the result (32 bits) of multiplication of the upper 16 bits, the result (32 bits) of the lower 16 bits and the cumulative sum (32 bits) which is stored in Rd, and the operation result into Rd. When that operation result overflows, MCVF is set to 1. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmachu Rm, Rn, Rd | | Δ | _ | _ | _ | 4 | #### Flag change VF: If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, this is set to 1. In all other cases, it keeps the previous condition. CF: This is not changed. NF: This is not changed. ZF: This is not changed. DMACHU 143 ## DMACHU imm, Rn ### Operation ``` (zero_ext)imm32[31:16] * (zero_ext)Rn[31:16] + (zero_ext)imm32[15:0] * (zero_ext)Rn[15:0] + MCRL -> MCRL ``` This instruction multiplies the upper 16bits of imm(unsigned) by the upper 16 bits of Rn (unsigned), and the lower 16 bits of imm (unsigned) by the lower 16bits of Rn (unsigned). And then, it adds the result (32 bits) of multiplication of the upper 16 bits, the result (32 bits) of the lower 16 bits and the cumulative sum (32 bits) which is stored in MCRL, and the operation result into MCRL. When that operation result overflows, MCVF is set to 1. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | dmachu imm32, Rn | | - | - | _ | _ | 7 | ### Flag change ## Signed multiply-and-accumulate operation ### MAC Rm, Rn ### Operation $(Rm * Rn) + \{MCRH, MCRL\} \rightarrow \{MCRH, MCRL\}$ This instruction multiplies the contents of Rm (signed) and Rn (signed), and adds the result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRH and MCRL respectively. And then the upper 32 bits of the operation result are stored into MCRH, and the lower 32 bits of that result are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF is set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | mac Rm, Rn | | - | _ | _ | | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MAC Rm, Rn, Rd1, Rd2 ### Operation $(Rm * Rn) + \{Rd1, Rd2\} \rightarrow \{Rd1, Rd2\}$ This instruction multiplies the contents of Rm (signed) and Rn (signed), and adds the result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in Rd1 and Rd2 respectively. And then the upper 32 bits of the operation result are stored into Rd1, and the lower 32 bits of that result are stored into Rd2. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF is set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |----------------------|------------------------------|---|---|---|---|------| | mac Rm, Rn, Rd1, Rd2 | Rd1=Rd2 can not be specified | Δ | _ | _ | - | 4 | #### Flag change VF: If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, this is set to 1. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ## MAC imm, Rn ### Operation ((sign\_ext)imm \* Rn) + {MCRH, MCRL} -> {MCRH, MCRL} This instruction multiplies the contents of the 32 bit-data which is obtained by sign-extending imm by the contents of Rn (signed), and adds the result to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits of the result are stored into MCRH and MCRL respectively. And then, the upper 32 bits of the operation result are stored into MCRH, and the lower 32 bits of that result are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF is set to 1. In all other cases, it keeps the previous condition. | | Assembler mnemonic | Note | V | С | Ν | Z | Size | |-----|--------------------|-------------------------|---|---|---|---|------| | mac | imm8, Rn | imm8 is sign-extended. | - | - | - | - | 4 | | mac | imm24, Rn | imm24 is sign-extended. | 1 | 1 | - | - | 6 | | mac | imm32, Rn | | - | - | - | - | 7 | ### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF : This is not changed. ## Unsigned multiply-and-accumulate operation ### MACU Rm, Rn Operation $(Rm * Rn) + \{MCRH, MCRL\} \rightarrow \{MCRH, MCRL\}$ This instruction multiplies the contents of Rm (unsigned) and Rn (unsigned), and adds the result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRH and MCRL respectively. And then the upper 32 bits of the operation result are stored into MCRH, and the lower 32 bits of that result are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF is set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | macu Rm, Rn | | _ | _ | _ | | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MACU Rm, Rn, Rd1, Rd2 Operation $(Rm * Rn) + \{Rd1, Rd2\} \rightarrow \{Rd1, Rd2\}$ This instruction multiplies the contents of Rm (unsigned) and Rn (unsigned), and adds the result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in Rd1 and Rd2 respectively. And then, the upper 32 bits of the operation result are stored into Rd1, and the lower 32 bits of that result are stored into Rd2. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF is set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | V | С | N | Ζ | Size | |-----------------------|------------------------------|---|---|---|---|------| | macu Rm, Rn, Rd1, Rd2 | Rd1=Rd2 can not be specified | Δ | - | - | _ | 4 | Flag change VF: If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, this is set to 1. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When Rd1=Rd2 is specified, the operation result is undefined. ### MACU imm, Rn ### Operation ((zero\_ext)imm \* Rn) + {MCRH, MCRL} -> {MCRH, MCRL} This instruction multiplies the contents of the 32 bit-data which is obtained by zero-extending imm by the contents of Rn (unsigned), and adds the result to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits of the result are stored into MCRH and MCRL respectively. And then, the upper 32 bits of the operation result are stored into MCRH, and the lower 32 bits of that result are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF is set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | V | С | N | Z | Size | |--------------------|-------------------------|---|---|---|---|------| | macu imm8, Rn | imm8 is sign-extended. | - | - | - | 1 | 4 | | macu imm24, Rn | imm24 is sign-extended. | - | - | - | 1 | 6 | | macu imm32, Rn | | - | - | - | - | 7 | ### Flag change ### Signed half-word multiply-and-accumulate operation ### MACH Rm, Rn #### Operation $((sign_ext)Rm[15:0] * (sign_ext)Rn[15:0]) + \{MCRH, MCRL\} -> \{MCRH, MCRL\}$ This instruction multiplies the 32-bit data which is obtained by sign-extending the lower 16 bits of Rm by the 32-bit data which is obtained by sign-extending the lower 16 bits of Rn, and adds that result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRH and MCRL respectively. The upper 32 bits of operation result (64 bits) are stored into MCRH and the lower 32 bits are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | > | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | mach Rm, Rn | | - | _ | | | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MACH Rm, Rn, Rd1, Rd2 ### Operation $((sign ext)Rm[15:0] * (sign ext)Rn[15:0]) + \{Rd1, Rd2\} -> \{Rd1, Rd2\}$ This instruction multiplies the 32-bit data which is obtained by sign-extending the lower16 bits of Rm and the 32-bit data which is obtained by sign-extending the lower 16 bits of Rn, and adds that result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in Rd1 and Rd2 respectively. The upper 32 bits of operation result (64 bits) are stored into Rd1 and the lower 32 bits are stored into Rd2. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | N | ١,/ | | N | 7 | Size | |-----------------------|------------------------------|-----|---|---|---|------| | Assembler inhemonic | Note | V | C | I | | Size | | mach Rm, Rn, Rd1, Rd2 | Rd1=Rd2 can not be specified | Δ | 1 | ı | | 4 | #### Flag change VF: If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, this is set to 1. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When Rd1=Rd2 is specified, the operation result is undefined. ### MACH imm, Rn ### Operation $((sign\_ext)imm[15:0] * (sign\_ext)Rn[15:0]) + \{MCRH, MCRL\} -> \{MCRH, MCRL\}$ This instruction multiplies the 16-bit data which is obtained by sign-extending imm and the 32-bit data which is obtained by sign-extending the lower 16 bits of Rn, and adds that result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRH and MCRL respectively. The upper 32 bits of operation result (64 bits) are stored into MCRH and the lower 32 bits are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | V | С | N | Z | Size | |--------------------|------------------------|---|---|---|---|------| | mach imm8, Rn | imm8 is sign-extended. | - | - | - | - | 4 | | mach imm24, Rn | | - | - | - | - | 6 | | mach imm32, Rn | | - | - | - | - | 7 | ### Flag change ### Unsigned half-word multiplyand-accumulate operation ### MACHU Rm, Rn #### Operation ((zero\_ext)Rm[15:0] \* (zero\_ext)Rn[15:0]) + {MCRH, MCRL} -> {MCRH, MCRL} This instruction multiplies the 32-bit data which is obtained by zero-extending the lower 16 bits of Rm by the 32-bit data which is obtained by zero-extending the lower 16 bits of Rn, and adds that result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRH and MCRL respectively. The upper 32 bits of operation result (64 bits) are stored into MCRH and the lower 32 bits are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | machu Rm, Rn | | _ | 1 | - | | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MACHU Rm, Rn, Rd1, Rd2 ### Operation $((zero ext)Rm[15:0] * (zero ext)Rn[15:0]) + {Rd1, Rd2} -> {Rd1, Rd2}$ This instruction multiplies the 32-bit data which is obtained by zero-extending the lower 16 bits of Rm and the 32-bit data which is obtained by zero-extending the lower 16 bits of Rn, and adds that result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in Rd1 and Rd2 respectively. The upper 32 bits of operation result (64 bits) are stored into Rd1 and the lower 32 bits are stored into Rd2. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------|------------------------------|---|---|---|---|------| | machu Rm, Rn, Rd1, Rd2 | Rd1=Rd2 can not be specified | Δ | _ | ı | _ | 4 | #### Flag change VF: If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, this is set to 1. CF: This is not changed. NF: This is not changed. ZF: This is not changed. When Rd1=Rd2 is specified, the operation result is undefined. ### MACHU imm, Rn ### Operation $((zero\_ext)imm[15:0] * (zero\_ext)Rn[15:0]) + \{MCRH, MCRL\} -> \{MCRH, MCRL\}$ This instruction multiplies the 16-bit data which is obtained by zero-extending imm and the 32-bit data which is obtained by zero-extending the lower 16 bits of Rn, and adds that result (64 bits) to the cumulative sum (64 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRH and MCRL respectively. The upper 32 bits of operation result (64 bits) are stored into MCRH and the lower 32 bits are stored into MCRL. If the cumulative sum data overflows out of 64 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------------------------|---|---|---|---|------| | machu imm8, Rn | imm8 is sign-extended. | - | - | - | - | 4 | | machu imm24, Rn | | - | 1 | - | - | 6 | | machu imm32, Rn | | - | - | - | - | 7 | ### Flag change ## Signed byte multiply-and-accumulate operation ### MACB Rm, Rn #### Operation (sign ext)Rm[7:0] \* (sign ext)Rn[7:0]) + MCRL -> MCRL This instruction multiplies the 32-bit data which is obtained by sign-extending the lower 8 bits of Rm by the 32-bit data which is obtained by sign-extending the lower 8 bits of Rn, and adds that result (32 bits) to the cumulative sum (32 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRL respectively. The operation result (32 bits) are stored into MCRL and the lower 32 bits are stored into MCRL. If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | V | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | macb Rm, Rn | | - | 1 | - | _ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MACB Rm, Rn, Rd #### Operation (sign ext)Rm[7:0] \* (sign ext)Rn[7:0]) + Rd -> Rd This instruction multiplies the 32-bit data which is obtained by sign-extending the lower 8 bits of Rm and the 32-bit data which is obtained by sign-extending the lower 8 bits of Rn, and adds that result (32 bits) to the cumulative sum (32 bits) stored in Rd. The operation result (32 bits) are stored into Rd. If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------------------------------|---|---|---|---|------| | macb Rm, Rn, Rd | Rd1=Rd2 can not be specified | Δ | ı | _ | _ | 4 | ### Flag change VF: If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, this is set to 1. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MACB imm, Rn ### Operation $((sign_ext)imm[7:0] * (sign_ext)Rn[7:0]) + MCRL -> MCRL$ This instruction multiplies the 8-bit data of imm and the 32-bit data which is obtained by sign-extending the lower 8 bits of Rn, and adds that result (64 bits) to the cumulative sum (32 bits) of which the upper 32 bits and the lower 32 bits are stored in MCRH and MCRL respectively. The operation result (32 bits) are stored into MCRL. If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | 11 | | | | | | | |--------------------|------|---|---|---|---|------| | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | | macb imm8, Rn | | - | ı | - | 1 | 4 | | macb imm24, Rn | | - | 1 | - | 1 | 6 | | macb imm32, Rn | | - | - | - | - | 7 | ### Flag change ### Unsigned byte-data multiplyand-accumulate operation ### MACBU Rm, Rn #### Operation $(zero_ext)Rm[7:0] * (zero_ext)Rn[7:0]) + MCRL \rightarrow MCRL$ This instruction multiplies the 32-bit data which is obtained by zero-extending the lower 8 bits of Rm by the 32-bit data which is obtained by zero-extending the lower 8 bits of Rn, and adds that result (32 bits) to the cumulative sum (32 bits) stored in MCRL. The operation result (32 bits) are stored into MCRL. If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|------|---|---|---|---|------| | macbu Rm, Rn | | - | - | - | - | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. ### MACBU Rm, Rn, Rd #### Operation ((zero ext)Rm[7:0] \* (zero ext)Rn[7:0]) + Rd -> Rd This instruction multiplies the 32-bit data which is obtained by zero-extending the lower 8 bits of Rm and the 32-bit data which is obtained by zero-extending the lower 8 bits of Rn, and adds that result (32 bits) to the cumulative sum (32 bits) stored in Rd. The operation result (32 bits) are stored into Rd. If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | > | С | Ν | Z | Size | |--------------------|------------------------------|---|---|---|---|------| | macbu Rm, Rn, Rd | Rd1=Rd2 can not be specified | Δ | _ | _ | _ | 4 | #### Flag change VF: If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, this is set to 1. CF: This is not changed. NF: This is not changed. $ZF:\mbox{\footnotemath{\text{This}}}$ is not changed. ### MACBU imm, Rn ### Operation ((zero\_ext)imm[7:0] \* (zero\_ext)Rn[7:0]) + MCRL -> MCRL This instruction multiplies the 8-bit data of imm and the 32-bit data which is obtained by zero-extending the lower 8 bits of Rn, and adds that result (32 bits) to the cumulative sum (32 bits) are stored in MCRL respectively. The operation result (32 bits) are stored into MCRL. If the cumulative sum data overflows out of 32 bits when adding the product and the cumulative sum, MCVF are set to 1. In all other cases, it keeps the previous condition. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | macbu imm8, Rn | | - | ı | - | - | 4 | | macbu imm24, Rn | | - | 1 | - | - | 6 | | macbu imm32, Rn | | - | - | - | - | 7 | ### Flag change ## Data swapping instruction between the upper 2 bytes and lower 2 bytes ### SWHW Rm, Rn ### Operation $Rm[31:16] \rightarrow Rn[15:0]$ $Rm[15:0] \rightarrow Rn[31:16]$ This instruction swaps the contents of the upper 16 bits and lower 16 bits of Rm, and stores the operation result (32 bits) in Rn. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | swhw Rm, Rn | | _ | _ | - | _ | 3 | ### Flag change ## Data swapping instruction between the upper and lower of the 4-byte data in byte unit ### SWAP Rm, Rn Operation Rm[31:24] -> Rn[7:0] Rm[23:16] -> Rn[15:8] Rm[15:8] -> Rn[23:16] Rm[7:0] -> Rn[31:24] This instruction swaps the upper and lower 16 bits of Rm after swapping the upper 8 bits and lower 8 bits both in the upper and lower 16 bits of Rm, and then stores the result in Rn. Execution example: Before execution Rm=0x12345678 -> After execution Rn=0x78563412 | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | swap Rm, Rn | | - | 1 | 1 | _ | 3 | #### Flag change # **SWAPH** Data swapping instruction between the upper ## and lower of the 2-byte data in byte unit ### SWAPH Rm, Rn Operation $Rm[31:24] \rightarrow Rn[23:16]$ Rm[23:16] -> Rn[31:24] $Rm[15:8] \rightarrow Rn[7:0]$ Rm[7:0] -> Rn[15:8] This instruction swaps the upper 8 bits and lower 8 bits both in the upper and lower 16 bits of Rm, and then stores the result in Rn. Execution example: Before execution Rm=0x12345678 -> After execution Rn=0x34127856 | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|------|---|---|---|---|------| | swaph Rm, Rn | | - | _ | _ | _ | 3 | ### Flag change # SAT16 ### 16-bit saturation operation instruction ### SAT16 Rm, Rn #### Operation - 1) equal or bigger than maximum positive value (0x00007FFFF) for 16-bit signed number, $0x00007FFFF \rightarrow Rn$ - 2) equal or smaller than minimum negative value (0xFFFF8000) for 16-bit signed number, 0xFFFF8000 -> Rn - 3) other than 1) or 2), $Rm \rightarrow Rn$ - 1) equal or bigger than maximum positive value (0x00007FFFF) for 16-bit signed number, the maximum positive value (0x00007FFFF) is stored into Rn. - 2) equal or smaller than minimum negative value (0xFFFF8000) for 16-bit signed number, the minimum negative value (0xFFFF8000) is stored into Rn. - 3) other than 1) or 2), the contents of Rm are stored into Rn. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|------|---|---|---|---|------| | sat16 Rm, Rn | | ? | ? | Δ | Δ | 3 | #### Flag change VF: This is not changed. CF: This is not changed. NF: "1" when the MSB of the operation result is "1", "0" in all other cases. ZF: "1" when the operation result is "0", "0" in all other cases. #### 24-bit saturation operation instruction ## SAT24 Rm, Rn #### Operation - 1) equal or bigger than maximum positive value (0x007FFFFFF) for 24-bit signed number, 0x007FFFFFF -> Rn - 2) equal or smaller than minimum negative value (0xFF800000) for 24-bit signed number, $0xFF800000 \rightarrow Rn$ - 3) other than 1) or 2), $Rm \rightarrow Rn$ - 1) equal or bigger than maximum positive value (0x007FFFFF) for 16-bit signed number, the maximum positive value (0x007FFFFF) is stored into Rn. - 2) equal or smaller than minimum negative value (0xFF800000) for 16-bit signed number, the minimum negative value (0xFF800000) is stored into Rn. - 3) other than 1) or 2), the contents of Rm are stored into Rn. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|------|---|---|---|---|------| | sat24 Rm, Rn | | ? | ? | Δ | Δ | 4 | #### Flag change VF: This is not changed. CF: This is not changed. NF: "1" when the MSB of the operation result is "1", "0" in all other cases. ZF: "1" when the operation result is "0", "0" in all other cases. ## for the multiply-and-accumulate result ## MCSTE Rm, Rn #### Operation This instruction sets the value of the multiply-and-accumulate operation overflow, and stores the result into the V flag. In addition, depending on the value of Rm, the following instructions are performed. #### 1) When the set value is 32 (0x00000020) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 32-bit signed number (0x00000007FFFFFFF), the maximum positive value (0x7fffffff) is stored in Rn. 0x7ffffffff-> Rn If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 32-bit signed number (0xfffffff80000000), the maximum negative value (0x80000000) is stored in Dn. 0x80000000 ->Rn In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn #### 2) When the set value is $16 (0 \times 00000010)$ When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 16-bit signed number (0x00000000007FFF), the maximum positive value (0x7fff) is stored in Rn. $0x7fff \rightarrow Rn$ If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 16-bit signed number (0xfffffffff8000), the maximum negative value (0xFFFF8000) is stored in Rn. $0xffff8000 \rightarrow Rn$ In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn #### 3) When the set value is 8 (0x00000008) When the 32-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for an 8-bit signed number (0x0000007F), the maximum positive value (0x0000007f) is stored in Rn. 0x0000007f -> Rn If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for an 8-bit signed number (0xffffff80), the maximum negative value (0xffffff80) is stored in Rn. 0xffffff80 -> Rn In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn #### Operation 4) When the set value is $9(0\times00000009)$ , When the 32-bit result of the multiply-and-accumulate operation that is stored in the multiplyand-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 9-bit signed number (0x000000ff), the maximum positive value (0xff) is stored in Rn. $$0xff -> Rn$$ If the value stored in the lower 31bits of the multiply-and-accumulate register MCRL is equal to or less than 0, 0(0x00000000) is stored in Rn. 0x000000000 -> Rn In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn 4) When the set value is 48 (0x00000030) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiplyand-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 48-bit signed number (0x00007fffffffffff), the bits from 47 to 16 are stored in Rn as the operation result. $0x7ffffffff \rightarrow Rn$ If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 48-bit signed number (0xffff80000000000), the bits from 47 to 16 are stored in Rn as the operation result. 0x800000000 -> Rn In all other cases, the values from the bits 16 to 47 of MCRH and MCRL are stored in Rn. {MCRH[15:0], MCRL[31:16] -> Rn[31:0] 5) When the set value is other than the above-mentioned values, Rn is undefined. | Assemble | er mnemonic | Note | V | С | Ζ | Z | Size | | | |-------------|-------------|-----------------------------------------------------------------------------|---|---|---|---|------|--|--| | mcste Rm, R | | When multiply-and-accumulate operation overflow was not detected (MCVF = 0) | 0 | 0 | ? | ? | 3 | | | | | | When multiply-and-accumulate operation overflow was detected (MCVF = 1) | 1 | 0 | ? | ? | 3 | | | #### Flag change When multiply-and-accumulate operation overflow was not detected VF: This is "0" and indicates that the multiply-and-accumulate operation is valid. CF: Always "0" NF: Undefined ZF: Undefined When multiply-and-accumulate operation overflow was detected VF: This is "1" and indicates that the multiply-and-accumulate operation is invalid. CF: Always "0" NF: Undefined ZF: Undefined ### MCSTE imm, Rn #### Operation This instruction sets the value of the multiply-and-accumulate operation overflow, and stores the result into the V flag. In addition, depending on the value of imm, the following instructions are performed. #### 1) When the set value is 32 (0x00000020) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 32-bit signed number (0x000000007FFFFFFF), the maximum positive value (0x7fffffff) is stored in Rn. 0x7ffffffff-> Rn If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 32-bit signed number (0xffffff80000000), the maximum negative value (0x80000000) is stored in Dn. 0x80000000 ->Rn In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn #### 2) When the set value is 16 (0x00000010) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 16-bit signed number (0x0000000000007FFF), the maximum positive value (0x7fff) is stored in Rn. $$0x7fff \rightarrow Rn$$ If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 16-bit signed number (0xffffffffffff8000), the maximum negative value (0xFFFF8000) is stored in Rn. 0xffff8000 -> Rn In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn #### 3) When the set value is 8 (0x00000008) When the 32-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for an 8-bit signed number (0x0000007F), the maximum positive value (0x0000007f) is stored in Rn. 0x0000007f -> Rn If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for an 8-bit signed number (0xffffff80), the maximum negative value (0xffffff80) is stored in Rn. 0xffffff80 -> Rn In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn #### Operation 4) When the set value is $9(0 \times 00000009)$ , When the 32-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 9-bit signed number (0x000000ff), the maximum positive value (0xff) is stored in Rn. $$0xff -> Rn$$ If the value stored in the multiply-and-accumulate register MCRL is equal to or less than 0, the maximum negative value 0(0x00000000) is stored in Rn. 0x000000000 -> Rn In all other cases, the lower 31 bits of MCRL are stored in Rn. MCRL -> Rn 4) When the set value is 48 (0x00000030) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 48-bit signed number (0x00007ffffffffffff), the bits from 47 to 16 are stored in Rn as the operation result. If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 48-bit signed number (0xffff800000000000), the bits from 47 to 16 are stored in Rn as the operation result. $$0x80000000 -> Rn$$ In all other cases, the values from the bits 16 to 47 of MCRH and MCRL are stored in Rn. 5) When the set value is other than the above-mentioned values, Rn is undefined. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|-----------------------------------------------------------------------------|---|---|---|---|------| | mcste imm8, Rn | When multiply-and-accumulate operation overflow was not detected (MCVF = 0) | 0 | 0 | ? | ? | 4 | | | When multiply-and-accumulate operation overflow was detected (MCVF = 1) | 1 | 0 | ? | ? | 4 | #### Flag change When multiply-and-accumulate operation overflow was not detected VF: This is "0" and indicates that the multiply-and-accumulate operation is valid. CF: Always "0" NF: Undefined ZF: Undefined When multiply-and-accumulate operation overflow was detected VF: This is "1" and indicates that the multiply-and-accumulate operation is invalid. CF: Always "0" NF: Undefined ZF: Undefined #### Bit search instruction ## BSCH Rm, Rn #### Operation This instruction conducts a bit search within the 32-bit bit string stored in Rm, starting from the bit position of the bit number indicated by the contents of (Rn - 1) in the direction of descending bit numbers. The bit number of the first bit position where a "1" is found is then stored in Rn. When the least significant five bits of Rm are zeroes, the bit search is conducted from bit 31 in the direction of descending bit numbers. If the bit search reaches bit 0 without finding a "1", the "C" flag is set, 0 is written in Rn. When execution of this instruction starts, the upper 27 bits of Rn are ignored. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|----------------------------------------------------------------|---|---|---|---|------| | bsch Rm, Rn | When the search operation was succeeded ("1" is found) | ? | 0 | ? | ? | 3 | | | When the search operation was not succeeded ("1" is not found) | ? | 1 | ? | ? | 3 | #### Flag change When the search operation was succeeded VF: Undefined CF: This is "0" and indicates that the search operation is succeeded. NF: Undefined ZF: Undefined When the search operation was not succeeded VF: Undefined CF: This is "1" and indicates that the search operation is not succeeded. NF: Undefined ZF: Undefined ## BSCH Rm, Rn, Rd #### Operation This instruction conducts a bit search within the 32-bit bit string stored in Rm, starting from the bit position of the bit number indicated by the contents of (Rn - 1) in the direction of descending bit numbers. The bit number of the first bit position where a "1" is found is then stored in Rn. When the least significant five bits of Rm are zeroes, the bit search is conducted from bit 31 in the direction of descending bit numbers. If the bit search reaches bit 0 without finding a "1", the "C" flag is set, 0 is written in Rn. When execution of this instruction starts, the upper 27 bits of Rn are ignored. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|----------------------------------------------------------------|---|---|---|---|------| | bsch Rm, Rn, Rd | When the search operation was succeeded ("1" is found) | ? | 0 | ? | ? | 4 | | | When the search operation was not succeeded ("1" is not found) | ? | 1 | ? | ? | 4 | #### Flag change When the search operation was succeeded VF: Undefined CF: This is "0" and indicates that the search operation is succeeded. NF: Undefined ZF: Undefined When the search operation was not succeeded VF: Undefined CF: This is "1" and indicates that the search operation is not succeeded. NF: Undefined ZF: Undefined ## $ADD \ \ OP2$ Parallel execution of addition ## and OP2 #### ADD OP2 Rm1, Rn1, Rm2, Rn2 #### Operation $[Rm1 + Rn1 \rightarrow Rn1]$ with op2 This performs the paralell execution of the addition between the register (Rm1) and the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | O | Z | Ζ | Size | |----------------------------|--------------------------------------------|---|---|---|---|------| | add_add Rm1, Rn1, Rm2, Rn2 | Same as add_add of the OP1_ADD instruction | - | - | - | - | 4 | | add_sub_Rm1, Rn1, Rm2, Rn2 | Same as add_sub of the OP1_SUB instruction | 1 | - | - | - | 4 | | add_cmp Rm1, Rn1, Rm2, Rn2 | Same as add_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | add_mov Rm1, Rn1, Rm2, Rn2 | Same as add_mov of the OP1_MOV instruction | - | - | - | - | 4 | | add_asr Rm1, Rn1, Rm2, Rn2 | Same as add_asr of the OP1_ASR instruction | - | - | - | - | 4 | | add_lsr Rm1, Rn1, Rm2, Rn2 | Same as add_Isr of the OP1_LSR instruction | - | - | - | - | 4 | | add_asl Rm1, Rn1, Rm2, Rn2 | Same as add_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # instruction ## ADD\_OP2 Rm1, Rn1, imm, Rn2 #### Operation $[Rm1 + Rn1 \rightarrow Rn1]$ with op2 This performs the paralell execution of the addition between the register (Rm1) and the register (Rn1) and the op2 operation between the immediate value (imm) and the register (Rn2). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_add Rm1, Rn1, imm4, Rn2 | Same as add_add of the OP1_ADD instruction | - | - | - | - | 4 | | add_sub_Rm1, Rn1, imm4, Rn2 | Same as add_sub of the OP1_SUB instruction | - | - | - | - | 4 | | add_cmp Rm1, Rn1, imm4, Rn2 | Same as add_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | add_mov Rm1, Rn1, imm4, Rn2 | Same as add_mov of the OP1_MOV instruction | - | - | - | - | 4 | | add_asr Rm1, Rn1, imm4, Rn2 | Same as add_asr of the OP1_ASR instruction | - | - | - | - | 4 | | add_lsr Rm1, Rn1, imm4, Rn2 | Same as add_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | add_asl Rm1, Rn1, imm4, Rn2 | Same as add_asl of the OP1_ASL instruction | - | - | ı | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### ADD\_OP2 imm, Rn1, Rm2, Rn2 #### Operation $[(sign\_ext)imm4 + Rn1 \rightarrow Rn1]$ with op2 This performs the paralell execution of the addition between the sign-extended immediate value (imm4) and the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | O | Z | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_add imm4, Rn1, Rm2, Rn2 | Same as add_add of the OP1_ADD instruction | - | - | - | - | 4 | | add_sub_imm4, Rn1, Rm2, Rn2 | Same as add_sub of the OP1_SUB instruction | 1 | 1 | | - | 4 | | add_cmp imm4, Rn1, Rm2, Rn2 | Same as add_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | add_mov_imm4, Rn1, Rm2, Rn2 | Same as add_mov of the OP1_MOV instruction | | 1 | | - | 4 | | add_asr imm4, Rn1, Rm2, Rn2 | Same as add_asr of the OP1_ASR instruction | - | - | - | - | 4 | | add_lsr imm4, Rn1, Rm2, Rn2 | Same as add_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | add_asl_imm4, Rn1, Rm2, Rn2 | Same as add_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## ADD\_OP2 imm, Rn1, imm, Rn2 #### Operation [(sign\_ext)imm4\* + Rn1 -> Rn1] with op2 (\* : 1st operand) This performs the paralell execution of the addition between the sign-extended immediate value (imm4) and the register (Rn1) and the op2 operation between the immediate value (imm) and the register (Rn2). | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_add imm4, Rn1, imm4, Rn2 | Same as add_add of the OP1_ADD instruction | - | - | - | - | 4 | | add_sub_imm4, Rn1, imm4, Rn2 | Same as add_sub of the OP1_SUB instruction | - | - | - | - | 4 | | add_cmp imm4, Rn1, imm4, Rn2 | Same as add_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | add_mov_imm4, Rn1, imm4, Rn2 | Same as add_mov of the OP1_MOV instruction | - | - | - | | 4 | | add_asr imm4, Rn1, imm4, Rn2 | Same as add_asr of the OP1_ASR instruction | - | - | - | - | 4 | | add_lsr_imm4, Rn1, imm4, Rn2 | Same as add_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | add_asl_imm4, Rn1, imm4, Rn2 | Same as add_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## son and OP2 ## CMP OP2 Rm1, Rn1, Rm2, Rn2 #### Operation [Rn1 - Rm1] with op2 This performs the paralell execution of the comparison between the register (Rm1) and the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | O | Ν | Ζ | Size | |----------------------------|--------------------------------------------|---|---|---|---|------| | cmp_add Rm1, Rn1, Rm2, Rn2 | Same as cmp_add of the OP1_ADD instruction | Δ | Δ | Δ | Δ | 4 | | cmp_sub_Rm1, Rn1, Rm2, Rn2 | Same as cmp_sub of the OP1_SUB instruction | Δ | Δ | Δ | Δ | 4 | | cmp_mov Rm1, Rn1, Rm2, Rn2 | Same as cmp_mov of the OP1_MOV instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asr Rm1, Rn1, Rm2, Rn2 | Same as cmp_asr of the OP1_ASR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_lsr Rm1, Rn1, Rm2, Rn2 | Same as cmp_lsr of the OP1_LSR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asl Rm1, Rn1, Rm2, Rn2 | Same as cmp_asl of the OP1_ASL instruction | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## CMP\_OP2 Rm1, Rn1, imm, Rn2 #### Operation [Rn1 - Rm1] with op2 This performs the paralell execution of the comparison between the register (Rm1) and the register (Rn1) and the op2 operation between the immediate value and the register (Rn2). | Assembler mnemonic | Note | V | C | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | cmp_add Rm1, Rn1, imm4, Rn2 | Same as cmp_add of the OP1_ADD instruction | Δ | Δ | Δ | Δ | 4 | | cmp_sub Rm1, Rn1, imm4, Rn2 | Same as cmp_sub of the OP1_SUB instruction | Δ | Δ | Δ | Δ | 4 | | cmp_mov Rm1, Rn1, imm4, Rn2 | Same as cmp_mov of the OP1_MOV instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asr Rm1, Rn1, imm4, Rn2 | Same as cmp_asr of the OP1_ASR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_lsr Rm1, Rn1, imm4, Rn2 | Same as cmp_lsr of the OP1_LSR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asl Rm1, Rn1, imm4, Rn2 | Same as cmp_asl of the OP1_ASL instruction | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### CMP\_OP2 imm, Rn1, Rm2, Rn2 #### Operation [Rn1 - (sign\_ext)imm4] with op2 This performs the paralell execution of the comparison between the sign-extended immediate value (imm4) and the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | О | Ζ | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | cmp_add imm4, Rn1, Rm2, Rn2 | Same as cmp_add of the OP1_ADD instruction | Δ | Δ | Δ | Δ | 4 | | cmp_sub_imm4, Rn1, Rm2, Rn2 | Same as cmp_sub of the OP1_SUB instruction | Δ | Δ | Δ | Δ | 4 | | cmp_mov imm4, Rn1, Rm2, Rn2 | Same as cmp_mov of the OP1_MOV instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asr imm4, Rn1, Rm2, Rn2 | Same as cmp_asr of the OP1_ASR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_lsr imm4, Rn1, Rm2, Rn2 | Same as cmp_lsr of the OP1_LSR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asl imm4, Rn1, Rm2, Rn2 | Same as cmp_asl of the OP1_ASL instruction | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## CMP\_OP2 imm, Rn1, imm, Rn2 #### Operation [Rn1 - (sign-ext)imm4\*] with op2 (\*:1st operand) This performs the paralell execution of the comparison between the first sign-extended immediate value (imm4) and the register (Rn1) and the op2 operation between the immediate value (imm) and the register (Rn2). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | cmp_add imm4, Rn1, imm4, Rn2 | Same as cmp_add of the OP1_ADD instruction | Δ | Δ | Δ | Δ | 4 | | cmp_sub_imm4, Rn1, imm4, Rn2 | Same as cmp_sub of the OP1_SUB instruction | Δ | Δ | Δ | Δ | 4 | | cmp_mov imm4, Rn1, imm4, Rn2 | Same as cmp_mov of the OP1_MOV instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asr_imm4, Rn1, imm4, Rn2 | Same as cmp_asr of the OP1_ASR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_lsr imm4, Rn1, imm4, Rn2 | Same as cmp_lsr of the OP1_LSR instruction | Δ | Δ | Δ | Δ | 4 | | cmp_asl_imm4, Rn1, imm4, Rn2 | Same as cmp_asl of the OP1_ASL instruction | Δ | Δ | Δ | Δ | 4 | #### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF : "1" when the operation result is "0"; "0" in all other cases. # SUB~OP2~ Parallel execution of subtrac- tion and OP2 #### SUB OP2 Rm1, Rn1, Rm2, Rn2 #### Operation [Rn1 - Rm1 -> Rn1] with op2 This performs the paralell execution of the subtraction of the register (Rm1)from the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | / | O | Ν | Ζ | Size | |----------------------------|--------------------------------------------|---|---|---|---|------| | sub_add Rm1, Rn1, Rm2, Rn2 | Same as sub_add of the OP1_ADD instruction | - | - | - | 1 | 4 | | sub_sub_Rm1, Rn1, Rm2, Rn2 | Same as sub_sub of the OP1_SUB instruction | 1 | | - | 1 | 4 | | sub_cmp Rm1, Rn1, Rm2, Rn2 | Same as sub_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov Rm1, Rn1, Rm2, Rn2 | Same as sub_mov of the OP1_MOV instruction | - | - | - | - | 4 | | sub_asr Rm1, Rn1, Rm2, Rn2 | Same as sub_asr of the OP1_ASR instruction | - | - | - | 1 | 4 | | sub_lsr Rm1, Rn1, Rm2, Rn2 | Same as sub_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | sub_asl Rm1, Rn1, Rm2, Rn2 | Same as sub_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## SUB\_OP2 Rm1, Rn1, imm, Rn2 #### Operation [Rn1 - Rm1 -> Rn1] with op2 This performs the paralell execution of the subtraction of the register (Rm1) from the register (Rn1) and the op2 operation between the immediate value (imm) and the register (Rn2). | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | sub_add Rm1, Rn1, imm4, Rn2 | Same as sub_add of the OP1_ADD instruction | - | - | - | - | 4 | | sub_sub Rm1, Rn1, imm4, Rn2 | Same as sub_sub of the OP1_SUB instruction | - | - | - | - | 4 | | sub_cmp Rm1, Rn1, imm4, Rn2 | Same as sub_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov Rm1, Rn1, imm4, Rn2 | Same as sub_mov of the OP1_MOV instruction | - | - | - | - | 4 | | sub_asr Rm1, Rn1, imm4, Rn2 | Same as sub_asr of the OP1_ASR instruction | - | - | - | - | 4 | | sub_lsr Rm1, Rn1, imm4, Rn2 | Same as sub_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | sub_asl Rm1, Rn1, imm4, Rn2 | Same as sub_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### SUB\_OP2 imm, Rn1, Rm2, Rn2 #### Operation [Rn1 - (sign\_ext)imm4 -> Rn1] with op2 This performs the paralell execution of the subtraction of the register (Rm1) from the sign-extended immediate value (imm4) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | 7 | С | Z | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | sub_add imm4, Rn1, Rm2, Rn2 | Same as sub_add of the OP1_ADD instruction | | 1 | | 1 | 4 | | sub_sub imm4, Rn1, Rm2, Rn2 | Same as sub_sub of the OP1_SUB instruction | 1 | 1 | | 1 | 4 | | sub_cmp_imm4, Rn1, Rm2, Rn2 | Same as sub_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov_imm4, Rn1, Rm2, Rn2 | Same as sub_mov of the OP1_MOV instruction | - | - | - | 1 | 4 | | sub_asr imm4, Rn1, Rm2, Rn2 | Same as sub_asr of the OP1_ASR instruction | - | - | - | - | 4 | | sub_lsr imm4, Rn1, Rm2, Rn2 | Same as sub_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | sub_asl_imm4, Rn1, Rm2, Rn2 | Same as sub_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## SUB\_OP2 imm, Rn1, imm, Rn2 #### Operation [Rn1 - (sign\_ext)imm4\* -> Rn1] with op2 (\*:1st operand) This performs the paralell execution of the subtraction of the register (Rm1) from the first sign-extended immediate value (imm4) and the op2 operation between the immediate value (imm4) and the register (Rn2). | Assembler mnemonic | Note | > | С | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | sub_add imm4, Rn1, imm4, Rn2 | Same as sub_add of the OP1_ADD instruction | • | - | - | - | 4 | | sub_sub_imm4, Rn1, imm4, Rn2 | Same as sub_sub of the OP1_SUB instruction | - | - | - | 1 | 4 | | sub_cmp imm4, Rn1, imm4, Rn2 | Same as sub_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov imm4, Rn1, imm4, Rn2 | Same as sub_mov of the OP1_MOV instruction | - | - | - | - | 4 | | sub_asr imm4, Rn1, imm4, Rn2 | Same as sub_asr of the OP1_ASR instruction | - | - | - | - | 4 | | sub_lsr imm4, Rn1, imm4, Rn2 | Same as sub_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | sub_asl imm4, Rn1, imm4, Rn2 | Same as sub_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # $MOV\_OP2$ Parallel execution of transfer and OP2 ## MOV\_OP2 Rm1, Rn1, Rm2, Rn2 #### Operation $[Rm1 \rightarrow Rn1]$ with op2 This performs the paralell execution of the transfer of the register (Rm1) to the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Note | ٧ | С | Ν | Ζ | Size | |--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------|------------------------------------------------------| | Same as mov_add of the OP1_ADD instruction | - | - | - | - | 4 | | Same as mov_sub of the OP1_SUB instruction | - | - | - | - | 4 | | Same as mov_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | Same as mov_mov of the OP1_MOV instruction | - | - | - | - | 4 | | Same as mov_asr of the OP1_ASR instruction | - | - | - | - | 4 | | Same as mov_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | Same as mov_asl of the OP1_ASL instruction | - | - | - | - | 4 | | | Same as mov_add of the OP1_ADD instruction Same as mov_sub of the OP1_SUB instruction Same as mov_cmp of the OP1_CMP instruction Same as mov_mov of the OP1_MOV instruction Same as mov_asr of the OP1_ASR instruction Same as mov_lsr of the OP1_LSR instruction | Same as mov_add of the OP1_ADD instruction Same as mov_sub of the OP1_SUB instruction Same as mov_cmp of the OP1_CMP instruction Same as mov_mov of the OP1_MOV instruction Same as mov_asr of the OP1_ASR instruction Same as mov_lsr of the OP1_LSR instruction | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## MOV\_OP2 Rm1, Rn1, imm, Rn2 #### Operation $[Rm1 \rightarrow Rn1]$ with op2 This performs the paralell execution of the transfer of the register (Rm1) to the register (Rn1) and the op2 operation between the immediate value (imm) and the register (Rn2). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | mov_add Rm1, Rn1, imm4, Rn2 | Same as mov_add of the OP1_ADD instruction | - | 1 | 1 | 1 | 4 | | mov_sub Rm1, Rn1, imm4, Rn2 | Same as mov_sub of the OP1_SUB instruction | - | 1 | 1 | 1 | 4 | | mov_cmp Rm1, Rn1, imm4, Rn2 | Same as mov_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | mov_mov Rm1, Rn1, imm4, Rn2 | Same as mov_mov of the OP1_MOV instruction | - | - | - | - | 4 | | mov_asr Rm1, Rn1, imm4, Rn2 | Same as mov_asr of the OP1_ASR instruction | - | - | - | - | 4 | | mov_lsr Rm1, Rn1, imm4, Rn2 | Same as mov_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | mov_asl Rm1, Rn1, imm4, Rn2 | Same as mov_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### MOV OP2 imm, Rn1, Rm2, Rn2 #### Operation [(sign-ext)imm4 -> Rn1] with op2 This performs the paralell execution of the transfer of the sign-extended immediate value (imm4) to the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | mov_add imm4, Rn1, Rm2, Rn2 | Same as mov_add of the OP1_ADD instruction | | - | - | 1 | 4 | | mov_sub_imm4, Rn1, Rm2, Rn2 | Same as mov_sub of the OP1_SUB instruction | - | - | - | - | 4 | | mov_cmp imm4, Rn1, Rm2, Rn2 | Same as mov_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | mov_mov imm4, Rn1, Rm2, Rn2 | Same as mov_mov of the OP1_MOV instruction | - | - | - | - | 4 | | mov_asr_imm4, Rn1, Rm2, Rn2 | Same as mov_asr of the OP1_ASR instruction | - | - | - | - | 4 | | mov_lsr imm4, Rn1, Rm2, Rn2 | Same as mov_lsr of the OP1_LSR instruction | - | - | - | 1 | 4 | | mov_asl_imm4, Rn1, Rm2, Rn2 | Same as mov_asl of the OP1_ASL instruction | - | - | - | 1 | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### MOV\_OP2 imm, Rn1, imm, Rn2 #### Operation [(sign\_ext)imm4\* -> Rn1] with op2 (\* : 1st operand) This performs the paralell execution of the transfer of the first sign-extended immediate value (imm4) to the register (Rn1) and the op2 operation between the immediate value (imm) and the registers (Rn2). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | mov_add imm4, Rn1, imm4, Rn2 | Same as mov_add of the OP1_ADD instruction | - | - | - | - | 4 | | mov_sub_imm4, Rn1, imm4, Rn2 | Same as mov_sub of the OP1_SUB instruction | - | 1 | 1 | 1 | 4 | | mov_cmp imm4, Rn1, imm4, Rn2 | Same as mov_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | mov_mov imm4, Rn1, imm4, Rn2 | Same as mov_mov of the OP1_MOV instruction | - | - | - | - | 4 | | mov_asr_imm4, Rn1, imm4, Rn2 | Same as mov_asr of the OP1_ASR instruction | - | - | - | - | 4 | | mov_lsr imm4, Rn1, imm4, Rn2 | Same as mov_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | mov_asl_imm4, Rn1, imm4, Rn2 | Same as mov_asl of the OP1_ASL instruction | - | - | ı | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # $AND \ \ OP2$ Parallel execution of AND ## and OP2 #### AND OP2 Rm1, Rn1, Rm2, Rn2 #### Operation [Rm1 & Rn1 -> Rn1] with op2 This performs the paralell execution of the AND between the register (Rm1) and the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | O | Z | Ζ | Size | |----------------------------|--------------------------------------------|---|---|---|---|------| | and_add Rm1, Rn1, Rm2, Rn2 | Same as and_add of the OP1_ADD instruction | - | - | - | - | 4 | | and_sub_Rm1, Rn1, Rm2, Rn2 | Same as and_sub of the OP1_SUB instruction | - | 1 | - | - | 4 | | and_cmp Rm1, Rn1, Rm2, Rn2 | Same as and_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | and_mov Rm1, Rn1, Rm2, Rn2 | Same as and_mov of the OP1_MOV instruction | - | - | - | - | 4 | | and_asr Rm1, Rn1, Rm2, Rn2 | Same as and_asr of the OP1_ASR instruction | - | - | - | - | 4 | | and_lsr Rm1, Rn1, Rm2, Rn2 | Same as and_Isr of the OP1_LSR instruction | - | 1 | - | - | 4 | | and_asl Rm1, Rn1, Rm2, Rn2 | Same as and_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### AND OP2 Rm1, Rn1, imm, Rn2 #### Operation [Rm1 & Rn1 -> Rn1] with op2 This performs the paralell execution of the AND between the register (Rm1) and the register (Rn1) and the op2 operation between the immediate value (imm) and the register (Rn2). | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | and_add Rm1, Rn1, imm4, Rn2 | Same as and_add of the OP1_ADD instruction | 1 | - | • | 1 | 4 | | and_sub_Rm1, Rn1, imm4, Rn2 | Same as and_sub of the OP1_SUB instruction | 1 | - | ı | 1 | 4 | | and_cmp_Rm1, Rn1, imm4, Rn2 | Same as and_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | and_mov Rm1, Rn1, imm4, Rn2 | Same as and_mov of the OP1_MOV instruction | - | - | - | - | 4 | | and_asr_Rm1, Rn1, imm4, Rn2 | Same as and_asr of the OP1_ASR instruction | - | - | • | - | 4 | | and_lsr Rm1, Rn1, imm4, Rn2 | Same as and_Isr of the OP1_LSR instruction | - | - | - | 1 | 4 | | and_asl_Rm1, Rn1, imm4, Rn2 | Same as and_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## OR OP2 ## Parallel execution of OR and ### OR\_OP2 Rm1, Rn1, Rm2, Rn2 #### Operation $[Rm1 \mid Rn1 \rightarrow Rn1]$ with op2 This performs the paralell execution of the OR between the register (Rm1) and the register (Rm1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |---------------------------|-------------------------------------------|---|---|---|---|------| | or_add Rm1, Rn1, Rm2, Rn2 | Same as or_add of the OP1_ADD instruction | - | - | - | - | 4 | | or_sub Rm1, Rn1, Rm2, Rn2 | Same as or_sub of the OP1_SUB instruction | - | - | - | - | 4 | | or_cmp Rm1, Rn1, Rm2, Rn2 | Same as or_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | or_mov Rm1, Rn1, Rm2, Rn2 | Same as or_mov of the OP1_MOV instruction | - | - | - | - | 4 | | or_asr_Rm1, Rn1, Rm2, Rn2 | Same as or_asr of the OP1_ASR instruction | - | - | - | - | 4 | | or_lsr Rm1, Rn1, Rm2, Rn2 | Same as or_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | or_asl_Rm1, Rn1, Rm2, Rn2 | Same as or_asl of the OP1_ASL instruction | - | - | - | 1 | 4 | | | | | | | | | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OR\_OP2 Rm1, Rn1, imm, Rn2 #### Operation [Rm1 | Rn1 -> Rn1] with op2 This performs the paralell execution of the OR between the register (Rm1) and the register (Rn1) and the op2 operation between the immediate value (imm) and the register (Rn2). | Note | ٧ | С | Ν | Ζ | Size | |-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------| | Same as or_add of the OP1_ADD instruction | - | - | - | - | 4 | | Same as or_sub of the OP1_SUB instruction | 1 | ı | ı | - | 4 | | Same as or_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | Same as or_mov of the OP1_MOV instruction | - | - | • | | 4 | | Same as or_asr of the OP1_ASR instruction | - | - | - | - | 4 | | Same as or_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | Same as or_asl of the OP1_ASL instruction | - | - | - | - | 4 | | | Same as or_add of the OP1_ADD instruction Same as or_sub of the OP1_SUB instruction Same as or_cmp of the OP1_CMP instruction Same as or_mov of the OP1_MOV instruction Same as or_asr of the OP1_ASR instruction Same as or_lsr of the OP1_LSR instruction | Same as or_add of the OP1_ADD instruction Same as or_sub of the OP1_SUB instruction Same as or_cmp of the OP1_CMP instruction Same as or_mov of the OP1_MOV instruction Same as or_asr of the OP1_ASR instruction Same as or_lsr of the OP1_LSR instruction | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## XOR OP2 Parallel execution of XOR #### XOR OP2 Rm1, Rn1, Rm2, Rn2 #### Operation $[Rm1^{\land} Rn1 \rightarrow Rn1]$ with op2 This performs the paralell execution of the XOR between the register (Rm1) and the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | О | Ζ | Ζ | Size | |----------------------------|--------------------------------------------|---|---|---|---|------| | xor_add Rm1, Rn1, Rm2, Rn2 | Same as xor_add of the OP1_ADD instruction | - | - | - | - | 4 | | xor_sub Rm1, Rn1, Rm2, Rn2 | Same as xor_sub of the OP1_SUB instruction | - | - | - | - | 4 | | xor_cmp Rm1, Rn1, Rm2, Rn2 | Same as xor_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | xor_mov Rm1, Rn1, Rm2, Rn2 | Same as xor_mov of the OP1_MOV instruction | - | - | - | - | 4 | | xor_asr Rm1, Rn1, Rm2, Rn2 | Same as xor_asr of the OP1_ASR instruction | - | - | - | - | 4 | | xor_lsr Rm1, Rn1, Rm2, Rn2 | Same as xor_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | xor_asl Rm1, Rn1, Rm2, Rn2 | Same as xor_asl of the OP1_ASL instruction | - | - | - | 1 | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### XOR OP2 Rm1, Rn1, imm, Rn2 #### Operation This performs the paralell execution of the XOR between the immediate value (imm) and the register (Rn1) and the op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | xor_add Rm1, Rn1, imm4, Rn2 | Same as xor_add of the OP1_ADD instruction | - | - | - | - | 4 | | kor_sub Rm1, Rn1, imm4, Rn2 | Same as xor_sub of the OP1_SUB instruction | - | - | - | - | 4 | | xor_cmp Rm1, Rn1, imm4, Rn2 | Same as xor_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | kor_mov Rm1, Rn1, imm4, Rn2 | Same as xor_mov of the OP1_MOV instruction | - | - | - | - | 4 | | xor_asr Rm1, Rn1, imm4, Rn2 | Same as xor_asr of the OP1_ASR instruction | - | - | - | - | 4 | | xor_lsr Rm1, Rn1, imm4, Rn2 | Same as xor_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | kor_asl_Rm1, Rn1, imm4, Rn2 | Same as xor_asl of the OP1_ASL instruction | - | - | - | - | 4 | | | | | | | | | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## DMACH OP2 Parallel execution of dual multiply-and-accumulate operation and OP2 #### DMACH OP2 Rm1, Rn1, Rm2, Rn2 #### Operation [(sign\_ext) (Rm1[31:16] \* (sign\_ext)Rn1[31:16]) $+((sign ext)Rm1[15:0]*(sign ext)Rn1[15:0]+MCRL \rightarrow MCRL]$ with op 2 This instruction adds the results of the multiplications between the upper 16 bits of the register (Rm1) and the upper 16 bits of the sign-extended register (Rn1) and between the lower 16 bits of the sign-extended register (Rm1) and the lower 16bits of the sign-extended register (Rn1), and MCRL to each other. Then it performs the parallel execution of storing the operation result in MCRL and executing the op2 operation between the registerS (Rm2 and Rn2). When that operation result overflows out of 32 bits, MCVF is set to 1 and the previous condition is kept. | Note | V | С | N | Ζ | Size | |----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | Same as dmach_add of the OP1_ADD instruction | - | - | - | - | 4 | | Same as dmach_sub of the OP1_SUB instruction | - | - | - | - | 4 | | Same as dmach_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | Same as dmach_mov of the OP1_MOV instruction | - | - | - | - | 4 | | Same as dmach_asr of the OP1_ASR instruction | - | - | - | - | 4 | | Same as dmach_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | Same as dmach_asl of the OP1_ASL instruction | - | - | - | - | 4 | | | Same as dmach_add of the OP1_ADD instruction Same as dmach_sub of the OP1_SUB instruction Same as dmach_cmp of the OP1_CMP instruction Same as dmach_mov of the OP1_MOV instruction Same as dmach_asr of the OP1_ASR instruction Same as dmach_lsr of the OP1_LSR instruction | Same as dmach_add of the OP1_ADD instruction - Same as dmach_sub of the OP1_SUB instruction - Same as dmach_cmp of the OP1_CMP instruction $\Delta$ Same as dmach_mov of the OP1_MOV instruction - Same as dmach_asr of the OP1_ASR instruction - Same as dmach_lsr of the OP1_LSR instruction - | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | Same as dmach_add of the OP1_ADD instruction $-$ - Same as dmach_sub of the OP1_SUB instruction $-$ - Same as dmach_cmp of the OP1_CMP instruction $-$ - Same as dmach_mov of the OP1_MOV instruction $-$ - Same as dmach_asr of the OP1_ASR instruction $-$ - Same as dmach_lsr of the OP1_LSR instruction $-$ - $-$ | Same as dmach_add of the OP1_ADD instruction $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### DMACH\_OP2 Rm1, Rn1, imm, Rn2 #### Operation [(sign\_ext) (Rm1[31:16] \* (sign\_ext)Rn1[31:16]) +((sign\_ext)Rm1[15:0] \* (sign\_ext)Rn1[15:0]+MCRL -> MCRL] with op2 This instruction adds the results of the multiplications between the upper 16 bits of the register (Rm1) and the upper 16 bits of the sign-extended register (Rn1) and between the lower 16 bits of the sign-extended register (Rm1) and the lower 16bits of the sign-extended register (Rn1), and MCRL to each other. Then it performs the parallel execution of storing the operation result in MCRL and executing the op2 operation between the registerS (imm and Rn2). When that operation result overflows out of 32 bits, MCVF is set to 1 and the previous condition is kept. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-------------------------------|----------------------------------------------|---|---|---|---|------| | dmach_add Rm1, Rn1, imm4, Rn2 | Same as dmach_add of the OP1_ADD instruction | - | - | - | - | 4 | | dmach_sub Rm1, Rn1, imm4, Rn2 | Same as dmach_sub of the OP1_SUB instruction | - | - | - | - | 4 | | dmach_cmp Rm1, Rn1, imm4, Rn2 | Same as dmach_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | dmach_mov Rm1, Rn1, imm4, Rn2 | Same as dmach_mov of the OP1_MOV instruction | - | - | - | - | 4 | | dmach_asr Rm1, Rn1, imm4, Rn2 | Same as dmach_asr of the OP1_ASR instruction | - | - | - | - | 4 | | dmach_lsr Rm1, Rn1, imm4, Rn2 | Same as dmach_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | dmach_asl Rm1, Rn1, imm4, Rn2 | Same as dmach_asl of the OP1_ASL instruction | - | ı | ı | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## SWHW OP2 Parallel execution of the data exchange between the upper 2bytes and lower 2 bytes and OP2 #### SWHW OP2 Rm1, Rn1, Rm2, Rn2 #### Operation [Rm1[15:0] -> Rn1[31:16], Rm1[31:16] -> Rn1[15:0]] with op2 This instruction performs the parallel execution of storing the upper 16 bits of the register (Rm1) in the lower 16 bits of the register (Rn1), storing the lower 16 bits of the register (Rm1) in the upper 16 bits of the register (Rn1), and op2 operation between the registers (Rm2 and Rn2). | Assembler mnemonic | Note | ٧ | С | Z | Ζ | Size | |-----------------------------|---------------------------------------------|---|---|---|---|------| | swhw_add Rm1, Rn1, Rm2, Rn2 | Same as swhw_add of the OP1_ADD instruction | - | - | | | 4 | | swhw_sub Rm1, Rn1, Rm2, Rn2 | Same as swhw_sub of the OP1_SUB instruction | - | - | - | - | 4 | | swhw_cmp Rm1, Rn1, Rm2, Rn2 | Same as swhw_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | swhw_mov Rm1, Rn1, Rm2, Rn2 | Same as swhw_mov of the OP1_MOV instruction | - | - | - | - | 4 | | swhw_asr Rm1, Rn1, Rm2, Rn2 | Same as swhw_asr of the OP1_ASR instruction | - | - | - | - | 4 | | swhw_lsr Rm1, Rn1, Rm2, Rn2 | Same as swhw_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | swhw_asl Rm1, Rn1, Rm2, Rn2 | Same as swhw_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## SWHW\_OP2 Rm1, Rn1, imm, Rn2 #### Operation [ Rm1[15:0] -> Rn1[31:16], Rm1[31: 16] -> Rn1[15:0]] with op2 This instruction performs the parallel execution of storing the upper 16 bits of the register (Rm1) in the lower 16 bits of the register (Rn1), storing the lower 16 bits of the register (Rm1) in the upper 16 bits of the register (Rn1), and op2 operation between the immediate value (imm) and the register (Rn2). | Assem | nbler mnemonic | Note | ٧ | С | N | Ζ | Size | |-------------|---------------------|---------------------------------------------|---|---|---|---|------| | swhw_add R | Rm1, Rn1, imm4, Rn2 | Same as swhw_add of the OP1_ADD instruction | - | - | - | - | 4 | | swhw_sub R | Rm1, Rn1, imm4, Rn2 | Same as swhw_sub of the OP1_SUB instruction | - | - | - | - | 4 | | swhw_cmp F | Rm1, Rn1, imm4, Rn2 | Same as swhw_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | swhw_mov F | Rm1, Rn1, imm4, Rn2 | Same as swhw_mov of the OP1_MOV instruction | - | - | - | - | 4 | | swhw_asr Rr | m1, Rn1, imm4, Rn2 | Same as swhw_asr of the OP1_ASR instruction | - | - | - | - | 4 | | swhw_lsr Rm | n1, Rn1, imm4, Rn2 | Same as swhw_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | swhw_asl Rr | m1, Rn1, imm4, Rn2 | Same as swhw_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # SAT16 OP2 Parallel execution of the saturation operation of the upper 16 bits and OP2 ## SAT16\_OP2 Rm1, Rn1, Rm2, Rn2 #### Operation [(SAT16 op.) Rm1 -> Rn1] with op2 When source register Rm1 is - 1) equal or bigger than maximum positive value (0x00007FFF) for 16-bit signed number, the maximum positive value (0x00007FFF) is stored into the register (Rn1). - 2) equal or smaller than minimum negative value (0xFFFF8000) for 16-bit signed number, the minimum negative value (0xFFFF8000) is stored into the register (Rn1). - 3) other than 1) or 2), the contents of the register (Rm1) are stored into the register (Rn1). Parallel execution is carried out for op2 operations of SAT16 and Rm2, Rn2. | Asse | mbler mnemonic | Note | ٧ | C | Z | Ζ | Size | |-------------|--------------------|----------------------------------------------|---|---|---|---|------| | sat16_add | Rm1, Rn1, Rm2, Rn2 | Same as sat16_add of the OP1_ADD instruction | - | - | - | - | 4 | | sat16_sub | Rm1, Rn1, Rm2, Rn2 | Same as sat16_sub of the OP1_SUB instruction | - | - | - | - | 4 | | sat16_cmp | Rm1, Rn1, Rm2, Rn2 | Same as sat16_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | sat16_mov | Rm1, Rn1, Rm2, Rn2 | Same as sat16_mov of the OP1_MOV instruction | - | - | - | - | 4 | | sat16_asr F | Rm1, Rn1, Rm2, Rn2 | Same as sat16_asr of the OP1_ASR instruction | - | - | | - | 4 | | sat16_lsr R | Rm1, Rn1, Rm2, Rn2 | Same as sat16_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | sat16_asl F | Rm1, Rn1, Rm2, Rn2 | Same as sat16_asl of the OP1_ASL instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## SAT16\_OP2 Rm1, Rn1, imm, Rn2 #### Operation [(SAT16 op.) Rm1 -> Rn1] with op2 When source register Rm1 is - 1) equal or bigger than maximum positive value (0x00007FFF) for 16-bit signed number, the maximum positive value (0x00007FFF) is stored into the register (Rn1). - 2) equal or smaller than minimum negative value (0xFFFF8000) for 16-bit signed number, the minimum negative value (0xFFFF8000) is stored into the register (Rn1). - 3) other than 1) or 2), the contents of the register (Rm1) are stored into the register (Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-------------------------------|----------------------------------------------|---|---|---|---|------| | sat16_add Rm1, Rn1, imm4, Rn2 | Same as sat16_add of the OP1_ADD instruction | - | - | - | - | 4 | | sat16_sub_Rm1, Rn1, imm4, Rn2 | Same as sat16_sub of the OP1_SUB instruction | - | - | - | - | 4 | | sat16_cmp Rm1, Rn1, imm4, Rn2 | Same as sat16_cmp of the OP1_CMP instruction | Δ | Δ | Δ | Δ | 4 | | sat16_mov Rm1, Rn1, imm4, Rn2 | Same as sat16_mov of the OP1_MOV instruction | - | - | - | - | 4 | | sat16_asr_Rm1, Rn1, imm4, Rn2 | Same as sat16_asr of the OP1_ASR instruction | - | - | - | - | 4 | | sat16_lsr_Rm1, Rn1, imm4, Rn2 | Same as sat16_lsr of the OP1_LSR instruction | - | - | - | - | 4 | | sat16_asl_Rm1, Rn1, imm4, Rn2 | Same as sat16_asl of the OP1_ASL instruction | - | ı | ı | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## addition ## OP1 ADD Rm1, Rn1, Rm2, Rn2 #### Operation [Rm2 +Rn -> Rn2] with op1 This performs the paralell execution of the addition between the registers (Rm2 and Rn2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | О | Ν | Z | Size | |------------------------------|------------------------------------------------|---|---|---|---|------| | add_add Rm1, Rn1, Rm2, Rn2 | Same as add_add of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_add Rm1, Rn1, Rm2, Rn2 | Same as cmp_add of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_add Rm1, Rn1, Rm2, Rn2 | Same as sub_add of the SUB_OP2 instruction | - | 1 | - | - | 4 | | mov_add Rm1, Rn1, Rm2, Rn2 | Same as mov_add of the MOV_OP2 instruction | - | - | - | - | 4 | | and_add Rm1, Rn1, Rm2, Rn2 | Same as and_add of the AND_OP2 instruction | - | - | - | - | 4 | | or_add Rm1, Rn1, Rm2, Rn2 | Same as or_add of the OR_OP2 instruction | - | 1 | - | - | 4 | | xor_add Rm1, Rn1, Rm2, Rn2 | Same as xor_add of the XOR_OP2 instruction | - | 1 | - | - | 4 | | dmach_add Rm1, Rn1, Rm2, Rn2 | Same as dmach_add of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_add Rm1, Rn1, Rm2, Rn2 | Same as swhw_add of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_add Rm1, Rn1, Rm2, Rn2 | Same as sat16_add of the SAT16_OP2 instruction | - | 1 | - | - | 4 | #### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ADD imm, Rn1, Rm2, Rn2 #### Operation [Rm2 +Rn -> Rn2] with op1 This performs the paralell execution of the addition between the registers (Rm2 and Rn2) and the op1 operation between the immediate value (imm) and the register (Rn1). | Assembler mnemonic | Note | < | С | Ζ | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_add_imm4, Rn1, Rm2, Rn2 | Same as add_add of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_add imm4, Rn1, Rm2, Rn2 | Same as cmp_add of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_add imm4, Rn1, Rm2, Rn2 | Same as sub_add of the SUB_OP2 instruction | 1 | , | , | - | 4 | | mov_add imm4, Rn1, Rm2, Rn2 | Same as mov_add of the MOV_OP2 instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## OP1\_ADD Rm1, Rn1, imm, Rn2 #### Operation [(sign\_ext) imm4+Rn2 -> Rn2] with op1 This performs the paralell execution of the addition between the sign-extended immediate value (imm4) the register (Rn2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | NT / | ١,, | $\overline{}$ | N I | 7 | Size | |-------------------------------|------------------------------------------------|-----|---------------|-----|---|------| | Assembler inhemonic | Note | ٧ | C | Ν | | SIZE | | add_add Rm1, Rn1, imm4, Rn2 | Same as add_add of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_add Rm1, Rn1, imm4, Rn2 | Same as cmp_add of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_add Rm1, Rn1, imm4, Rn2 | Same as sub_add of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_add Rm1, Rn1, imm4, Rn2 | Same as mov_add of the MOV_OP2 instruction | - | - | - | - | 4 | | and_add Rm1, Rn1, imm4, Rn2 | Same as and_add of the AND_OP2 instruction | - | - | - | - | 4 | | or_add Rm1, Rn1, imm4, Rn2 | Same as or_add of the OR_OP2 instruction | - | - | - | - | 4 | | xor_add Rm1, Rn1, imm4, Rn2 | Same as xor_add of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_add Rm1,Rn1,imm4,Rn2 | Same as dmach_add of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_add Rm1, Rn1, imm4, Rn2 | Same as swhw_add of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_add Rm1, Rn1, imm4, Rn2 | Same as sat16_add of the SAT16_OP2 instruction | - | - | - | - | 4 | #### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF : "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ADD imm, Rn1, imm, Rn2 ### Operation [(sign\_ext) imm4\* + Rn2 -> Rn2] with op1 (\* : 3rd operand) This performs the paralell execution of the addition between the sign-extended first immediate value (imm4) the register (Rn2) and the op1 operation between the immediate value (imm) and the register (Rn1). | Assembler mnemonic | Note | ٧ | C | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_add imm4, Rn1, imm4, Rn2 | Same as add_add of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_add imm4, Rn1, imm4, Rn2 | Same as cmp_add of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_add imm4, Rn1, imm4, Rn2 | Same as sub_add of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_add imm4, Rn1, imm4, Rn2 | Same as mov add of the MOV OP2 instruction | - | - | - | - | 4 | Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # OP1 SUB ### Parallel execution of OP1 and subtraction #### OP1 SUB Rm1, Rn1, Rm2, Rn2 ### Operation [Rn2 - Rm2 -> Rn2] with op1 This performs the paralell execution of the subtraction of the register (Rm2) from the register (Rn2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------------|------------------------------------------------|---|---|---|---|------| | add_sub_Rm1, Rn1, Rm2, Rn2 | Same as add_sub of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_sub Rm1, Rn1, Rm2, Rn2 | Same as cmp_sub of the CMP_OP2 instruction | - | - | - | - | 4 | | sub_sub Rm1, Rn1, Rm2, Rn2 | Same as sub_sub of the SUB_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | mov_sub Rm1, Rn1, Rm2, Rn2 | Same as mov_sub of the MOV_OP2 instruction | - | - | - | - | 4 | | and_sub_Rm1, Rn1, Rm2, Rn2 | Same as and_sub of the AND_OP2 instruction | - | - | - | - | 4 | | or_sub Rm1, Rn1, Rm2, Rn2 | Same as or_sub of the OR_OP2 instruction | - | - | - | - | 4 | | xor_sub Rm1, Rn1, Rm2, Rn2 | Same as xor_sub of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_sub Rm1, Rn1, Rm2, Rn2 | Same as dmach_sub of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_sub Rm1, Rn1, Rm2, Rn2 | Same as swhw_sub of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_sub Rm1, Rn1, Rm2, Rn2 | Same as sat16_sub of the SAT16_OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_SUB imm, Rn1, Rm2, Rn2 ### Operation [Rn2 - Rm2 -> Rn2] with op1 This performs the paralell execution of the subtraction of the register (Rm2) from the register (Rn2) and the op1 operation between the immediate value and the register (Rn1). | Assembler mnemonic | Note | ٧ | C | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_sub_imm4, Rn1, Rm2, Rn2 | Same as add_sub of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_sub_imm4, Rn1, Rm2, Rn2 | Same as cmp_sub of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_sub_imm4, Rn1, Rm2, Rn2 | Same as sub_sub of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_sub_imm4, Rn1, Rm2, Rn2 | Same as mov_sub of the MOV_OP2 instruction | - | - | - | - | 4 | ### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### OP1 SUB Rm1, Rn1, imm, Rn2 ### Operation [Rn2 - (sign\_ext)imm4 -> Rn2] with op1 This performs the paralell execution of the subtraction of the register (Rm2) from the signextended immediate value (imm4) and the op1 operation between the registers (Rm1 and Rn1). | Note | ٧ | О | Ν | Ζ | Size | |------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | Same as add_sub of the ADD_OP2 instruction | - | - | - | - | 4 | | Same as cmp_sub of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | Same as sub_sub of the SUB_OP2 instruction | | | - | - | 4 | | Same as mov_sub of the MOV_OP2 instruction | - | - | - | - | 4 | | Same as and_sub of the AND_OP2 instruction | - | - | - | - | 4 | | Same as or_sub of the OR_OP2 instruction | - | - | - | - | 4 | | Same as xor_sub of the XOR_OP2 instruction | - | - | - | - | 4 | | Same as dmach_sub of the DMACH_OP2 instruction | - | - | - | - | 4 | | Same as swhw_sub of the SWHW_OP2 instruction | - | - | - | - | 4 | | Same as sat16_sub of the SAT16_OP2 instruction | - | - | - | - | 4 | | | Same as add_sub of the ADD_OP2 instruction Same as cmp_sub of the CMP_OP2 instruction Same as sub_sub of the SUB_OP2 instruction Same as mov_sub of the MOV_OP2 instruction Same as and_sub of the AND_OP2 instruction Same as or_sub of the OR_OP2 instruction Same as xor_sub of the XOR_OP2 instruction Same as dmach_sub of the DMACH_OP2 instruction Same as swhw_sub of the SWHW_OP2 instruction | Same as add_sub of the ADD_OP2 instruction - Same as cmp_sub of the CMP_OP2 instruction $\Delta$ Same as sub_sub of the SUB_OP2 instruction - Same as mov_sub of the MOV_OP2 instruction - Same as and_sub of the AND_OP2 instruction - Same as or_sub of the OR_OP2 instruction - Same as xor_sub of the XOR_OP2 instruction - Same as dmach_sub of the DMACH_OP2 instruction - Same as swhw_sub of the SWHW_OP2 instruction - | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | Same as add_sub of the ADD_OP2 instruction $-$ Same as cmp_sub of the CMP_OP2 instruction $\Delta$ $\Delta$ $\Delta$ Same as sub_sub of the SUB_OP2 instruction $-$ Same as mov_sub of the MOV_OP2 instruction $-$ Same as and_sub of the AND_OP2 instruction $-$ Same as or_sub of the OR_OP2 instruction $-$ Same as xor_sub of the XOR_OP2 instruction $-$ Same as dmach_sub of the DMACH_OP2 instruction $-$ Same as swhw_sub of the SWHW_OP2 instruction $-$ | Same as add_sub of the ADD_OP2 instruction $-$ Same as cmp_sub of the CMP_OP2 instruction $-$ | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_SUB imm, Rn1, imm, Rn2 ### Operation $[Rn2 - (sign_ext)imm4* -> Rn2]$ with op1 (\*: 3rd operand) This performs the paralell execution of the subtraction of the register (Rm2) from the sign-extended first immediate value (imm4) and the op1 operation between the immediate value and the register (Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_sub_imm4, Rn1, imm4, Rn2 | Same as add_sub of the ADD_OP2 instruction | | - | - | - | 4 | | cmp_sub_imm4, Rn1, imm4, Rn2 | Same as cmp_sub of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_sub_imm4, Rn1, imm4, Rn2 | Same as sub_sub of the SUB_OP2 instruction | | - | - | - | 4 | | mov_sub_imm4, Rn1, imm4, Rn2 | Same as mov sub of the MOV OP2 instruction | - | - | - | - | 4 | ### Flag change When OP2 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP2 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # OP1 CMP Parallel execution of compari- ## son and OP1 #### OP1 CMP Rm1, Rn1, Rm2, Rn2 Operation [Rn2 - Rm2 : EPSW] with op1 This performs the paralell execution of the comparison between the registers (Rm2 and Rn2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |------------------------------|------------------------------------------------|---|---|---|---|------| | add_cmp Rm1, Rn1, Rm2, Rn2 | Same as add_cmp of the ADD_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_cmp Rm1, Rn1, Rm2, Rn2 | Same as sub_cmp of the SUB_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | mov_cmp Rm1, Rn1, Rm2, Rn2 | Same as mov_cmp of the MOV_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | and_cmp Rm1, Rn1, Rm2, Rn2 | Same as and_cmp of the AND_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | or_cmp Rm1, Rn1, Rm2, Rn2 | Same as or_cmp of the OR_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | xor_cmp Rm1, Rn1, Rm2, Rn2 | Same as xor_cmp of the XOR_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | dmach_cmp Rm1, Rn1, Rm2, Rn2 | Same as dmach_cmp of the DMACH_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | swhw_cmp Rm1, Rn1, Rm2, Rn2 | Same as swhw_cmp of the SWHW_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sat16_cmp Rm1, Rn1, Rm2, Rn2 | Same as sat16_cmp of the SAT16_OP2 instruction | Δ | Δ | Δ | Δ | 4 | ### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### OP1 CMP imm, Rn1, Rm2, Rn2 Operation [Rn2 - Rm2 : EPSW] with op1 This performs the paralell execution of the comparison between the registers (Rm2 and Rn2) and the op1 operation between the immediate value (imm) and the register (Rn1). | <u> </u> | | | | | | | |-----------------------------|--------------------------------------------|---|---|---|---|------| | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | | add_cmp imm4, Rn1, Rm2, Rn2 | Same as add_cmp of the ADD_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_cmp_imm4, Rn1, Rm2, Rn2 | Same as sub_cmp of the SUB_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | mov_cmp imm4, Rn1, Rm2, Rn2 | Same as mov cmp of the MOV OP2 instruction | Δ | Δ | Δ | Δ | 4 | ### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_CMP Rm1, Rn1, imm, Rn2 ### Operation [Rn2 - (sign\_ext)imm4\*: EPSW] with op1 (\*: 3rd operand) This performs the paralell execution of the comparison between the sign-extended immediate value (imm4) and the register (Rn2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | < | С | Ζ | Ζ | Size | |-------------------------------|------------------------------------------------|---|---|---|---|------| | add_cmp Rm1, Rn1, imm4, Rn2 | Same as add_cmp of the ADD_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_cmp Rm1, Rn1, imm4, Rn2 | Same as sub_cmp of the SUB_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | mov_cmp Rm1, Rn1, imm4, Rn2 | Same as mov_cmp of the MOV_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | and_cmp Rm1, Rn1, imm4, Rn2 | Same as and_cmp of the AND_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | or_cmp Rm1, Rn1, imm4, Rn2 | Same as or_cmp of the OR_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | xor_cmp Rm1, Rn1, imm4, Rn2 | Same as xor_cmp of the XOR_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | dmach_cmp Rm1, Rn1, imm4,Rn2 | Same as dmach_cmp of the DMACH_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | swhw_cmp Rm1, Rn1, imm4, Rn2 | Same as swhw_cmp of the SWHW_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sat16_cmp Rm1, Rn1, imm4, Rn2 | Same as sat16_cmp of the SAT16_OP2 instruction | Δ | Δ | Δ | Δ | 4 | ### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_CMP imm, Rn1, imm, Rn2 #### Operation [Rn2 - (sign\_ext)imm4\* : EPSW] with op1 (\* : 3rd operand) This performs the paralell execution of the comparison between the registers (Rm2 and Rn2) and the op1 operation between the immediate value (imm) and the register (Rn1). | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_cmp_imm4, Rn1, imm4, Rn2 | Same as add_cmp of the ADD_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_cmp imm4, Rn1, imm4, Rn2 | Same as sub_cmp of the SUB_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | mov_cmp imm4, Rn1, imm4, Rn2 | Same as mov_cmp of the MOV_OP2 instruction | Δ | Δ | Δ | Δ | 4 | ### Flag change VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # $OP1\ MOV$ Parallel execution of transfer ## and OP1 ### OP1\_MOV Rm1, Rn1, Rm2, Rn2 ### Operation $[Rm2 \rightarrow Rn2]$ with op1 This performs the paralell execution of the transfer of the register (Rm2) to the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | O | Ν | Z | Size | |------------------------------|------------------------------------------------|---|---|---|---|------| | add_mov Rm1, Rn1, Rm2, Rn2 | Same as add_mov of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_mov Rm1, Rn1, Rm2, Rn2 | Same as cmp_mov of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov Rm1, Rn1, Rm2, Rn2 | Same as sub_mov of the SUB_OP2 instruction | - | 1 | - | - | 4 | | mov_mov Rm1, Rn1, Rm2, Rn2 | Same as mov_mov of the MOV_OP2 instruction | - | - | - | - | 4 | | and_mov Rm1, Rn1, Rm2, Rn2 | Same as and_mov of the AND_OP2 instruction | - | - | - | - | 4 | | or_mov Rm1, Rn1, Rm2, Rn2 | Same as or_mov of the OR_OP2 instruction | - | - | - | - | 4 | | xor_mov Rm1, Rn1, Rm2, Rn2 | Same as xor_mov of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_mov Rm1, Rn1, Rm2, Rn2 | Same as dmach_mov of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_mov Rm1, Rn1, Rm2, Rn2 | Same as swhw_mov of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_mov Rm1, Rn1, Rm2, Rn2 | Same as sat16_mov of the SAT16_OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_MOV imm, Rn1, Rm2, Rn2 ### Operation $[Rm2 \rightarrow Rn2]$ with op1 This performs the paralell execution of the transfer of the register (Rm2) to the register (Rn2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | O | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_mov_imm4, Rn1, Rm2, Rn2 | Same as add_mov of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_mov imm4, Rn1, Rm2, Rn2 | Same as cmp_mov of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov imm4, Rn1, Rm2, Rn2 | Same as sub_mov of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_mov imm4, Rn1, Rm2, Rn2 | Same as mov_mov of the MOV_OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### OP1 MOV Rm1, Rn1, imm, Rn2 ### Operation [(sign\_ext)imm4\* -> Rn2] with op1 (\* : 3rd operand) This performs the paralell execution of the transfer of the sign-extended immediate value (imm4) to the register (Rn2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |-------------------------------|------------------------------------------------|---|---|---|---|------| | add_mov Rm1, Rn1, imm4, Rn2 | Same as add_mov of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_mov Rm1, Rn1, imm4, Rn2 | Same as cmp_mov of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov Rm1, Rn1, imm4, Rn2 | Same as sub_mov of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_mov Rm1, Rn1, imm4, Rn2 | Same as mov_mov of the MOV_OP2 instruction | - | - | - | - | 4 | | and_mov Rm1, Rn1, imm4, Rn2 | Same as and_mov of the AND_OP2 instruction | - | - | - | - | 4 | | or_mov Rm1, Rn1, imm4, Rn2 | Same as or_mov of the OR_OP2 instruction | - | - | - | - | 4 | | xor_mov Rm1, Rn1, imm4, Rn2 | Same as xor_mov of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_mov Rm1, Rn1,imm4,Rn2 | Same as dmach_mov of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_mov Rm1, Rn1, imm4, Rn2 | Same as swhw_mov of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_mov Rm1, Rn1, imm4, Rn2 | Same as sat16_mov of the SAT16_OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_MOV imm, Rn1, imm, Rn2 ### Operation [(sign\_ext)imm4\* -> Rn2] with op1 (\*: 3rd operand) This performs the paralell execution of the transfer of the sign-extended third-operand immediate value (imm4) to the register (Rn2) and the op1 operation between the immediate value (imm) and the register (Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_mov_imm4, Rn1, imm4, Rn2 | Same as add_mov of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_mov imm4, Rn1, imm4, Rn2 | Same as cmp_mov of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_mov_imm4, Rn1, imm4, Rn2 | Same as sub_mov of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_mov imm4, Rn1, imm4, Rn2 | Same as mov mov of the MOV OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## metic shift right and OP1 #### OP1 ASR Rm1, Rn1, Rm2, Rn2 ### Operation $[(Rn2 \gg Rm2) \rightarrow Rn2]$ with op1 This performs the paralell execution of the arithmetic right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------------|------------------------------------------------|---|---|---|---|------| | add_asr Rm1, Rn1, Rm2, Rn2 | Same as add_asr of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_asr Rm1, Rn1, Rm2, Rn2 | Same as cmp_asr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asr_Rm1, Rn1, Rm2, Rn2 | Same as sub_asr of the SUB_OP2 instruction | - | 1 | - | - | 4 | | mov_asr Rm1, Rn1, Rm2, Rn2 | Same as mov_asr of the MOV_OP2 instruction | - | - | - | - | 4 | | and_asr Rm1, Rn1, Rm2, Rn2 | Same as and_asr of the AND_OP2 instruction | - | - | - | - | 4 | | or_asr Rm1, Rn1, Rm2, Rn2 | Same as or_asr of the OR_OP2 instruction | - | - | - | - | 4 | | xor_asr Rm1, Rn1, Rm2, Rn2 | Same as xor_asr of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_asr Rm1, Rn1, Rm2, Rn2 | Same as dmach_asr of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_asr Rm1, Rn1, Rm2, Rn2 | Same as swhw_asr of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_asr Rm1, Rn1, Rm2, Rn2 | Same as sat16_asr of the SAT16_OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ASR imm, Rn1, Rm2, Rn2 ### Operation $[(Rn2 \gg Rm2) \rightarrow Rn2]$ with op1 This performs the paralell execution of the arithmetic right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_asr imm4, Rn1, Rm2, Rn2 | Same as add_asr of the ADD_OP2 instruction | | - | - | - | 4 | | cmp_asr imm4, Rn1, Rm2, Rn2 | Same as cmp_asr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asr imm4, Rn1, Rm2, Rn2 | Same as sub_asr of the SUB_OP2 instruction | | - | - | - | 4 | | mov_asr imm4, Rn1, Rm2, Rn2 | Same as mov asr of the MOV OP2 instruction | - | - | - | - | 4 | #### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ASR Rm1, Rn1, imm, Rn2 ### Operation [(sign\_ext)imm4\* -> Rn2] with op1 (\* : 3rd operand) This performs the paralell execution of the arithmetic right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-------------------------------|------------------------------------------------|---|---|---|---|------| | add_asr Rm1, Rn1, imm4, Rn2 | Same as add_asr of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_asr Rm1, Rn1, imm4, Rn2 | Same as cmp_asr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asr Rm1, Rn1, imm4, Rn2 | Same as sub_asr of the SUB_OP2 instruction | ı | 1 | ı | - | 4 | | mov_asr Rm1, Rn1, imm4, Rn2 | Same as mov_asr of the MOV_OP2 instruction | 1 | - | | - | 4 | | and_asr_Rm1, Rn1, imm4, Rn2 | Same as and_asr of the AND_OP2 instruction | - | - | - | - | 4 | | or_asr Rm1, Rn1, imm4, Rn2 | Same as or_asr of the OR_OP2 instruction | - | - | - | - | 4 | | xor_asr Rm1, Rn1, imm4, Rn2 | Same as xor_asr of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_asr Rm1, Rn1, imm4, Rn2 | Same as dmach_asr of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_asr Rm1, Rn1, imm4, Rn2 | Same as swhw_asr of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_asr Rm1, Rn1, imm4, Rn2 | Same as sat16_asr of the SAT16_OP2 instruction | ı | - | 1 | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ASR imm, Rn1, imm, Rn2 ### Operation $[(Rn2 >> (sign_ext)imm4* -> Rn2]$ with op1 (\*: 3rd operand) This performs the paralell execution of the arithmetic right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | V | С | Ν | Z | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_asr_imm4, Rn1, imm4, Rn2 | Same as add_asr of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_asr imm4, Rn1, imm4, Rn2 | Same as cmp_asr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asr imm4, Rn1, imm4, Rn2 | Same as sub_asr of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_asr imm4, Rn1, imm4, Rn2 | Same as mov asr of the MOV OP2 instruction | - | - | - | - | 4 | #### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## shift right and OP1 #### OP1 LSR Rm1, Rn1, Rm2, Rn2 ### Operation $[(Rn2 \gg Rm2) \rightarrow Rn2]$ with op1 This performs the paralell execution of the logical right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | V | С | N | 7 | Size | |------------------------------|------------------------------------------------|---|---|---|---|------| | add Isr Rm1, Rn1, Rm2, Rn2 | Same as add_lsr of the ADD_OP2 instruction | _ | _ | - | _ | 4 | | cmp_lsr Rm1, Rn1, Rm2, Rn2 | Same as cmp_lsr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_lsr Rm1, Rn1, Rm2, Rn2 | Same as sub_lsr of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_lsr Rm1, Rn1, Rm2, Rn2 | Same as mov_lsr of the MOV_OP2 instruction | 1 | - | - | - | 4 | | and_lsr Rm1, Rn1, Rm2, Rn2 | Same as and_Isr of the AND_OP2 instruction | - | - | - | - | 4 | | or_lsr Rm1, Rn1, Rm2, Rn2 | Same as or_lsr of the OR_OP2 instruction | 1 | - | - | - | 4 | | xor_lsr Rm1, Rn1, Rm2, Rn2 | Same as xor_lsr of the XOR_OP2 instruction | 1 | - | - | - | 4 | | dmach_lsr Rm1, Rn1, Rm2, Rn2 | Same as dmach_lsr of the DMACH_OP2 instruction | 1 | - | - | - | 4 | | swhw_lsr Rm1, Rn1, Rm2, Rn2 | Same as swhw_lsr of the SWHW_OP2 instruction | 1 | - | - | - | 4 | | sat16_lsr Rm1, Rn1, Rm2, Rn2 | Same as sat16_lsr of the SAT16_OP2 instruction | - | - | - | - | 4 | #### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_LSR imm, Rn1, Rm2, Rn2 ### Operation $[(Rn2 \gg Rm2) \rightarrow Rn2]$ with op1 This performs the paralell execution of the logical right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | O | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_lsr imm4, Rn1, Rm2, Rn2 | Same as add_Isr of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_lsr imm4, Rn1, Rm2, Rn2 | Same as cmp_lsr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_lsr imm4, Rn1, Rm2, Rn2 | Same as sub_lsr of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_lsr imm4, Rn1, Rm2, Rn2 | Same as mov_lsr of the MOV_OP2 instruction | - | - | - | - | 4 | #### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_LSR Rm1, Rn1, imm, Rn2 ### Operation $[(Rn2 \gg (zero\_ext)imm4*) -> Rn2]$ with op1 (\*: 3rd operand) This performs the paralell execution of the logical right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ζ | Z | Size | |-------------------------------|------------------------------------------------|---|---|---|---|------| | add_lsr Rm1, Rn1, imm4, Rn2 | Same as add_lsr of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_lsr Rm1, Rn1, imm4, Rn2 | Same as cmp_lsr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_lsr Rm1, Rn1, imm4, Rn2 | Same as sub_lsr of the SUB_OP2 instruction | - | - | 1 | - | 4 | | mov_lsr Rm1, Rn1, imm4, Rn2 | Same as mov_lsr of the MOV_OP2 instruction | - | - | - | - | 4 | | and_lsr Rm1, Rn1, imm4, Rn2 | Same as and_lsr of the AND_OP2 instruction | - | - | - | - | 4 | | or_lsr Rm1, Rn1, imm4, Rn2 | Same as or_lsr of the OR_OP2 instruction | - | - | - | - | 4 | | xor_lsr Rm1, Rn1, imm4, Rn2 | Same as xor_lsr of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_lsr Rm1, Rn1, imm4, Rn2 | Same as dmach_lsr of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_lsr Rm1, Rn1, imm4, Rn2 | Same as swhw_lsr of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_lsr Rm1, Rn1, imm4, Rn2 | Same as sat16_lsr of the SAT16_OP2 instruction | - | ı | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF : No change CF : No change NF : No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_LSR imm, Rn1, imm, Rn2 ### Operation $[(Rn2 >> (zero\_ext) imm4* -> Rn2]$ with op1 (\*: 3rd operand) This performs the paralell execution of the logical right shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | O | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_lsr_imm4, Rn1, imm4, Rn2 | Same as add_Isr of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_lsr imm4, Rn1, imm4, Rn2 | Same as cmp_lsr of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_lsr imm4, Rn1, imm4, Rn2 | Same as sub_lsr of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_lsr imm4, Rn1, imm4, Rn2 | Same as mov_lsr of the MOV_OP2 instruction | - | - | - | - | 4 | #### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ## metic shift left and OP1 #### OP1 ASL Rm1, Rn1, Rm2, Rn2 ### Operation $[(Rn2 \le Rm2) -> Rn2]$ with op1 This performs the paralell execution of the arithmetic left shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | <b>V</b> | C | Ζ | Ζ | Size | |------------------------------|------------------------------------------------|----------|---|---|---|------| | add_asl Rm1, Rn1, Rm2, Rn2 | Same as add_asl of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_asl Rm1, Rn1, Rm2, Rn2 | Same as cmp_asl of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asl_Rm1, Rn1, Rm2, Rn2 | Same as sub_asl of the SUB_OP2 instruction | - | - | 1 | - | 4 | | mov_asl Rm1, Rn1, Rm2, Rn2 | Same as mov_asl of the MOV_OP2 instruction | - | - | - | - | 4 | | and_asl Rm1, Rn1, Rm2, Rn2 | Same as and_asl of the AND_OP2 instruction | - | - | - | - | 4 | | or_asl Rm1, Rn1, Rm2, Rn2 | Same as or_asl of the OR_OP2 instruction | - | - | - | - | 4 | | xor_asl Rm1, Rn1, Rm2, Rn2 | Same as xor_asl of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_asl Rm1, Rn1, Rm2, Rn2 | Same as dmach_asl of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_asl_Rm1, Rn1, Rm2, Rn2 | Same as swhw_asl of the SWHW_OP2 instruction | - | - | 1 | - | 4 | | sat16_asl Rm1, Rn1, Rm2, Rn2 | Same as sat16_asl of the SAT16_OP2 instruction | - | - | - | - | 4 | #### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ASL imm, Rn1, Rm2, Rn2 ### Operation $[(Rn2 \ll Rm2) \rightarrow Rn2]$ with op1 This performs the paralell execution of the arithmetic left shift of the register (Rn2) by the lower-5-bit values of the register (Rm2) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-----------------------------|--------------------------------------------|---|---|---|---|------| | add_asl_imm4, Rn1, Rm2, Rn2 | Same as add_asl of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_asl_imm4, Rn1, Rm2, Rn2 | Same as cmp_asl of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asl_imm4, Rn1, Rm2, Rn2 | Same as sub_asl of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_asl_imm4, Rn1, Rm2, Rn2 | Same as mov asl of the MOV OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ASL Rm1, Rn1, imm, Rn2 ### Operation $[(Rn2 \le (zero\_ext)imm4* -> Rn2]$ with op1 (\*:3rd operand) This performs the paralell execution of the arithmetic left shift of the register (Rn2) by the lower-5-bit values of the immediate value (imm4) and the op1 operation between the registers (Rm1 and Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |-------------------------------|------------------------------------------------|---|---|---|---|------| | add_asl_Rm1, Rn1, imm4, Rn2 | Same as add_asl of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_asl Rm1, Rn1, imm4, Rn2 | Same as cmp_asl of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asl_Rm1, Rn1, imm4, Rn2 | Same as sub_asl of the SUB_OP2 instruction | ı | 1 | ı | - | 4 | | mov_asl_Rm1, Rn1, imm4, Rn2 | Same as mov_asl of the MOV_OP2 instruction | 1 | 1 | | - | 4 | | and_asl_Rm1, Rn1, imm4, Rn2 | Same as and_asl of the AND_OP2 instruction | - | - | - | - | 4 | | or_asl_Rm1, Rn1, imm4, Rn2 | Same as or_asl of the OR_OP2 instruction | - | - | - | - | 4 | | xor_asl Rm1, Rn1, imm4, Rn2 | Same as xor_asl of the XOR_OP2 instruction | - | - | - | - | 4 | | dmach_asl Rm1, Rn1, imm4, Rn2 | Same as dmach_asl of the DMACH_OP2 instruction | - | - | - | - | 4 | | swhw_asl_Rm1, Rn1, imm4, Rn2 | Same as swhw_asl of the SWHW_OP2 instruction | - | - | - | - | 4 | | sat16_asl_Rm1, Rn1, imm4, Rn2 | Same as sat16_asl of the SAT16_OP2 instruction | ı | - | ı | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. ### OP1\_ASL imm, Rn1, imm, Rn2 ### Operation $[(Rn2 \le (zero\_ext)imm4* -> Rn2]$ with op1 (\*:3rd operand) This performs the paralell execution of the arithmetic left shift of the register (Rn2) by the lower-5-bit values of the third-operand immediate value (imm4) and the op1 operation between the immediate value (imm) and the register (Rn1). | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |------------------------------|--------------------------------------------|---|---|---|---|------| | add_asl_imm4, Rn1, imm4, Rn2 | Same as add_asl of the ADD_OP2 instruction | - | - | - | - | 4 | | cmp_asl_imm4, Rn1, imm4, Rn2 | Same as cmp_asl of the CMP_OP2 instruction | Δ | Δ | Δ | Δ | 4 | | sub_asl_imm4, Rn1, imm4, Rn2 | Same as sub_asl of the SUB_OP2 instruction | - | - | - | - | 4 | | mov_asl_imm4, Rn1, imm4, Rn2 | Same as mov_asl of the MOV_OP2 instruction | - | - | - | - | 4 | ### Flag change When OP1 is other than the CMP instruction VF: No change CF: No change NF: No change ZF: No change When OP1 is the CMP instruction (The flag change is according to the result of the CMP instruction.) VF: "1" when overflow occurs as a 32-bit signed number; "0" in all ther cases. CF: "1" when borrow to bit 31 occurs; "0" in all other cases. NF: "1" when bit 31 of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. # Mov Lcc Parallel execution of transfer and loop-dedicated conditional branch ### MOV Lcc (Rm+, imm), Rn ### Operation This instruction is a combination instruction of MOV (Rm+), Rn operation and LCC operation. MOV (Rm+), Rn instruction $mem32(Rm) \rightarrow Rn$ $Rm + 4 \rightarrow Rm$ The data indicated by the register (Rm) is loaded from the memory (Mem), and is stored in Rn. Moreover, the register (Rm) and "4" are added to each other, and the result is stored in the register (Rm). #### Lcc instruction Lcc is used together with STLB in order to increase the loop execution speed, and performs conditional branch to the top of the loop set by SETLB. The types of condition codes (CC) are listed below. | cc | Conditions | Meaning | |----|---------------------------------|-------------------------------------------------| | eq | Z | Branch when $Z = 1$ or $Z$ flag set | | ne | ~ Z | Branch when not $Z = 1$ or $Z$ flag cleared | | gt | $\sim$ (Z or (N $^{\wedge}$ V)) | Branch when < (signed) | | ge | ~ (N ^ V) | Branch when $\leq$ (signed) | | le | Z or $(N \wedge V)$ | Branch when $\geq$ (signed) | | 1t | N ^ V | Branch when > (signed) | | hi | $\sim$ (C or Z) | Branch when < (signed) | | cc | ~ C | Branch when $\leq$ or C flag cleared (unsigned) | | 1s | C or Z | Branch when $\geq$ (unsigned) | | cs | C | Branch when > or C flag set (unsigned) | | ra | None | Always branch | #### When branch is taken LAR -4 -> nPC (the next instruction PC) The instruction loaded to the loop instruction register (LIR) is executed and instruction fetch starts for the address loaded to the loop address register (LAR). At the same time, 4 is subtracted from the loop address register (LAR) and the result is written into the PC. Even if the addition result overflows, this overflow is ignored and the result is written into the PC. Lcc is not coordinated with SETLB, execution cannot be assured. When branch is not taken PC (Self-instruction address) + CodeSize -> nPC (Next instruction PC) The next instruction is executed. | Ass | sembler mnemonic | Note | V | С | Ν | Ζ | Size | |---------|------------------|------------------------|---|---|---|---|------| | mov_leq | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_lne | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_lgt | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_lge | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_lle | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_llt | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_lhi | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | 1 | - | 4 | | mov_lcc | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_lls | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | - | - | 4 | | mov_lcs | (Rm+, imm4), Rn | imm4 is sign-extended. | - | - | 1 | - | 4 | | mov_lra | (Rm+, imm4), Rn | imm4 is sign-extended. | | | | | | ### Flag change VF: No change CF: No change NF: No change ZF: No change When Rd1=Rd2 is specified, the operation result is undefined. ### Signed multiplication instruction ### UDF00 Dm, Dn (MULQ Dm, Dn) Operation $Dm * Dn -> \{MDRQ, Dn\}$ The instruction multiplies the contents of the signed 32-bit integer register (Dm: multiplicand) by the contents of the signed 32-bit integer register (Dn: multiplier), and then stores the upper 32 bits of the 64-bit result in the MDRQ and the lower 32 bits in the Dn. | Assembler mnemonic | Note | ٧ | C | N | Ζ | Size | |--------------------|-------------|---|---|---|----------|------| | udf00 Dm, Dn | | ? | ? | Δ | $\Delta$ | 2 | | | Flag change | | | | | | VF: Undefined. CF: Undefined. NF: "1" when the MSB of the lower 32 bits of the operation result is "1"; "0" in all other cases. ZF: "1" when the lower 32 bits of the operation result is "0"; "0" in all other cases. #### imm, Dn (MULQ imm, Dn) UDF00 Operation imm \* Dn -> {MDRQ, Dn} The instruction multiplies the contents of the 32-bit sign-extended immediate value (imm: multiplicand) by the contents of the signed 32-bit integer register (Dn: multiplier), and then stores the upper 32 bits of the 64-bit result in the MDRQ and the lower 32 bits in the Dn. This instruction performs quick multiplication using the multiplier in the extension function unit. | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-------------------------|---|---|---|---|------| | udf00 imm8, Dn | imm8 is sign-extended. | ? | ? | Δ | Δ | 3 | | udf00 imm16, Dn | imm16 is sign-extended. | ? | ? | Δ | Δ | 4 | | udf00 imm32, Dn | | ? | ? | Δ | Δ | 6 | Flag change VF: Undefined. CF: Undefined. NF: "1" when the MSB of the lower 32 bits of the operation result is "1"; "0" in all other cases. ZF: "1" when the lower 32 bits of the operation result is "0"; "0" in all other cases. # UDF01 Unsigned multiplication instruction ### UDF01 Dm, Dn (MULQU Dm, Dn) Operation $Dm * Dn \rightarrow \{MDRQ, Dn\}$ The instruction multiplies the contents of the unsigned 32-bit integer register (Dm: multiplicand) by the contents of the unsigned 32-bit integer register (Dn: multiplier), and then stores the upper 32 bits of the 64-bit result in the MDRQ and the lower 32 bits in the Dn. This instruction performs quick multiplication using the multiplier in the extension function | Assembler mnemonic | Note | V | С | Ν | Ζ | Size | |--------------------|-------------|---|---|---|------------|------| | udf01 Dm, Dn | | ? | ? | Δ | $ \Delta $ | 2 | | | Flag change | | | | | | VF: Undefined. CF: Undefined. NF: "1" when the MSB of the lower 32 bits of the operation result is "1"; "0" in all other cases. ZF: "1" when the lower 32 bits of the operation result is "0"; "0" in all other cases. #### imm, Dn (MULQU imm, Dn) UDFU01 Operation imm \* Dn -> {MDRQ, Dn} The instruction multiplies the contents of the 32-bit zero-extended immediate value (imm: multiplicand) by the contents of the unsigned 32-bit integer register (Dn: multiplier), and then stores the upper 32 bits of the 64-bit result in the MDRQ and the lower 32 bits in the Dn. This instruction performs quick multiplication using the multiplier in the extension function unit. | Assembler mnemonic | Note | ٧ | С | Ν | Z | Size | |--------------------|-------------------------|---|---|---|---|------| | udfu01 imm8, Dn | imm8 is zero-extended. | ? | ? | Δ | Δ | 3 | | udfu01 imm16, Dn | imm16 is zero-extended. | ? | ? | Δ | Δ | 4 | | udfu01 imm32, Dn | | ? | ? | Δ | Δ | 6 | Flag change VF: Undefined. CF: Undefined. NF: "1" when the MSB of the lower 32 bits of the operation result is "1"; "0" in all other cases. ZF: "1" when the lower 32 bits of the operation result is "0"; "0" in all other cases. # Instruction of the saturation operation for the multiply-and-accumulate result ### UDF02 Dm, Dn (MCST32, MCST16, MCST8) #### Operation This instruction sets the contents of the multiply-and-accumulate operation overflow detect register MCVF into the V flag. In addition, depending on the value of Dm, the following operations are performed. When the value of Dm is 32 (0x00000020) (1) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 32-bit signed number (0x000000007FFFFFFF), the maximum positive value (0x7FFFFFFF) is stored in Dn. 0x7FFFFFFF -> Dn (2) If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 32-bit signed number (0xFFFFFFF80000000), the maximum negative value (0x80000000) is stored in Dn. 0x80000000 -> Dn (3) In all other cases, the contents of MCRL are stored in Dn. MCRL -> Dn When the value of Dm is 16 (0x00000010) (1) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or greater than the maximum positive value for a 16-bit signed number (0x0000000000007FFF), the maximum positive value (0x00007FFF) is stored in Dn. 0x00007FFF -> Dn (2) If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 16-bit signed number (0xFFFFFFFFFFF8000), the maximum negative value (0xFFFF8000) is stored in Dn. 0x80000000 -> Dn (3) In all other cases, the contents of MCRL are stored in Dn. $MCRL \rightarrow Dn$ When the value of Dm is 8 (0x00000008) (1) When the 32-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate register MCRL is equal to or greater than the maximum positive value for an 8-bit signed number (0x0000007F), the maximum positive value (0x7F) is stored in Dn. $0x7F \rightarrow Dn$ (2) If the value stored in the multiply-and-accumulate register MCRL is equal to or less than the maximum negative value for an 8-bit signed number (0xFFFFF80), the maximum negative value (0x80) is stored in Dn. When the value of Dm is any other value The value in Dn is undefined. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|-----------------------------------------------------------------------------|---|---|---|---|------| | udf02 Dm, Dn | When multiply-and-accumulate operation overflow was not detected (MCVF = 0) | 0 | 0 | ? | ? | 2 | | | When multiply-and-accumulate operation overflow was detected (MCVF = 1) | 1 | 0 | ? | ? | | ### Flag change When multiply-and-accumulate operation overflow was not detected $VF:\ This\ is\ "0"\ and\ indicates\ that\ the\ multiply-and-accumulate\ operation\ is\ valid.$ CF: Always "0" NF: Undefined ZF: Undefined When multiply-and-accumulate operation overflow was detected (MCVF = 1) VF: This is "1" and indicates that the multiply-and-accumulate operation is invalid. CF: Always "0" NF: Undefined ZF: Undefined # Instruction of the saturation operation for the multiply-and-accumulate result ### UDF03 Dm, Dn (MCST9 Dn) ### Operation This instruction sets the contents of the multiply-and-accumulate operation overflow detect register MCVF into the V flag. In addition, depending on the value of Dm, the following operations are performed. (1) When the 32-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate register MCRL is equal to or greater than the maximum positive value for a 9-bit signed number (0x000000FF), the maximum positive value (0xFF) is stored in Dn. $0xFF \rightarrow Dn$ (2) If the value stored in the multiply-and-accumulate register MCRL is equal to or less than the maximum negative value for a 8-bit signed number (0x00000000), the maximum negative value (0x00) is stored in Dn. 0x00000000 ->Dn (3) In all other cases, the contents of MCRL are stored in Dn. MCRL -> Dn | Assembler mnemonic | Note | V | С | N | Z | Size | |--------------------|-----------------------------------------------------|---|---|---|---|------| | udf03 Dm, Dn | When multiply-and-accumulate operation overflow was | 0 | 0 | ? | ? | 2 | | | not detected (MCVF = 0) | | | | | | | | When multiply-and-accumulate operation overflow was | 1 | 0 | ? | ? | | | | detected (MCVF = 1) | | | | | | #### Flag change When multiply-and-accumulate operation overflow was not detected VF: This is "0" and indicates that the multiply-and-accumulate operation is valid. CF: Always "0" NF: Undefined ZF: Undefined When multiply-and-accumulate operation overflow was detected (MCVF = 1) VF: This is "1" and indicates that the multiply-and-accumulate operation is invalid. CF: Always "0" NF: Undefined ZF: Undefined # Instruction of the 16-bit saturation operation ### UDF04 Dm, Dn (SAT16 Dm, Dn) #### Operation (1) When the register Dm is equal to or greater than the maximum positive value for a 16-bit signed number (0x00007FFF) 0x00007FFF -> Dn (2) When the register Dm is equal to or less than the maximum negative value for a 16-bit signed number (0xFFFF8000) 0xFFFF8000 -> Dn In all other cases, Dm -> Dn - (1) When the register Dm is equal to or greater than the maximum positive value for a 16-bit signed number (0x00007FFF), the maximum positive value (0x00007FFF) is stored in the register Dn. - (2) When the register Dm is equal to or less than the maximum negative value for a 16-bit signed number (0xFFFF8000), the maximum negative value (0xFFFF8000) is stored in the register Dn. In all other cases, the contents of the register Dm are stored in the register Dn. | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-------------|---|---|---|---|------| | udf04 Dm, Dn | | ? | ? | Δ | Δ | 2 | | | Flag change | | | | | | VF : Undefined. CF : Undefined. NF: "1" when the MSB of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0", "0" in all other cases. ### Instruction of the 24-bit saturation operation ### UDF05 Dm, Dn (SAT24 Dm, Dn) ### Operation (1) When the register Dm is equal to or greater than the maximum positive value for a 24-bit signed number (0x007FFFFF) 0x007FFFFF -> Dn (2) When the register Dm is equal to or less than the maximum negative value for a 16-bit signed number (0xFFFF8000) 0xFF800000 -> Dn In all other cases, Dm -> Dn - (1) When the register Dm is equal to or greater than the maximum positive value for a 16-bit signed number (0x007FFFFF), the maximum positive value (0x007FFFFF) is stored in the register Dn. - (2) When the register Dm is equal to or less than the maximum negative value for a 16-bit signed number (0xFF800000), the maximum negative value (0xFF800000)is stored in the register Dn. In all other cases, the contents of the register Dm are stored in the register Dn. | Assembler mnemonic | Note | ٧ | C | Ν | Ζ | Size | |--------------------|-------------|---|---|---|---|------| | udf05 Dm, Dn | | ? | ? | Δ | Δ | 2 | | | Flag change | | | | | | VF: Undefined. CF: Undefined. NF: "1" when the MSB of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0", "0" in all other cases. # Instruction of the saturation operation for the multiply-and-accumulate result ### UDF06 Dm, Dn (MCST48 Dn) #### Operation This instruction sets the contents of the multiply-and-accumulate operation overflow detect register MCVF into the V flag. (1) When the 64-bit result of the multiply-and-accumulate operation that is stored in the multiply-and-accumulate register MCRH and MCRL is equal to or greater than the maximum positive value for a 48-bit signed number (0x00007FFFFFFFFFF), the maximum positive value (0x00007FFFFFFFFFFF) is output and bits 47 through bits 16 of that output are stored in Dn. 0x7FFFFFFF -> Dn (2) If the value stored in the multiply-and-accumulate registers MCRH and MCRL is equal to or less than the maximum negative value for a 48-bit signed number (0xFFFF800000000000), the maximum negative value (0xFFFF8000000000000) is output and bits 47 through bits 16 of that output are stored in Dn. 0x80000000 -> Dn (3) In all other cases, the contents of MCRH[31:0] and MCRL[31:0] are output and bits 47 through bits 16 of that output are stored in Dn. { MCRH[15:0], MCRL[31:16] } -> Dn[31:0] | Assembler mnemonic | Note | V | С | N | Z | Size | |--------------------|-----------------------------------------------------|---|---|---|---|------| | udf06 Dm, Dn | When multiply-and-accumulate operation overflow was | 0 | 0 | ? | ? | 2 | | | not detected (MCVF = 0) | | | | | | | | When multiply-and-accumulate operation overflow was | 1 | 0 | ? | ? | | | | detected (MCVF = 1) | | | | | | #### Flag change When multiply-and-accumulate operation overflow was not detected VF: This is "0" and indicates that the multiply-and-accumulate operation is valid. CF: Always "0" NF: Undefined ZF: Undefined When multiply-and-accumulate operation overflow was detected VF: This is "1" and indicates that the multiply-and-accumulate operation is invalid. CF: Always "0" NF: Undefined ZF: Undefined ### Bit search instruction ### UDF07 Dm, Dn (BSCH Dm, Dn) ### Operation This instruction conducts a bit search within the 32-bit bit string stored in Dm, starting from the bit position of the bit number indicated by the contents of (DN - 1) and continuing in the direction of descending bit numbers. The bit number of the first bit position where a "1" is found is then stored in Dn. When the least significant five bits of Dn are zeroes, the bit search is conducted from bit 31 and continues in the direction of descending bit numbers. If the bit search reaches bit 0 without finding a "1", the "C" flag is set, 0x000000000 is written in Dn and execution of this instruction ends. When execution of this instruction starts, the upper 27 bits of Dn are ignored. | Assembler mnemonic | Note | ٧ | С | N | Z | Size | |--------------------|---------------------------------------------------|---|---|---|---|------| | udf07 Dm, Dn | When a bit search was succeeded ("1" was founded) | ? | 0 | ? | ? | 2 | | | When a bit search was not succeeded ("1" was not | ? | 1 | ? | ? | | | | founded) | | | | | | ### Flag change When a bit search was succeeded ("1" was found) VF: Undefined CF: Always "0" NF: Undefined ZF: Undefined When a bit search was not succeeded ("1" was not founded) VF: Undefined CF: Always "0" NF: Undefined ZF: Undefined Data swapping instruction that swaps bytes from high-order to low-order and vice versa in four byte data. ### UDF08 Dm, Dn (SWAP Dm, Dn) Operation $Dm[31:24] \rightarrow Dn[7:0]$ Dm[23:16] -> Dn[15:8] Dm[15:8] -> Dn[23:16] $Dm[7:0] \rightarrow Dn[31:24]$ This instruction swaps the positions of the high-order and low-order 8-bit bytes within the respective high-and low-order 16 bits in Dm, and then swaps the positions of the high-order and low-order 16 bits in Dm, and then stores the result in Dn. An example of execution is shown here. Before execution: Dm=0x12345678 -> After execution: Dn=0x78563412 | Assembler mnemonic | Note | V | С | Ν | Z | Size | |--------------------|-------------|---|---|---|---|------| | udf08 Dm, Dn | | _ | _ | - | _ | 2 | | | Flag change | | | | | | VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. Data swapping instruction that swaps bytes from high-order to low-order and vice versa in two byte data. ### UDF09 Dm, Dn (SWAPH Dm, Dn) Operation Dm[31:24] -> Dn[23:16] Dm[23:16] -> Dn[31:24] $Dm[15:8] \rightarrow Dn[7:0]$ $Dm[7:0] \rightarrow Dn[15:8]$ This instruction swaps the positions of the high-order and low-order 8-bit bytes within the respective high-and low-order 16 bits in Dm, and then stores the result in Dn. An example of execution is shown here. Before execution: Dm=0x12345678 -> After execution: Dn=0x34127856 | Assembler mnemonic | Note | ٧ | С | Ν | Ζ | Size | |--------------------|-------------|---|---|---|---|------| | udf09 Dm, Dn | | - | - | - | _ | 2 | | | Flag change | | | | | | VF: This is not changed. CF: This is not changed. NF: This is not changed. ZF: This is not changed. # Transfer instruction of the upper 32 bits in the multiply-and-accumulate register ### UDF12 Dm, Dn (GETCHX Dn) #### Operation .MCRH -> Dn MCVF -> EPSW.V This instruction stores the upper 32 bits of the multiply-and-accumulate operation register (MCRH) in the register, Dn. This sets the contents of the multiply-and-accumulate operation overflow, which is shown in MCVF, in the V flag. | Assembl | er mnemonic | Note | ٧ | С | N | Ζ | Size | |----------|-------------|-----------------------------------------------------------------------------|---|---|---|---|------| | udf12 Dm | ı, Dn | When multiply-and-accumulate operation overflow was not detected (MCVF = 0) | 0 | 0 | ? | ? | 2 | | | | When multiply-and-accumulate operation overflow was detected (MCVF = 1) | 1 | 0 | ? | ? | | #### Flag change When multiply-and-accumulate operation overflow was not detected VF: This is "0" and indicates that the multiply-and-accumulate operation is valid. CF: Always "0" NF: Undefined ZF: Undefined When multiply-and-accumulate operation overflow was detected VF: This is "1" and indicates that the multiply-and-accumulate operation is invalid. CF: Always "0" NF: Undefined ZF: Undefined # Transfer instruction of the upper 32 bits in the multiply-and-accumulate register ### UDF13 Dm, Dn (GETCLX Dn) #### Operation .MCRL -> Dn MCVF -> EPSW.V This instruction stores the lower 32 bits of the multiply-and-accumulate operation register (MCRH) in the register, Dn. This sets the contents of the multiply-and-accumulate operation overflow, which is shown in MCVF, in the V flag. | Assembler mnemonic | Note | ٧ | С | N | Ζ | Size | |--------------------|-----------------------------------------------------------------------------|---|---|---|---|------| | udf13 Dm, Dn | When multiply-and-accumulate operation overflow was not detected (MCVF = 0) | 0 | 0 | ? | ? | 2 | | | When multiply-and-accumulate operation overflow was detected (MCVF = 1) | 1 | 0 | ? | ? | | #### Flag change When multiply-and-accumulate operation overflow was not detected VF: This is "0" and indicates that the multiply-and-accumulate operation is valid. CF: Always "0" NF: Undefined ZF: Undefined When multiply-and-accumulate operation overflow was detected VF: This is "1" and indicates that the multiply-and-accumulate operation is invalid. CF: Always "0" NF: Undefined ZF: Undefined ### Transfer instruction of the highspeed multiplication register | UDF | 15 Dm, Dn | (GETX Dn) | | | | | | |-----------|------------------------|------------------------------------------------------|-----|-------|------|----|------| | Operation | MDRQ -> Dn | | | | | | | | | The instruction stores | the high-speed multiplication register (MDRQ) in the | reg | ister | , Dn | ١. | | | Asse | embler mnemonic | Note | ٧ | С | N | Z | Size | | udf15 Dm | , Dn | | 0 | 0 | Δ | Δ | 2 | | | | Flag change | | | | | | | VF : Ur | ndefined. | | | | | | | VF: Undefined. CF: Undefined. NF: "1" when the MSB of the operation result is "1"; "0" in all other cases. ZF: "1" when the operation result is "0"; "0" in all other cases. #### Transfer (Floating-point unit) ## FMOV Mem, FSn Operation FMOV in the case of (Rm), FSn mem32(Rm) -> FSn FMOV in the case of (SP), FSn mem32(SP) -> FSn FMOV in the case of (Rm, Ri), FSn mem32(Rm+Ri) -> FSn FMOV in the case of (disp, Rm), FSn mem32(Rm+disp) -> FSn FMOV in the case of (disp, SP), FSn mem32(SP+disp) -> FSn Memory contents are stored in the single-precision floating-point register (FSn). | A1.1 | Nata | | Е | C fl | ag | | | FCC | C fla | g | c. | |---------------------|-----------------------|---|---|------|----|---|---|-----|-------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Е | U | Size | | fmov (Rm), FSn | | - | - | - | - | - | - | - | - | - | 3 | | fmov (SP), FSn | | - | - | - | - | - | - | - | - | - | 3 | | fmov (Rm, Ri), FSn | | - | - | - | - | - | - | - | - | | 4 | | fmov (d8, Rm), FSn | d8 is code-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov (d24, Rm), FSn | d24 is code-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov (d32, Rm), FSn | | - | - | - | - | - | - | - | - | - | 7 | | fmov (d8, SP), FSn | d8 is zero-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov (d24, SP), FSn | d24 is zero-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov (d32, SP), FSn | | - | - | - | - | - | | - | - | - | 7 | #### Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change When the memory address is not a multiple of 4, a system exception (address misalignment exception) occurs. ### FMOV FSm, Mem Operation FMOV in the case of FSm, (Rn) FSm -> mem32 (Rn) FMOV in the case of FSm, (SP) FSm -> mem32 (SP) FMOV in the case of FSm, (Rn, Ri) FSm -> mem32 (Rn+Ri) FMOV in the case of FSm, (disp, Rn) FSm -> mem32 (Rn+disp) FMOV in the case of FSm, (disp, SP) FSm -> mem32 (SP+disp) The contents of the single-precision floating-point register (FSn) are stored in the memory. | Assembler mnemonic | N | | Е | C fla | ag | | | FCC | flag | 3 | Size | |---------------------|-----------------------|---|---|-------|----|---|---|-----|------|---|------| | Assembler inhemonic | Notes | ٧ | Ζ | 0 | U | I | L | G | Е | U | Size | | fmov FSm, (Rn) | | - | - | - | - | - | - | - | - | - | 3 | | fmov FSm, (SP) | | - | - | - | - | - | - | - | - | - | 3 | | fmov FSm, (Rn, Ri) | | - | - | - | - | - | - | - | - | - | 4 | | fmov FSm, (d8, Rn) | d8 is code-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov FSm, (d24, Rn) | d24 is code-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov FSm, (d32, Rn) | | - | - | - | - | - | - | - | - | - | 7 | | fmov FSm, (d8, SP) | d8 is zero-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov FSm, (d24, SP) | d24 is zero-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov FSm, (d32, SP) | | - | - | - | - | - | - | - | - | - | 7 | #### Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change UF: No change When the memory address is not a multiple of 4,a system exception (address misalignment exception) occurs. ## FMOV (Rm+), FSn #### Operation mem32(Rm) -> FSn Rm + 0x00000004 -> Rm Data specified by the register (Rm) are loaded from the memory and stored in the single-precision floating-point register (FSn). Moreover, the register (Rm) and 4 are added and the result is stored in the register (Rm). | A 11 | Note | | Е | C fla | ag | | ] | FCC | flag | , | Size | |--------------------|------|---|---|-------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Ε | С | Size | | fmov (Rm+), FSn | | - | - | - | - | - | - | - | - | - | 3 | VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change When memory address is not a multiple of 4, system exception (address misalignment exception) occurs. ### FMOV (Rm+, imm), FSn #### Operation mem32(Rm) -> FSn $Rm + imm \rightarrow Rm$ Data specified by the register (Rm) are loaded from the memory (Mem) and stored in the contents of the single-precision floating-point register (FSn). Moreover, the register (Rm) and immediate value (imm) are added and the result is stored in the register (Rm). | | | | Е | C fla | ıg | | J | FCC | flag | | | |------------------------|-------------------------|---|---|-------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | V | Ζ | 0 | U | I | L | G | E | U | Size | | fmov (Rn+, imm8), FSn | imm8 is code-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov (Rn+, imm24), FSn | imm24 is code-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov (Rn+, imm32), FSn | | - | - | - | - | - | - | - | - | - | 7 | #### Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change When memory address is not a multiple of 4, system exception (address misalignment exception) occurs. ### FMOV FSm, (Rn+) Operation FSm -> mem32(Rn) Rn + 0x00000004 -> Rn The contents of the single-precision floating-point register (FSm) are stored in the memory specified by the register (Rn). Moreover, the register (Rn) and 4 are added and the result is stored in the register (Rn). | Accomblar mamonia | NI / | | Е | C fl | ag | | | FCC | flag | 3 | Size | |--------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | ı | L | G | Е | U | Size | | fmov FSn, (Rn+) | | - | - | - | - | - | - | - | - | - | 3 | Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change When the memory address is not a multiple of 4, system exception (address misalignment exception) occurs. ### FMOV FSm, (Rn+, imm) #### Operation FSm -> mem32 (Rn) $Rn + imm \rightarrow Rn$ The contents of the single-precision floating-point register (FSm) are stored in the memory (Mem) specified by the register (Rn). Moreover, the register (Rn) and immediate value (imm) are added and the result is stored in the register (Rn). | A11 | N | | Е | C fla | ıg | | | FCC | C fla | g | Size | |------------------------|-------------------------|---|---|-------|----|---|---|-----|-------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | - | L | G | Е | U | Size | | fmov FSm, (Rn+, imm8) | imm8 is code-extended. | - | - | - | - | 1 | - | - | - | - | 4 | | fmov FSm, (Rn+, imm24) | imm24 is code-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov FSm, (Rn+, imm32) | | - | - | - | - | - | - | - | - | - | 7 | #### Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change UF: No change When the memory address is not a multiple of 4, system exception (address misalignment exception) occurs. #### FMOV FSm, FSn Operation FSm -> FSn The contents of the single-precision-floatingpoint register (FSm) are stored in the single-precision floating-point register (FSn). FCC flag EC flag Assembler mnemonic Note Size EU 0 U I G 3 fmov FSm, FSn Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change #### FMOV FSm, Rn Operation FSm -> Rn The contents of the single-precision floating-point register (FSm) are stored in the register (Rn). FCC flag EC flag Assembler mnemonic Note Size 0 UI GE U fmov FSm, Rn 3 Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change #### FMOV Rm,FSn Operation Rm -> FSn The contents of the register (Rm) are stored in the single-precision floating-point register (FSn). EC flag FCC flag Assembler mnemonic Note Size GEU $O \mid U$ 3 fmov Rm,FSn Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change #### FMOV imm,FSn Operation imm32 -> FSn The immediate value (imm) is stored in the single-precision floating-point register (FSn). EC flag FCC flag Assembler mnemonic Note Size GEU 7 fmov imm32,FSn Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change #### FMOV FPCR,Rn Operation FPCR -> Rn The contents of the floating-point control unit register (FPCR) are stored in the register (Rn). EF flag EC flag FCC flag Assembler mnemonic Note Size ZOUI G E U $Z \mid O \mid U$ fmov FPCR,Rn 3 Flag change EF flag VF: No change ZF: No change OF: No change UF: No change IF: No change EC flag VF: No change ZF: No change OF: No change UF: No change IF: No change FCC flag LF: No change GF: No change EF: No change UF: No change ### FMOV Rm, FPCR Operation Rm -> FPCR The contents of the register (Rm) are stored in the floating-point control unit register (FCPR). | Assembler mnemonic | Note | | Е | F fla | ıg | | | Е | C fla | ıg | | ] | FCC | flag | 5 | Size | |-------------------------|------|---|---|-------|----|---|---|---|-------|----|---|---|-----|------|---|------| | Assembler fillefilottic | Note | ٧ | Ζ | 0 | U | I | > | Ζ | 0 | U | I | L | G | Ε | U | Size | | fmov Rm,FPCR | | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Δ | Δ | 3 | Flag change EF flag VF: This is "0" when Bit 4 of the source data is "1". This not changed when Bit 4 of the source data is "0". ZF: This is "0" when Bit 3 of the source data is "1". This is not changed when Bit 3 of the source data is "0". OF: This is "0" when Bit 2 of the source data is "1". This is not changed when Bit 2 of the source data is "0". UF: This is "0" when Bit 1 of the source data is "1". This is not changed when Bit 1 of the source data is "0". IF: This is "0" when Bit 0 of the source data is "1". This is not changed when Bit 0 of the source data is "0". EC flag VF: Bit 14 of the source data is set. ZF: Bit 13 of the source data is set. OF: Bit 12 of the source data is set. UF: Bit 11 of the source data is set. IF: Bit 10 of the source data is set. FCC flag LF: Bit 21 of the source data is set. GF: Bit 20 of the source data is set. EF: Bit 19 of the source data is set. UF: Bit 18 of the source data is set. #### FMOV imm, FPCR Operation imm32 -> FPCR The contents of the immediate values (imm32) are stored in the floating-point control unit register EF flag EC flag FCC flag Assembler mnemonic Note Size ZOU G E U $Z \mid O \mid U$ fmov imm32,FPCR Δ 6 Flag change EF flag VF: This is "0" when Bit 4 of the source data is "1". This not changed when Bit 4 of the source data is "0". ZF: This is "0" when Bit 3 of the source data is "1". This is not changed when Bit 3 of the source data is "0". OF: This is "0" when Bit 2 of the source data is "1". This is not changed when Bit 2 of the source data is "0". UF: This is "0" when Bit 1 of the source data is "1". This is not changed when Bit 1 of the source data is "0". IF: This is "0" when Bit 0 of the source data is "1". This is not changed when Bit 0 of the source data is "0". EC flag VF: Bit 14 of the source data is set. ZF: Bit 13 of the source data is set. OF: Bit 12 of the source data is set. UF: Bit 11 of the source data is set. IF: Bit 10 of the source data is set. FCC flag LF: Bit 21 of the source data is set. GF: Bit 20 of the source data is set. EF: Bit 19 of the source data is set. UF: Bit 18 of the source data is set. ### FMOV Mem,FDn Operation FMOV (Rm),FDn mem64(Rm) -> FDn FMOV (SP),FDn mem64(SP) -> FDn FMOV (Rm,Ri),FSn mem64(Rm + Ri) -> FDn FMOV (disp,Rm),FDn mem64(disp+ Rm ) -> FDn FMOV (disp,SP),FDn mem64(disp+ SP) -> FDn $FDn \rightarrow \{FSn+1,FSn\}$ (n: even) The contents of the 64-bit memory are stored in the double-precision floating point register (FDn). | Assembler mnemonic | Note | | Е | C fl | ag | | | FCC | flag | 5 | Size | |---------------------|-----------------------|---|---|------|----|---|---|-----|------|---|------| | Assembler inhemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Е | U | Size | | fmov (Rm),FDn | | ı | - | - | - | - | - | - | - | - | 3 | | fmov (SP),FDn | | - | - | - | - | - | - | - | - | - | 3 | | fmov (Rm,Ri),FDn | | - | - | - | - | - | - | - | - | - | 4 | | fmov (d8,Rm),FDn | d8 is sign-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov (d24,Rm),FDn | d24 is sign-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov (d32,Rm),FDn | | - | - | - | - | - | - | - | - | - | 7 | | fmov (d8,SP),FDn | d8 is zero-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov (d24,SP),FDn | d24 is zero-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov (d32,SP),FDn | | - | - | - | - | - | - | - | - | - | 7 | #### Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change When the Mem address is not a multiple of 8, system exception (Address misalignment exception) occurs. ### FMOV FDm,Mem Operation FMOV FDm,(Rn) $FDm \rightarrow mem64(Rn)$ FMOV FDm,(SP) FDm -> mem64(SP) FMOV FDm,(Rn,Ri) $FDm \rightarrow mem64(Rn + Ri)$ FMOV FDm,(disp,Rn) FDm -> mem64(Rn + disp) FMOV FDm,(disp,SP) FDm -> mem64(SP + disp) $FDm \rightarrow \{FSm+1,FSm\} (m : even)$ The contents of the double-precision floating point register (FDm) are stored in the 64-bit memory. | Assembler mnemonic | Note | | E | C fl | ag | | | FCC | flag | 5 | Size | |---------------------|-----------------------|---|---|------|----|---|---|-----|------|---|------| | Assembler inhemonic | Note | ٧ | Z | 0 | U | I | L | G | Е | U | Size | | fmov FDm,(Rn) | | - | - | - | - | - | - | - | - | - | 3 | | fmov FDm,(SP) | | - | - | - | - | - | - | - | - | - | 3 | | fmov FDm,(Rn,Ri) | | - | - | - | - | - | - | - | - | - | 4 | | fmov FDm,(d8,Rn) | d8 is sign-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov FDm,(d24,Rn) | d24 is sign-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov FDm,(d32,Rn) | | - | - | - | - | - | - | - | - | - | 7 | | fmov FDm,(d8,SP) | d8 is zero-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov FDm,(d24,SP) | d24 is zero-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov FDm,(d32,SP) | | - | - | - | - | - | - | - | - | - | 7 | Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change When the Mem address is not a multiple of 8, system exception (Address misalignment exception) occurs. ## FMOV (Rm+),FDn Operation mem64(Rm)-> FDn Rm + 0x00000008 -> Rm $FDn = \{FSn+1,FSn\}$ (n:even) The contents of the 64-bit memory which is specified by the register (Rm) are stored in the double-precision floating-point register (FDn). Then, 0x00000008 is added to the register (Rm). | Assambler mnamonic | Note | | Е | C fla | ag | | | FCC | flag | 5 | Siza | |--------------------|------|---|---|-------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Е | U | Size | | fmov (Rm+),FDn | | - | - | - | - | - | - | - | - | - | 3 | Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change When the Mem address is not a multiple of 8, system exception (Address misalignment exception) occurs. #### FMOV (Rm+,imm),FDn Operation $mem64(Rm) \rightarrow FDn$ $Rm + imm \rightarrow Rm$ $FDn = \{FSn+1,FSn\}$ (n:even) The contents of the 64-bit memory which is specified by the register (Rm) are stored in the doubleprecision floating-point register (FDn). Then, an immediate value is added to the register (Rm). | Assembler mnemonic | Note | | Е | C fla | ag | | | FCC | flag | 5 | Size | |----------------------|-------------------------|---|---|-------|----|---|---|-----|------|---|------| | Assembler inhemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Е | U | Size | | fmov (Rm+,imm8),FDn | imm8 is sign-extended. | - | - | - | - | - | - | - | - | - | 4 | | fmov (Rm+,imm24),FDn | imm24 is sign-extended. | - | - | - | - | - | - | - | - | - | 6 | | fmov (Rm+,imm32),FDn | | - | - | - | - | - | - | - | - | - | 7 | Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change When the Mem address is not a multiple of 8, system exception (Address misalignment exception) occurs. ## FMOV FDm,(Rn+) Operation $FDm \rightarrow mem64(Rn)$ Rn + 0x00000008 -> Rn $FDm = \{FSm+1, FSm\}(m:even)$ The contents of the double-precision floating-point register (FDm) which is specified by the register (Rn) are stored in the 64-bit memory. Then 0x000000008 is added to the register (Rn). | Assembler mnemonic | Note | | Е | C fla | ag | | | FCC | flag | 3 | Size | |---------------------|------|---|---|-------|----|---|---|-----|------|---|------| | Assembler inhemonic | Note | ٧ | Ζ | 0 | U | 1 | L | G | E | U | Size | | fmov FDm,(Rn+) | | - | - | - | - | - | - | - | - | - | 3 | #### Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change When the Mem address is not a multiple of 8, system exception (Address misalignment exception) occurs. ### FMOV FDm,(Rn+,imm) Operation $FDm \rightarrow mem64(Rn)$ $Rn + imm \rightarrow Rn$ $FDm = \{FSm+1, FSm\}(m:even)$ The contents of the double-precision floating-point register (FDm) are stored in the 64-bit memory specified by the register (Rn). Then an immediate value is added to the register (Rn). | Assembler mnemonic | Note | EC flag | | | | | | FCC | Size | | | |----------------------|------------------------|---------|---|---|---|---|---|-----|------|---|------| | Assembler inhemonic | Note | > | Ζ | 0 | U | I | L | G | Е | U | Size | | fmov FDm,(Rn+,imm8) | imm8 is sign-extended | ı | - | - | - | ı | - | - | 1 | - | 4 | | fmov FDm,(Rn+,imm24) | imm24 is sign-extended | - | - | - | - | - | - | - | - | - | 6 | | fmov FDm,(Rn+,imm32) | | - | - | - | - | - | - | - | - | - | 7 | #### Flag change VF: No change ZF: No change OF: No change UF: No change IF: No change LF: No change GF: No change EF: No change UF: No change When the Mem address is not a multiple of 8, system exception (Address misalignment exception) occurs. ### FABS FSn #### Operation | FSn | -> FSn This takes an absolute value of the register (FSn), and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | flag | g | Size | |--------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | ı | L | G | Ε | U | Size | | fabs FSn | | - | - | - | - | - | - | - | - | - | 3 | #### Flag change VF: This is not changed. ZF: This is not changed. OF: This is not changed. UF: This is not changed. IF: This is not changed. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ### FABS FSm, FSn #### Operation | FSm | -> FSn This takes an absolute value of the register (FSm), and stores the result in the register (FSn). | | | | F | EC fl | ag | | | FCC | flag | g | Size | |--------------------|------|---|---|-------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | 1 | L | G | Е | U | Size | | fabs FSm, FSn | | - | - | - | - | - | - | - | - | - | 4 | #### Flag change VF: This is not changed. ZF: This is not changed. OF: This is not changed. UF: This is not changed. IF: This is not changed. LF: This is not changed. GF: This is not changed. EF: This is not changed. ### Floating-point negative numbers ### FNEG FSn Operation FSn \* (-1) -> FSn This multiplies the register (FSn) by -1, and stores the result in the register (FSn). | | | | E | C fl | ag | | | FCC | flag | 3 | Size | |--------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Ε | U | Size | | fneg FSn | | - | - | - | - | - | - | - | - | - | 3 | #### Flag change VF: This is not changed. ZF: This is not changed. OF: This is not changed. UF: This is not changed. IF: This is not changed. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ### FNEG FSm, FSn Operation FSn \* (-1) -> FSn This multiplies the register (FSm) by -1, and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | fla | g | Size | |--------------------|------|---|---|------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | ı | L | G | Е | U | Size | | fneg FSm, FSn | | - | - | - | - | - | - | - | - | - | 4 | #### Flag change VF: This is not changed. ZF: This is not changed. OF: This is not changed. UF: This is not changed. IF: This is not changed. LF: This is not changed. GF: This is not changed. EF: This is not changed. # FRSORT 1/square root of the floating point ### FRSQRT FSn Operation 1/Sqrt (FSn) -> FSn This stores the reciprocal of the square root of the register (FSn) in the register FSn). | | | | Е | C fla | ag | | | FCC | flag | 3 | Size | |--------------------|------|---|---|-------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | ı | L | G | Ε | U | Size | | frsqrt FSm | | Δ | Δ | 0 | 0 | Δ | - | - | - | - | 3 | #### Flag change VF: This is "1" when the source data is sNaN, negative normalized numbers, or -INF. This is "0" in all other cases. ZF: This is "1" when the source data is $\pm 0$ . This is "0" in all other cases. OF: This is always "0". UF: This is always "0". IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ### FRSQRT FSm, FSn Operation 1/Sqrt (FSn) -> FSn This stores the reciprocal of the square root of the register (FSm) in the register (FSn). | | | | Е | C fl | ag | | | FCC | flag | g | Size | |--------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | Ι | L | G | Ε | U | Size | | frsqrt FSm, FSn | | Δ | Δ | 0 | 0 | Δ | - | - | - | - | 4 | #### Flag change VF: This is "1" when the source data is sNaN, negative normalized numbers, or -INF. This is "0" in all other cases. ZF: This is "1" when the source data is $\pm 0$ . This is "0" in all other cases. OF: This is always "0". UF: This is always "0". IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. #### (1) When the FPU operation exception enable flag is "1" | FSm | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | |-------------|--------|-------|----|----|------|------|------|------| | Data Output | 1/Sqrt | - | ı | ı | +0 | ı | qNaN | 1 | | FSm | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | |---------|--------|-------|----|----|------|------|------|------| | EC Flag | 1/Sqrt | V | Z | Z | 0 | V | 0 | V | #### (1-1) 1/Sqrt | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | 0 | | 0xff7fffff ≤v ≤ 0x80800000 | */- | 0 / I | | 0x80800000 <v <0<="" td=""><td>-</td><td>U</td></v> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */ - | 0/I | | 0x7f7fffff < v | - | О | #### (2) When the FPU operation exception enable flag is "0" $\,$ | FSm | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | |-------------|--------|-------|------|------|------|------|------|------| | Data Output | 1/Sqrt | qNaN | +INF | -INF | +0 | qNaN | qNaN | qNaN | | FSm | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | |---------|--------|-------|----|----|------|------|------|------| | EC Flag | 1/Sart | _ | _ | _ | _ | _ | _ | _ | #### (2-1) 1/Sqrt | Calculation result | Data Output | EC Flag | |------------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v <0<="" td=""><td>-0</td><td>-</td></v> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | ### Comparison of the floating-point data ### FCMP FSm1, FSm2 #### Operation FSm2 - FSm1 : FPCR (EC) This subtracts the register (FSm1) from the register (FSm2), and reflects the result in the floating-point unit control register (FPCR). | | | | Е | C fl | ag | | | FCC | flag | g | Size | |--------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Ε | U | Size | | fcmp FSm1, FSm2 | | Δ | 0 | 0 | 0 | 0 | Δ | Δ | Δ | Δ | 3 | #### Flag change VF: This is "1" when the source data is sNaN. This is "0" in all other cases. ZF: This is always "0". OF: This is always "0". UF: This is always "0". IF: This is always "0". LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ### FCMP imm, FSm #### Operation FSm - imm32 : FPCR (EC) This subtracts the register (FSm1) from the register (FSm2), and reflects the result in the floating-point unit control register (FPCR). | | | | Е | C fl | ag | | | FCC | fla | g | Size | |----------------------|------|---|---|------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | V | Ζ | 0 | U | I | L | G | Ε | U | Size | | fcmp imm32, FSm, FSn | | Δ | 0 | 0 | 0 | 0 | Δ | Δ | Δ | Δ | 3 | #### Flag change VF: This is "1" when the source data is sNaN. This is "0" in all other cases. ZF: This is always "0". OF: This is always "0". UF: This is always "0". IF: This is always "0". LF: This is "1" when FSm1>FSm2 or fimm32>FSm. GF: This is "1" when FSm1>FSm2 or fimm32>FSm. EF: This is "1" when FSm1=FSm2 or fimm32=FSm. UF: This is "1" when comparison is impossible. ### (1) When the FPU operation exception enable flag is "1" | Data ( | Data Output | | FSm2 / FSm | | | | | | | | | | |--------|-------------|---|------------|----|------|------|------|------|--|--|--|--| | Data | | | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | - | - | - | - | - | - | - | | | | | | | +0 | - | - | - | - | - | - | - | | | | | | FSm1 / | -0 | - | - | - | - | ı | - | ı | | | | | | imm32 | +INF | - | - | - | - | - | - | - | | | | | | | -INF | - | - | - | - | ı | - | ı | | | | | | | qNaN | - | - | - | - | ı | - | ı | | | | | | | sNaN | - | - | - | - | - | - | - | | | | | | FC | EC Flag | | FSm2 / FSm | | | | | | | | | | |--------|---------|------|------------|----|------|------|------|------|--|--|--|--| | Lering | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | +0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | FSm1 / | -0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | imm32 | +INF | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | -INF | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | sNaN | V | V | V | V | V | V | V | | | | | | FCC Flag | | | FSm2 / FSm | | | | | | | | | | |----------|------|------|------------|-----|------|------|------|------|--|--|--|--| | | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | CMP | CMP | CMP | G | L | U | 0 | | | | | | | +0 | CNP | Е | Е | G | L | U | 0 | | | | | | FSm1 / | -0 | CNP | Е | Е | G | L | U | 0 | | | | | | imm32 | +INF | L | L | L | Е | L | U | 0 | | | | | | | -INF | G | G | G | G | Е | U | 0 | | | | | | | qNaN | U | U | U | U | U | U | 0 | | | | | | | sNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | #### (1-1) CMP instruction | Calculation result | Data Output | EC Flag | FCC Flag | |--------------------------------------------------------------|-------------|---------|----------| | v < 0xff7fffff | - | - | L | | 0xff7fffff ≤v ≤ 0x80800000 | - | - | L | | 0x80800000 <v<0< td=""><td>-</td><td>-</td><td>L</td></v<0<> | - | - | L | | 0 | - | - | Е | | 0 < v < 0x00800000 | - | - | G | | $0x00800000 \le v \le 0x7f7fffff$ | - | - | G | | 0x7f7fffff < v | - | - | G | ### (1) When the FPU operation exception enable flag is "0" | Data ( | Dutnut | | FSm2 / FSm | | | | | | | | | | |-------------|--------|------|------------|----|------|------|------|------|--|--|--|--| | Data Output | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | - | - | - | - | - | - | - | | | | | | | +0 | - | - | - | - | - | - | - | | | | | | FSm1/ | -0 | - | - | - | - | - | - | - | | | | | | imm32 | +INF | - | - | - | - | - | - | - | | | | | | | -INF | - | | - | 1 | - | - | - | | | | | | | qNaN | - | ı | - | ı | - | - | - | | | | | | | sNaN | _ | - | _ | - | _ | _ | _ | | | | | | FC | EC Flag | | FSm2 / FSm | | | | | | | | | | |--------|---------|---|------------|----|------|------|------|------|--|--|--|--| | LC. | | | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | - | - | - | - | - | - | - | | | | | | | +0 | - | - | - | - | - | - | - | | | | | | FSm1 / | -0 | - | - | - | - | - | - | - | | | | | | imm32 | +INF | - | - | - | - | - | - | - | | | | | | | -INF | - | - | - | - | - | - | - | | | | | | | qNaN | - | - | - | - | - | - | - | | | | | | | sNaN | _ | _ | _ | - | - | _ | - | | | | | | FCC | Flag | | FSm2 / FSm | | | | | | | | | | |--------|-------|------|------------|-----|------|------|------|------|--|--|--|--| | 100 | 1 145 | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | CMP | CMP | CMP | G | L | U | U | | | | | | | +0 | CNP | Е | Е | G | L | U | U | | | | | | FSm1 / | -0 | CNP | Е | Е | G | L | U | U | | | | | | imm32 | +INF | L | L | L | Е | L U | | U | | | | | | | -INF | G | G | G | G | Е | U | U | | | | | | | qNaN | U | U | U | U | U | U | U | | | | | | | sNaN | U | U | U | U | U | U | U | | | | | #### (2-1) CMP instruction | Calculation result | Data Output | EC Flag | FCC Flag | |--------------------------------------------------------------|-------------|---------|----------| | v < 0xff7fffff | - | - | L | | 0xff7fffff ≤v ≤ 0x80800000 | - | - | L | | 0x80800000 <v<0< td=""><td>-</td><td>-</td><td>L</td></v<0<> | - | - | L | | 0 | - | - | Е | | 0 < v < 0x00800000 | - | - | G | | $0x00800000 \le v \le 0x7f7fffff$ | - | - | G | | 0x7f7fffff < v | - | - | G | ### Addition of the floating-point data ### FADD FSm, FSn #### Operation FSn + FSm -> FSn This adds the contents of the register (FSn) and the register (FSm) to each other, and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | flag | g | Size | |--------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | Ι | L | G | Ε | U | Size | | fadd FSm, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | ı | - | 3 | #### Flag change VF: This is "1" when the source data is sNaN or (+INF)+(-INF). This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ### FADD FSm1, FSm2, FSn #### Operation FSm1 + FSm2 -> FSn This adds the contents of the register (FSm2) and the register (FSm1) to each other, and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | fla | g | Size | |----------------------|------|---|---|------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | ٧ | Z | 0 | U | Ι | L | G | Е | U | Size | | fadd FSm1, FSm2, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 4 | #### Flag change VF: This is "1" when the source data is sNaN or (+INF)+(-INF). This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between $\pm 2$ Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. ### FADD imm, FSm, FSn #### Operation FSm + imm32 -> FSn This adds the register (FSm) to the immediate value (imm32), and stores the result in the register (FSn). | | | | Е | C fla | ag | | | FCC | fla | g | Size | |----------------------|------|---|---|-------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | Ι | L | G | Е | U | Size | | fadd imm32, FSm, FSn | | Δ | - | Δ | Δ | Δ | - | - | - | - | 7 | #### Flag change VF: This is "1" when the source data is sNaN or (+INF)+(-INF). This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. #### (1) When the FPU operation exception enable flag | Data ( | Output | | FSm2 / FSm | | | | | | | | | | |--------|----------|------|------------|------|------|------|------|------|--|--|--|--| | Duta | Juipui | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | ADD | ADD | ADD | +INF | -INF | qNaN | - | | | | | | | +0 | ADD | +0 | +0 | +INF | -INF | qNaN | - | | | | | | FSm1/ | -0 | ADD | +0 | -0 | +INF | -INF | qNaN | - | | | | | | imm32 | +INF | +INF | +INF | +INF | +INF | - | qNaN | - | | | | | | | -INF | -INF | -INF | -INF | - | -INF | qNaN | - | | | | | | | qNaN qNa | | qNaN | qNaN | qNaN | qNaN | qNaN | | | | | | | | sNaN | - | - | - | - | - | - | - | | | | | | EC 1 | Flaσ | | FSm2 / FSm | | | | | | | | | | | |--------|------|------|------------|----|------|------|------|------|--|--|--|--|--| | LC. | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | ADD | 0 | 0 | 0 | 0 | 0 | V | | | | | | | | +0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | FSm1 / | -0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | imm32 | +INF | 0 | 0 | 0 | 0 | V | 0 | V | | | | | | | | -INF | 0 | 0 | 0 | V | 0 | 0 | V | | | | | | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | | sNaN | V | V | V | V | V | V | V | | | | | | #### (1-1) ADD instruction | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | О | | 0xff7fffff ≤v ≤ 0x80800000 | */ - | 0 / I | | 0x80800000 <v <0<="" td=""><td>-</td><td>U</td></v> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */- | 0 / I | | 0x7f7fffff < v | - | О | ### (2) When the FPU operation exception enable flag is "0" $\,$ | Data ( | Output | | FSm2 / FSm | | | | | | | | | | |--------|--------|--------------------------|------------|------|------|------|------|------|--|--|--|--| | Data | Juipui | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | NORM | ADD | ADD | ADD | +INF | -INF | qNaN | qNaN | | | | | | | +0 | ADD | +0 | +0 | +INF | -INF | qNaN | qNaN | | | | | | FSm1 / | -0 | ADD | +0 | -0 | +INF | -INF | qNaN | qNaN | | | | | | imm32 | +INF | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | | | | | | | -INF | -INF | -INF | -INF | qNaN | -INF | qNaN | qNaN | | | | | | | qNaN | qNaN qNaN qNaN qNaN qNaN | | qNaN | qNaN | qNaN | qNaN | | | | | | | | sNaN | qNaN | | | | | FC | Flag | | | F | Sm2 / FS1 | m | | | |--------|------|------|----|----|-----------|------|------|------| | LC. | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | FSm1 / | -0 | - | - | - | - | - | - | - | | imm32 | +INF | - | - | - | 1 | - | - | - | | | -INF | - | - | - | ı | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | #### (2-1) ADD instruction | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v<0< td=""><td>-0</td><td>-</td></v<0<> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | ### FSUB FSm, FSn #### Operation FSn - FSm -> FSn This subtracts the contents of the register (FSm) from the contents of the register (FSn), and stores the result in the register (FSn). | | | | | Е | C fl | ag | | FCC flag | | | | Size | |------|--------------------|------|---|---|------|----|---|----------|---|---|---|------| | | Assembler mnemonic | Note | V | Ζ | 0 | U | I | L | G | Ε | U | Size | | fsud | FSm, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 3 | #### Flag change VF: This is "1" when the source data is sNaN or (±INF)+(±INF). This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ### FSUB FSm1, FSm2, FSn #### Operation FSm2 - FSm1 -> FSn This subtracts the contents of the register (FSm1) from the contents of the register (FSm2), and stores the result in the register (FSn). | | | | Е | C fla | ag | | | FCC | fla | g | Size | |----------------------|------|---|---|-------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Е | U | Size | | fsub FSm1, FSm2, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 4 | #### Flag change VF: This is "1" when the source data is sNaN or (±INF)+(±INF). This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. #### **FSUB** imm, FSm, FSn Operation FSm - imm32 -> FSn This subtracts the immeidiate value (imm32) from the contents of the register (FSm), and stores the result in the register (FSn). | | | | Е | C fla | ag | | | FCC | fla | g | Size | |----------------------|------|---|---|-------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Ε | U | Size | | fsub imm32, FSm, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 7 | Flag change VF: This is "1" when the source data is sNaN or (±INF)+(±INF). This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. #### (1) When the FPU operation exception enable flag is "1" | Data ( | Output | | FSm2 / FSm | | | | | | | | | | | |--------|--------|------|------------|------|------|------|------|------|--|--|--|--|--| | Data | Juipui | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | SUB | SUB | SUB | +INF | -INF | qNaN | - | | | | | | | | +0 | SUB | +0 | -0 | +INF | -INF | qNaN | - | | | | | | | FSm1 / | -0 | SUB | +0 | +0 | +INF | -INF | qNaN | - | | | | | | | imm32 | +INF | -INF | -INF | -INF | • | -INF | qNaN | - | | | | | | | | -INF | +INF | +INF | +INF | +INF | • | qNaN | - | | | | | | | | qNaN - | | | | | | | | sNaN | - | - | _ | - | - | - | - | | | | | | | EC 1 | Flaσ | | FSm2 / FSm | | | | | | | | | | | |-------|------|------|------------|----|------|------|------|------|--|--|--|--|--| | LC | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | SUB | 0 | 0 | 0 | 0 | 0 | V | | | | | | | | +0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | FSm1/ | -0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | imm32 | +INF | 0 | 0 | 0 | V | 0 | 0 | V | | | | | | | | -INF | 0 | 0 | 0 | 0 | V | 0 | V | | | | | | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | | sNaN | V | V | V | V | V | V | V | | | | | | #### (1-1) SUB instruction | Calculation result | Data Output | EC Flag | |----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | 0 | | $0xff7fffff \le v \le 0x80800000$ | */- | 0 / I | | 0x80800000 <v<0< td=""><td>-</td><td>U</td></v<0<> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */- | 0 / I | | 0x7f7fffff < v | - | О | ### (2) When the FPU operation exception enable flag is "0" $\,$ | Data ( | Data Output | | FSm2 / FSm | | | | | | | | | | | |--------|-------------|------|------------|------|------|------|------|------|--|--|--|--|--| | Data | Juipui | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | SUB | SUB | SUB | +INF | -INF | qNaN | qNaN | | | | | | | | +0 | SUB | +0 | -0 | +INF | -INF | qNaN | qNaN | | | | | | | FSm1 / | -0 | SUB | +0 | +0 | +INF | -INF | qNaN | qNaN | | | | | | | imm32 | +INF | -INF | -INF | -INF | qNaN | -INF | qNaN | qNaN | | | | | | | | -INF | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | | | | | | | | qNaN | | | | | | | sNaN | qNaN | | | | | | EC Flag | | | FSm2 / FSm | | | | | | | | | | | |---------|-------|------|------------|----|------|------|------|------|--|--|--|--|--| | LC | i iug | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | - | - | - | - | - | - | - | | | | | | | | +0 | - | - | - | - | - | - | - | | | | | | | FSm1 / | -0 | - | - | - | - | - | - | - | | | | | | | imm32 | +INF | - | - | - | - | - | - | - | | | | | | | | -INF | - | - | - | - | - | - | - | | | | | | | | qNaN | - | - | - | - | - | - | - | | | | | | | | sNaN | - | - | - | - | - | - | - | | | | | | #### (2-1) SUB instruction | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v<0< td=""><td>-0</td><td>-</td></v<0<> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | ### Multiplication of floating-point data ### FMUL FSm, FSn #### Operation FSn \* FSm -> FSn This multiplies the contents of the register (FSm) by the contents of the register (FSn), and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | fla | g | Size | |--------------------|------|---|---|------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Ε | U | Size | | fmul FSm, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 3 | #### Flag change - VF: This is "1" when the source data is sNaN or (±INF) \* (0). This is "0" in all other cases. - ZF: This is always "0". - OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. - UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. - IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. - LF: This is not changed. - GF: This is not changed. - EF: This is not changed. - UF: This is not changed. ### FMUL FSm1, FSm2, FSn #### Operation FSn \* FSm -> FSn This multiplies the contents of the register (FSm1) by the contents of the register (FSm2), and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | flag | g | Size | |----------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Е | J | Size | | fmul FSm1, FSm2, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 4 | #### Flag change - VF: This is "1" when the source data is sNaN or (±INF) \* (0). This is "0" in all other cases. - ZF: This is always "0". - OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. - UF: This is "1" when the operation result is not "0" and is between $\pm 2$ Emin. This is "0" in all other cases. - IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. - LF: This is not changed. - GF: This is not changed. - EF: This is not changed. - UF: This is not changed. ### FMUL imm32, FSm, FSn Operation FSn \* imm32 -> FSn This multiplies the contents of the register (FSm) by the immediate value (imm32), and stores the result in the register (FSn). | | | | EC flag FCC flag | | | | | | g | Size | | |----------------------|------|---|------------------|---|---|---|---|---|---|------|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | Ι | L | G | Е | U | Size | | fmul imm32, FSm, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 7 | #### Flag change VF: This is "1" when the source data is sNaN or $(\pm INF) * (0)$ . This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between $\pm 2$ Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. #### (1) When the FPU operation exception enable flag is "1" | Data ( | Output | | FSm2 / FSm | | | | | | | | | | | |--------|--------|------|------------|------|------|------|------|------|--|--|--|--|--| | Duta | Jaipai | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | MUL | 0 | 0 | INF | INF | qNaN | - | | | | | | | | +0 | 0 | +0 | -0 | - | - | qNaN | - | | | | | | | FSm1 / | -0 | 0 | -0 | +0 | - | - | qNaN | - | | | | | | | imm32 | +INF | INF | - | - | +INF | -INF | qNaN | - | | | | | | | | -INF | INF | ı | - | -INF | +INF | qNaN | ı | | | | | | | | qNaN - | | | | | | | | sNaN | - | - | _ | - | _ | - | - | | | | | | | EC Flag | | FSm2 / FSm | | | | | | | | |--------------|------|------------|----|----|------|------|------|------|--| | | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | NORM | MUL | 0 | 0 | 0 | 0 | 0 | V | | | FSm1 / imm32 | +0 | 0 | 0 | 0 | V | V | 0 | V | | | | -0 | 0 | 0 | 0 | V | V | 0 | V | | | | +INF | 0 | V | V | 0 | 0 | 0 | V | | | | -INF | 0 | V | V | 0 | 0 | 0 | V | | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | sNaN | V | V | V | V | V | V | V | | #### (1-1) MUL instruction | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | 0 | | 0xff7fffff ≤v ≤ 0x80800000 | */ - | 0 / I | | 0x80800000 <v <0<="" td=""><td>-</td><td>U</td></v> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */ - | 0 / I | | 0x7f7fffff < v | - | О | ### (2) When the FPU operation exception enable flag is "0" $\,$ | Data Output | | FSm2 / FSm | | | | | | | | |--------------|------|------------|------|------|------|------|------|------|--| | | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | NORM | MUL | 0 | 0 | INF | INF | qNaN | qNaN | | | FSm1 / imm32 | +0 | 0 | +0 | -0 | qNaN | qNaN | qNaN | qNaN | | | | -0 | MUL | -0 | +0 | qNaN | qNaN | qNaN | qNaN | | | | +INF | INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | | -INF | INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | | qNaN | | | sNaN | qNaN | | EC Flag | | FSm2 / FSm | | | | | | | | |--------------|------|------------|----|----|------|------|------|------|--| | | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | NORM | - | - | - | - | - | - | - | | | FSm1 / imm32 | +0 | - | - | - | - | 1 | 1 | - | | | | -0 | - | - | - | - | - | - | - | | | | +INF | - | - | - | - | - | - | - | | | | -INF | - | - | - | - | ı | ı | - | | | | qNaN | - | - | - | - | ı | ı | - | | | | sNaN | - | - | - | - | - | - | - | | #### (2-1) MUL instruction | Calculation result | Data Output | EC Flag | |------------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v <0<="" td=""><td>-0</td><td>-</td></v> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | ## Division of floating-point data ## FDIV FSm, FSn Operation FSn/FSm -> FSn This divides the contents of the register (FSn) by the contents of the register (FSm), and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | flag | g | Size | |--------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Е | U | Size | | fdiv FSm, FSn | | Δ | Δ | Δ | Δ | Δ | - | - | - | - | 3 | #### Flag change VF: This is "1" when the source data is sNaN, $(\pm INF)/(\pm INF)$ , or $(\pm 0)/(\pm 0)$ . This is "0" in all other cases. ZF: This is "1" when the dividend is $\pm 0$ . This is "0" in all other cases. OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between $\pm 2$ Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ## FDIV FSm1, FSm2, FSn Operation FSn/FSm -> FSn This divides the contents of the register (FSn) by the contents of the register (FSm), and stores the result in the register (FSn). | | | | Е | C fl | ag | | | FCC | fla | g | Size | |----------------------|------|---|---|------|----|---|---|-----|-----|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | ı | L | G | Е | U | Size | | fdiv FSm1, FSm2, FSn | | Δ | Δ | Δ | Δ | Δ | - | - | - | - | 3 | #### Flag change VF: This is "1" when the source data is sNaN, $(\pm INF)/(\pm INF)$ , or $(\pm 0)/(\pm 0)$ . This is "0" in all other cases. ZF: This is "1" when the dividend is $\pm 0$ . This is "0" in all other cases. OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. ## FDIV imm, FSm, FSn #### Operation FSm/imm32 -> FSn This divides the contents of the register (FSm) by the immediate value (imm32), and stores the result in the register (FSn). | | | EC flag | | | FCC flag | | | | Size | | | |----------------------|------|---------|---|---|----------|---|---|---|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Ε | U | Size | | fdiv imm32, FSm, FSn | | Δ | Δ | Δ | Δ | Δ | - | - | - | - | 7 | #### Flag change VF: This is "1" when the source data is sNaN, $(\pm INF)/(\pm INF)$ , or $(\pm 0)/(\pm 0)$ . This is "0" in all other cases. ZF: This is "1" when the dividend is $\pm 0$ . This is "0" in all other cases. OF: This is "1" when the operation result is greater than the positive maximum value or smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin. This is "0" in all other cases. IF: This is "1" when the operation result is inaccurate. This is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. #### (1) When the FPU operation exception enable flag is "1" | Data ( | Data Output | | FSm2 / FSm | | | | | | | | | | | |--------|-------------|------|------------|------|------|------|------|------|--|--|--|--|--| | Data | Juipui | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | DIV | 0 | 0 | INF | INF | qNaN | - | | | | | | | | +0 | - | - | - | +INF | -INF | qNaN | - | | | | | | | FSm1 / | -0 | - | ı | - | -INF | +INF | qNaN | - | | | | | | | imm32 | +INF | 0 | +0 | -0 | - | - | qNaN | - | | | | | | | | -INF | 0 | -0 | +0 | ı | - | qNaN | - | | | | | | | | qNaN - | | | | | | | | sNaN | - | - | - | - | - | - | - | | | | | | | FC | EC Flag | | FSm2 / FSm | | | | | | | | | | | |--------|---------|------|------------|----|------|------|------|------|--|--|--|--|--| | LC | | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | DIV | 0 | 0 | 0 | 0 | 0 | V | | | | | | | | +0 | Z | V | V | 0 | 0 | 0 | V | | | | | | | FSm1 / | -0 | Z | V | V | 0 | 0 | 0 | V | | | | | | | imm32 | +INF | 0 | 0 | 0 | V | V | 0 | V | | | | | | | | -INF | 0 | 0 | 0 | V | V | 0 | V | | | | | | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | V | | | | | | | | sNaN | V | V | V | V | V | V | V | | | | | | #### (1-1) DIV instruction | Calculation result | Data Output | EC Flag | |----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | 0 | | 0xff7fffff ≤v ≤ 0x80800000 | */_ | 0 / I | | 0x80800000 <v<0< td=""><td>-</td><td>U</td></v<0<> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */_ | 0 / I | | 0x7f7fffff < v | - | O | ### (2) When the FPU operation exception enable flag is "0" $\,$ | Data ( | Data Output | | FSm2 / FSm | | | | | | | | | | | |--------|-------------|------|------------|------|------|------|------|------|--|--|--|--|--| | Data | Juipui | NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | | | | | | NORM | DIV | 0 | 0 | INF | INF | qNaN | qNaN | | | | | | | | +0 | INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | | | | | FSm1 / | -0 | INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | | | | | imm32 | +INF | 0 | +0 | -0 | qNaN | qNaN | qNaN | qNaN | | | | | | | | -INF | 0 | -0 | +0 | qNaN | qNaN | qNaN | qNaN | | | | | | | | qNaN | | | | | | | sNaN | qNaN | | | | | | FC | EC Flag | | | F | Sm2 / FS1 | m | | | |--------|---------|------|----|----|-----------|------|------|---| | LC | ı ıug | NORM | +0 | -0 | +INF | qNaN | sNaN | | | | NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | FSm1 / | -0 | - | - | - | - | - | - | - | | imm32 | +INF | - | - | - | - | | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | - | _ | _ | _ | _ | _ | - | | Calculation result | Data Output | EC Flag | |------------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v <0<="" td=""><td>-0</td><td>-</td></v> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | ## plication and addition of the floating-point data ## FMADD FSm1, FSm2, FSm3, FSn Operation ((FSm1\*FSm2) + FSm3) -> FSn The result of multiplying the contents of the register (FSm1) by the contents of the register (FSm2) is added to the contents of the register (FSm3), and the result of addition is stored in the register (FSn). The purpose register is any of FS0-FS7. | | | | Е | C fla | ag | | | FCC | flag | 3 | Size | |-----------------------------|------|---|---|-------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | I | L | G | Ε | U | Size | | fmadd FSm1, FSm2, FSm3, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 4 | #### Flag change - VF: This is "1" when the source data is any of the followings: sNaN, (±INF)\*(±0), (+INF)+(-INF), (-INF)+(+INF), or $(\pm INF)-(\pm INF)$ . This is "0" in all other cases. - ZF: This is always "0". - OF: This is "1" when the operation result is greater than the positive maximum value and smaller than the negative maximum value. This is "0" in all other cases. - UF: This is "1" when the operation result is not "0" and is between ±2Emin, and this is "0" in other cases. - IF: This is "1" when the operation result is inaccurate, and this is "0" in all other cases. - LF: This is not changed. - GF: This is not changed. - EF: This is not changed. - UF: This is not changed. The purpose register is one of the FS0-FS7. (1) The followings are shown when the FPU operational exception enable flag is "1". | Data ( | Output | | | | FS | m2 | | | | |--------|--------|-------|-------|------|------|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | - | | | -NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | - | | | +0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | -0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | +INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | -INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | +0 | +NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | - | | | -NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | - | | | +0 | +0 | +0 | +0 | +0 | - | - | qNaN | - | | | -0 | +0 | +0 | +0 | +0 | - | - | qNaN | - | | | +INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | -INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | -0 | +NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | - | | | -NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | - | | | +0 | +0 | -0 | +0 | -0 | - | - | qNaN | - | | | -0 | -0 | +0 | -0 | +0 | - | - | qNaN | - | | | 1 | ı | 1 | ı | 1 | ı | ı | ı | 1 | |------|-----------|------|------|------|------|------|------|------|---| | | +INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | -INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | | - | - | - | - | - | | +INF | +NORM | +INF | +INF | +INF | +INF | +INF | - | qNaN | - | | | -NORM | +INF | +INF | +INF | +INF | - | +INF | qNaN | - | | | +0 | +INF | +INF | +INF | +INF | - | - | qNaN | - | | | -0 | +INF | +INF | +INF | +INF | - | - | qNaN | | | | +INF | +INF | - | - | - | +INF | - | qNaN | - | | | -INF | - | +INF | - | - | - | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | -INF | +NORM | -INF | -INF | -INF | -INF | - | -INF | qNaN | - | | | -NORM | -INF | -INF | -INF | -INF | -INF | - | qNaN | - | | | +0 | -INF | -INF | -INF | -INF | - | - | qNaN | | | | -0 | -INF | -INF | -INF | -INF | - | - | qNaN | - | | | +INF | - | -INF | - | - | - | -INF | qNaN | - | | | -INF | -INF | - | - | - | -INF | - | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | qNaN | NORM | qNaN - | | | 0 | qNaN | qNaN | qNaN | qNaN | - | - | qNaN | - | | | INF | qNaN | qNaN | - | - | qNaN | qNaN | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | sNaN | all types | - | - | - | - | - | - | - | - | | EC | Flag | | | | FS | m2 | | | | |------|-------|-------|-------|-----|-----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | +0 | MAC | MAC | MAC | MAC | V | V | 0 | V | | | -0 | MAC | MAC | MAC | MAC | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | |------|-----------|-----|-----|---|---|---|---|---|---| | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +INF | +NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | V | 0 | V | V | V | 0 | 0 | V | | | -INF | 0 | V | V | V | 0 | V | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -INF | +NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | V | V | V | 0 | V | 0 | V | | | -INF | V | 0 | V | V | V | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | qNaN | NORM | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | 0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | sNaN | all Types | V | V | V | V | V | V | V | V | #### (1-1) MAC | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | О | | 0xff7fffff ≤v ≤ 0x80800000 | */ - | 0 / I | | 0x80800000 <v <0<="" td=""><td>-</td><td>U</td></v> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */ - | 0 / I | | 0x7f7fffff < v | - | О | | Data ( | Output | FSm2 | | | | | | | | | |--------|--------|-------|-------|-----|-----|------|------|------|------|--| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | | NORM | +NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | qNaN | | | | -NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | qNaN | | | | +0 | MAC | MAC | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | | 1 | | | | | | | | | | |------|-----------|------|------|------|------|------|------|------|------| | | -0 | MAC | MAC | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | +0 | +NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | qNaN | | | +0 | +0 | +0 | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | -0 | +0 | +0 | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | -0 | +NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | qNaN | | | +0 | -0 | +0 | -0 | +0 | qNaN | qNaN | qNaN | qNaN | | | -0 | +0 | -0 | +0 | -0 | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | +INF | +NORM | +INF | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | | | -NORM | +INF | +INF | +INF | +INF | qNaN | +INF | qNaN | qNaN | | | +0 | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | -0 | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | +INF | +INF | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | qNaN | | | -INF | +INF | qNaN | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | -INF | +NORM | -INF | -INF | -INF | -INF | qNaN | -INF | qNaN | qNaN | | | -NORM | -INF | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | | | +0 | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | -0 | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | qNaN | | | -INF | qNaN | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | qNaN | NORM | qNaN | | 0 | qNaN | | INF | qNaN | | qNaN | | sNaN | qNaN | sNaN | all types | qNaN | EC : | Flag | | | FS | m2 | | | | |------|------------|-------|-------|-------|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | | -0 | - | | - | _ | - | _ | - | | | +INF | - | - | - | _ | - | _ | - | | | -INF | - | - | - | - | - | _ | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | _ | - | _ | _ | _ | _ | - | | +0 | +NORM | _ | - | _ | - | - | _ | - | | | -NORM | _ | - | _ | _ | _ | _ | - | | | +0 | _ | _ | _ | _ | _ | _ | _ | | | -0 | _ | - | _ | _ | _ | _ | - | | | +INF | - | - | - | _ | | _ | - | | | -INF | - | - | _ | _ | - | _ | _ | | | qNaN | - | _ | - | - | - | - | _ | | | sNaN | - | - | - | _ | - | _ | _ | | -0 | +NORM | - | - | _ | _ | - | _ | _ | | -0 | -NORM | | | | | | | | | | +0 | - | - | - | - | - | - | - | | • | | | - | | - | - | - | - | | | -0<br>-DIE | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | +INF | +NORM | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | -INF | +NORM | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | - | ı | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | qNaN | NORM | - | - | <br>- | - | - | - | - | | | 0 | - | - | - | - | - | - | - | | | INF | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | sNaN | all types | - | - | - | - | - | - | - | #### (2-1) MAC | Calculation result | Data Output | EC Flag | |------------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v <0<="" td=""><td>-0</td><td>-</td></v> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | ## FISUB Compound instructions of multiplication and subtraction of the floating-point data ## FMSUB FSm1, FSm2, FSm3, FSn Operation ((FSm1\*FSm2) - FSm3) -> FSn The contents of the register (FSm3) is subtracted from the result of multiplying the contents of the register (FSm1) by the contents of the register (FSm2) , and the result of subtraction is stored in the register (FSn). | The purpose register is | one of FS0-FS7. | | Е | C fla | ag | | | FCC | flag | 3 | Size | |-----------------------------|-----------------|---|---|-------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | ı | L | G | Ε | U | Size | | fmsub FSm1, FSm2, FSm3, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 4 | #### Flag change VF: This is "1" when the source data is any of the followings: sNaN, (±INF)\*(±0), (+INF)+(-INF), (-INF)+(+INF), or $(\pm INF)-(\pm INF)$ . This is "0" in the other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value and smaller than the negative maximum value. This is "0" in other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin, and this is "0" in other cases. IF: This is "1" when the operation result is inaccurate, and this is "0" in other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. The purpose register is one of FS0-FS7. #### (1) When the FPU operational exception enable flag is "1" | Data ( | Output | | | | FS | m2 | | | | |--------|--------|-------|-------|------|------|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | - | | | -NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | - | | | +0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | -0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | +INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | -INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | +0 | +NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | - | | | -NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | - | | | +0 | +0 | -0 | +0 | -0 | - | - | qNaN | - | | | -0 | -0 | +0 | -0 | +0 | - | - | qNaN | - | | | +INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | -INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | 1 | - | i | - | - | - | | -0 | +NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | - | | | -NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | - | | | +0 | +0 | +0 | +0 | +0 | 1 | - | qNaN | - | | | -0 | +0 | +0 | +0 | +0 | - | - | qNaN | - | | | +INF | +INF | -INF | _ | _ | +INF | -INF | qNaN | _ | |------|-----------|------|------|------|------|------|------|------|---| | | -INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | +INF | +NORM | -INF | -INF | -INF | -INF | - | -INF | qNaN | - | | | -NORM | -INF | -INF | -INF | -INF | -INF | - | qNaN | - | | | +0 | -INF | -INF | -INF | -INF | - | - | qNaN | - | | | -0 | -INF | -INF | -INF | -INF | - | - | qNaN | - | | | +INF | - | -INF | - | - | - | -INF | qNaN | - | | | -INF | -INF | - | - | - | -INF | - | qNaN | - | | | qNaN - | | | sNaN | 1 | - | - | - | - | - | - | - | | -INF | +NORM | +INF | +INF | +INF | +INF | +INF | - | qNaN | - | | | -NORM | +INF | +INF | +INF | +INF | - | +INF | qNaN | - | | | +0 | +INF | +INF | +INF | +INF | - | - | qNaN | - | | | -0 | +INF | +INF | +INF | +INF | - | - | qNaN | - | | | +INF | +INF | - | - | - | +INF | - | qNaN | - | | | -INF | - | +INF | - | - | - | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | qNaN | NORM | qNaN - | | | 0 | qNaN | qNaN | qNaN | qNaN | - | - | qNaN | - | | | INF | qNaN | qNaN | - | - | qNaN | qNaN | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | sNaN | all types | - | - | - | - | - | - | - | - | | EC | Flag | | | | FS | m2 | | | | |------|-------|-------|-------|-----|-----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | +0 | MAC | MAC | MAC | MAC | V | V | 0 | V | | | -0 | MAC | MAC | MAC | MAC | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | |------|-----------|-----|-----|---|---|---|---|---|---| | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | | | | V | | | | | | | | V | V | 0 | | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +INF | +NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | V | 0 | V | V | V | 0 | 0 | V | | | -INF | 0 | V | V | V | 0 | V | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -INF | +NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | V | V | V | 0 | V | 0 | V | | | -INF | V | 0 | V | V | V | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | qNaN | NORM | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | 0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | sNaN | all Types | V | V | V | V | V | V | V | V | #### (1-1)MAC | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | О | | 0xff7fffff ≤v ≤ 0x80800000 | */ - | 0 / I | | 0x80800000 <v <0<="" td=""><td>-</td><td>U</td></v> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */ - | 0 / I | | 0x7f7fffff < v | - | О | ### (2) When the FPU operational exception enable flag is "0" $\,$ | Data Output FS | | | | | | m2 | | | | |----------------|-------|-------|-------|-----|-----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | qNaN | | | -NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | qNaN | | | +0 | MAC | MAC | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | 1 | | 2446 | MAG | 264.0 | 264.6 | 27.27 | NIN | 27.27 | 27.27 | |--------|-----------|--------|--------|--------|--------|--------|--------|--------|--------| | | -0 | MAC | MAC | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | | +INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | -INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | +0 | +NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | qNaN | | | -NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | qNaN | | | +0 | +0 | -0 | +0 | -0 | qNaN | qNaN | qNaN | qNaN | | | -0 | -0 | +0 | -0 | +0 | qNaN | qNaN | qNaN | qNaN | | | +INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | -INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | -0 | +NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | qNaN | | | -NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | qNaN | | | +0 | +0 | +0 | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | +0 | +0 | +0 | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | +INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | -INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | +INF | +NORM | -INF | -INF | -INF | -INF | qNaN | -INF | qNaN | qNaN | | | -NORM | -INF | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | | | +0 | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | -0 | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | +INF | qNaN | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | | | -INF | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | qNaN | | | qNaN | | sNaN | qNaN | -INF | +NORM | +INF | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | | | -NORM | +INF | +INF | +INF | +INF | qNaN | +INF | qNaN | qNaN | | | +0 | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | -0 | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | +INF | +INF | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | qNaN | | | -INF | qNaN | +INF | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | qNaN | NORM | qNaN | | 0 | qNaN | | INF | qNaN | | qNaN | | sNaN | qNaN | sNaN | all types | qNaN | SINAIN | an types | qinain | qınain | qınain | qınain | qınain | qinain | qinain | qinain | | EC : | Flag | | | FS | m2 | | | | |--------|-----------|--------------|-------|----|------|------|------|------| | FSm3 | FSm1 | | -NORM | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | +NORM | _ | _ | _ | - | - | - | | | -NORM | - | _ | _ | _ | _ | _ | _ | | | +0 | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | _ | - | | | +INF | - | _ | _ | _ | _ | _ | _ | | | -INF | - | _ | - | _ | _ | _ | _ | | | qNaN | - | | - | | | _ | | | | sNaN | - | - | - | - | - | _ | - | | +0 | +NORM | - | | - | | _ | _ | | | '0 | -NORM | - | - | | - | | | - | | | +0 | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | | | | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | -0 | +NORM | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | | -0 | | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | 1 | - | - | - | - | - | - | | +INF | +NORM | 1 | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | -INF | +NORM | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | _ | - | - | | | -0 | - | - | - | - | - | - | - | | | +INF | - | _ | - | - | - | - | - | | | -INF | - | _ | - | - | - | - | - | | | qNaN | - | - | _ | _ | - | _ | - | | | sNaN | - | _ | - | - | _ | - | - | | qNaN | NORM | - | - | - | - | _ | _ | - | | qrvarv | 0 | - | - | - | - | _ | _ | - | | | INF | <u>-</u> | | | | | | | | | | <del>-</del> | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | | - | | "XT.XT | sNaN | <u>-</u> | - | - | - | - | - | - | | sNaN | all types | | - | - | - | - | - | - | #### (2-1) MAC | Calculation result | Data Output | EC Flag | |------------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v <0<="" td=""><td>-0</td><td>-</td></v> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | # FMADD Compound instructions of multiplication and addition of the floating-point data ### FNMADD FSm1, FSm2, FSm3,FSn Operation (-(FSm1\*FSm2) + FSm3) -> FSn The contents of the register (FSm3) is added to the result of multiplying the contents of the register (FSm1), the contents of the register (FSm2) and "-1" by each other, and the result of addition is stored in the register (FSn). The purpose register is one of FS0-FS7. | | | | Е | C fl | ag | | | FCC | flag | 3 | Size | |------------------------------|------|---|---|------|----|---|---|-----|------|---|------| | Assembler mnemonic | Note | ٧ | Ζ | 0 | U | Ι | L | G | Ε | U | Size | | fnmadd FSm1, FSm2, FSm3, FSn | | Δ | 0 | Δ | Δ | Δ | ı | - | • | - | 4 | Flag change VF: This is "1" when the source data is any of the followings: sNaN, (±INF)\*(±0), (+INF)+(-INF), (-INF)+(+INF), or (± INF)-(±INF). This is "0" in allother cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value and smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin, and this is "0" in all other cases. IF: This is "1" when the operation result is inaccurate, and this is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. The purpose register is one of the FS0-FS7. #### (1) When the FPU operational exception enable flag is "1" | Data ( | Output | | | | FS | m2 | | | | |--------|--------|-------|-------|------|------|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | - | | | -NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | - | | | +0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | -0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | +INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | -INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | +0 | +NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | - | | | -NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | - | | | +0 | +0 | +0 | +0 | +0 | - | - | qNaN | - | | | -0 | +0 | +0 | +0 | +0 | ı | - | qNaN | - | | | +INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | -INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | qNaN | | | sNaN | - | - | - | - | i | - | - | - | | -0 | +NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | - | | | -NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | - | | | +0 | -0 | +0 | -0 | +0 | - | - | qNaN | - | | | -0 | +0 | -0 | +0 | -0 | - | - | qNaN | - | | | +INF | -INF | +INF | _ | - | +INF | -INF | qNaN | - | |------|-----------|------|------|------|------|------|------|------|---| | | -INF | +INF | -INF | - | - | -INF | +INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | +INF | +NORM | +INF | +INF | +INF | +INF | - | +INF | qNaN | - | | | -NORM | +INF | +INF | +INF | +INF | +INF | - | qNaN | - | | | +0 | +INF | +INF | +INF | +INF | - | - | qNaN | - | | | -0 | +INF | +INF | +INF | +INF | - | - | qNaN | - | | | +INF | - | +INF | - | - | - | +INF | qNaN | - | | | -INF | +INF | - | - | ı | +INF | - | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | -INF | +NORM | -INF | -INF | -INF | -INF | -INF | - | qNaN | - | | | -NORM | -INF | -INF | -INF | -INF | - | -INF | qNaN | - | | | +0 | -INF | -INF | -INF | -INF | - | - | qNaN | - | | | -0 | -INF | -INF | -INF | -INF | - | - | qNaN | - | | | +INF | -INF | - | - | - | -INF | - | qNaN | - | | | -INF | - | -INF | - | - | - | -INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | 1 | - | - | - | - | | qNaN | NORM | qNaN - | | | 0 | qNaN | qNaN | qNaN | qNaN | - | - | qNaN | - | | | INF | qNaN | qNaN | - | - | qNaN | qNaN | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | sNaN | all types | - | - | - | - | - | - | - | - | | EC | Flag | | | | FS | m2 | | | | |------|-------|-------|-------|-----|-----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | +0 | MAC | MAC | MAC | MAC | V | V | 0 | V | | | -0 | MAC | MAC | MAC | MAC | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | |------|-----------|-----|-----|---|---|---|---|---|---| | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +INF | +NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | V | 0 | V | V | V | 0 | 0 | V | | | -INF | 0 | V | V | V | 0 | V | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -INF | +NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | V | V | V | 0 | V | 0 | V | | | -INF | V | 0 | V | V | V | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | qNaN | NORM | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | 0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | sNaN | all Types | V | V | V | V | V | V | V | V | #### (1-1) MAC | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | 0 | | 0xff7fffff ≤v ≤ 0x80800000 | */ - | 0 / I | | 0x80800000 <v <0<="" td=""><td>-</td><td>U</td></v> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */ - | 0 / I | | 0x7f7fffff < v | - | О | ### (2) When the FPU operational exception enable flag is "0" $\,$ | Data Output FSm2 | | | | | | | | | | |------------------|-------|-------|-------|-----|-----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | qNaN | | | +0 | MAC | MAC | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | I | 0 | MAC | MAC | MAG | MAG | -N-N | aNaN | ~NaN | ~NaN | |--------|------------|------|------|------|------|------|--------------|------|------| | | -0<br>-DIE | MAC | MAC | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | +0 | sNaN | qNaN | qNaN | qNaN | qNaN | qNaN | qNaN<br>±INE | qNaN | qNaN | | +0 | +NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | qNaN | | | +0 | +0 | +0 | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | | | | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | 0 | sNaN | qNaN | -0 | +NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | qNaN | | | +0 | -0 | +0 | -0 | +0 | qNaN | qNaN | qNaN | qNaN | | | -0<br>-DIF | +0 | -0 | +0 | -0 | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | , D.IE | sNaN | qNaN | +INF | +NORM | +INF | +INF | +INF | +INF | qNaN | +INF | qNaN | qNaN | | | -NORM | +INF | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | | | +0 | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | -0<br>-DIF | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | +INF | qNaN | +INF | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | | | -INF | +INF | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | qNaN | | | qNaN | DIE | sNaN | qNaN | -INF | +NORM | -INF | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | | | -NORM | -INF | -INF | -INF | -INF | qNaN | -INF | qNaN | qNaN | | | +0 | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | -0<br>-DIE | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | qNaN | | | -INF | qNaN | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | | | qNaN | "NT-NT | sNaN | qNaN | qNaN | NORM | qNaN | | 0 | qNaN | | INF | qNaN | | qNaN | 27.27 | sNaN | qNaN | sNaN | all types | qNaN | EC | Flag | | | | FS | m2 | | | | |-------|----------|----------|-------|----|----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | - | - | - | - | - | - | - | - | | | -NORM | _ | - | _ | _ | - | _ | _ | - | | | +0 | - | - | - | - | - | _ | - | _ | | | -0 | _ | - | _ | _ | - | - | _ | _ | | | +INF | - | - | _ | _ | _ | - | - | - | | | -INF | | - | _ | - | - | _ | - | | | | | | | | - | | | - | | | | qNaN | - | - | - | _ | - | - | _ | - | | +0 | sNaN | - | | - | - | - | - | - | - | | 70 | +NORM | - | - | - | _ | | - | _ | - | | | -NORM | - | - | - | | - | - | | - | | | +0 | - | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | - | | -0 | +NORM | - | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | - | | +INF | +NORM | - | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | - | | | sNaN | - | - | _ | - | - | - | - | - | | -INF | +NORM | - | - | - | - | - | _ | - | - | | | -NORM | - | - | _ | - | - | - | - | - | | | +0 | _ | - | _ | - | - | _ | - | _ | | | -0 | - | - | _ | _ | _ | - | - | - | | | +INF | - | - | _ | - | - | _ | - | | | | -INF | <u>-</u> | - | | _ | - | _ | _ | - | | | | | - | | _ | - | | - | - | | | qNaN | - | | - | | | - | | - | | aNaN | sNaN | - | - | - | - | - | - | - | - | | qNaN | NORM | - | - | - | | - | - | | - | | | 0 | - | - | - | - | - | - | - | - | | | INF | - | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | - | | ,,,,, | sNaN | - | - | - | - | - | - | - | - | | sNaN | alltypes | - | - | - | - | - | - | - | - | #### (2-1) MAC | Calculation result | Data Output | EC Flag | |------------------------------------------------------|-------------|---------| | v < 0xff7fffff | -INF | - | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | 0x80800000 <v <0<="" td=""><td>-0</td><td>-</td></v> | -0 | - | | 0 | -0 /+0 | - | | 0 < v < 0x00800000 | +0 | - | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | 0x7f7fffff < v | +INF | - | ing-point data ## FNMSUB FSm1, FSm2, FSm3,FSn Operation (-(FSm1\*FSm2) - FSm3) -> FSn The contents of the register (FSm3) is subtracted from the result of multiplying the contents of the register (FSm1), the contents of the register (FSm2) and "-1" by each other, and the result of subtraction is stored in the register (FSn). | | - | one of FS0-FS7. | | EC flag | | | | | FCC | Size | | | |------------------------|--------|-----------------|---|---------|---|---|---|---|-----|------|---|------| | Assembler mnemonic | 2 | Note | ٧ | Ζ | 0 | U | ı | L | G | Ε | U | Size | | fnmsub FSm1, FSm2, FSm | 3, FSn | | Δ | 0 | Δ | Δ | Δ | - | - | - | - | 4 | #### Flag change VF: This is "1" when the source data is any of the followings: sNaN, (±INF)\*(±0), (+INF)+(-INF), (-INF)+(+INF), or $(\pm INF)-(\pm INF)$ . This is "0" in all other cases. ZF: This is always "0". OF: This is "1" when the operation result is greater than the positive maximum value and smaller than the negative maximum value. This is "0" in all other cases. UF: This is "1" when the operation result is not "0" and is between ±2Emin, and this is "0" in all other cases. IF: This is "1" when the operation result is inaccurate, and this is "0" in all other cases. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. The purpose register is one of FS0-FS7. #### (1) When the FPU operational exception enable flag is "1" | Data ( | Output | | | | FSı | m2 | | | | |--------|--------|-------|-------|------|------|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | - | | | -NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | - | | | +0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | -0 | MAC | MAC | MAC | MAC | - | - | qNaN | - | | | +INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | -INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | +0 | +NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | - | | | -NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | - | | | +0 | -0 | +0 | +0 | +0 | ı | - | qNaN | - | | | -0 | +0 | -0 | +0 | +0 | ı | - | qNaN | - | | | +INF | -INF | +INF | - | - | -INF | +INF | qNaN | - | | | -INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | ı | - | - | - | | -0 | +NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | - | | | -NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | - | | | +0 | +0 | +0 | -0 | +0 | | - | qNaN | - | | | -0 | +0 | +0 | +0 | -0 | - | - | qNaN | - | | | +INF | -INF | +INF | _ | _ | -INF | +INF | qNaN | _ | |------|-----------|------|------|------|------|------|------|------|---| | | -INF | +INF | -INF | - | - | +INF | -INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | _ | | +INF | +NORM | -INF | -INF | -INF | -INF | -INF | - | qNaN | - | | | -NORM | -INF | -INF | -INF | -INF | - | -INF | qNaN | - | | | +0 | -INF | -INF | -INF | -INF | - | - | qNaN | - | | | -0 | -INF | -INF | -INF | -INF | - | - | qNaN | - | | | +INF | -INF | - | - | - | -INF | - | qNaN | - | | | -INF | - | -INF | - | - | - | -INF | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | -INF | +NORM | +INF | +INF | +INF | +INF | - | +INF | qNaN | - | | | -NORM | +INF | +INF | +INF | +INF | +INF | - | qNaN | - | | | +0 | +INF | +INF | +INF | +INF | - | - | qNaN | - | | | -0 | +INF | +INF | +INF | +INF | - | - | qNaN | - | | | +INF | - | +INF | - | - | - | +INF | qNaN | - | | | -INF | +INF | - | - | - | +INF | - | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | qNaN | NORM | qNaN - | | | 0 | qNaN | qNaN | qNaN | qNaN | - | - | qNaN | - | | | INF | qNaN | qNaN | - | - | qNaN | qNaN | qNaN | - | | | qNaN - | | | sNaN | - | - | - | - | - | - | - | - | | sNaN | all types | - | - | - | - | - | - | - | - | | EC | Flag | | | | FS | m2 | | | | |------|-------|-------|-------|-----|-----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | MAC | MAC | 0 | 0 | 0 | V | | | +0 | MAC | MAC | MAC | MAC | V | V | 0 | V | | | -0 | MAC | MAC0 | MAC | MAC | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -0 | +NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | I. | | | 1 | | | | | 1 | | |------|-----------|-----|-----|---|---|---|---|---|---| | | -NORM | MAC | MAC | 0 | 0 | 0 | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | -INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | +INF | +NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | 0 | V | V | V | 0 | V | 0 | V | | | -INF | V | 0 | V | V | V | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | -INF | +NORM | 0 | 0 | 0 | 0 | V | 0 | 0 | V | | | -NORM | 0 | 0 | 0 | 0 | 0 | V | 0 | V | | | +0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | -0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | +INF | V | 0 | V | V | V | 0 | 0 | V | | | -INF | 0 | V | V | V | 0 | V | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | qNaN | NORM | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | 0 | 0 | 0 | 0 | 0 | V | V | 0 | V | | | INF | 0 | 0 | V | V | 0 | 0 | 0 | V | | | qNaN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | V | | | sNaN | V | V | V | V | V | V | V | V | | sNaN | all Types | V | V | V | V | V | V | V | V | #### (1-1) MAC | Calculation result | Data Output | EC Flag | |-----------------------------------------------------|-------------|---------| | v < 0xff7fffff | - | О | | 0xff7fffff ≤v ≤ 0x80800000 | */ - | 0 / I | | 0x80800000 <v <0<="" td=""><td>-</td><td>U</td></v> | - | U | | 0 | +0 / -0 | 0 | | 0 < v < 0x00800000 | - | U | | $0x00800000 \le v \le 0x7f7fffff$ | */ - | 0 / I | | 0x7f7fffff < v | - | О | ### (2) When the FPU operational exception enable flag is "1" | Data ( | Output | | | | FS | m2 | | | | |--------|--------|-------|-------|-----|-----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | +0 | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | MAC | MAC | MAC | MAC | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | MAC | MAC | +INF | -INF | qNaN | qNaN | | | +0 | MAC | MAC | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | | -0 | MAC | MAC | MAC | MAC | aNaN | aNaN | aNaN | aNaN | |------|-----------|------|------|------|------|------|------|------|------| | | | MAC | | MAC | MAC | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | 10 | sNaN | qNaN | +0 | +NORM | MAC | MAC | -0 | +0 | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | +0 | -0 | +INF | -INF | qNaN | qNaN | | | +0 | -0 | +0 | -0 | +0 | qNaN | qNaN | qNaN | qNaN | | | -0 | +0 | -0 | +0 | -0 | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | -0 | +NORM | MAC | MAC | +0 | +0 | -INF | +INF | qNaN | qNaN | | | -NORM | MAC | MAC | +0 | +0 | +INF | -INF | qNaN | qNaN | | | +0 | +0 | +0 | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | -0 | +0 | +0 | +0 | +0 | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | +INF | qNaN | qNaN | -INF | +INF | qNaN | qNaN | | | -INF | +INF | -INF | qNaN | qNaN | +INF | -INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | +INF | +NORM | -INF | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | | | -NORM | -INF | -INF | -INF | -INF | qNaN | -INF | qNaN | qNaN | | | +0 | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | -0 | -INF | -INF | -INF | -INF | qNaN | qNaN | qNaN | qNaN | | | +INF | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | qNaN | | | -INF | qNaN | -INF | qNaN | qNaN | qNaN | -INF | qNaN | qNaN | | | qNaN | | sNaN | qNaN | -INF | +NORM | +INF | +INF | +INF | +INF | qNaN | +INF | qNaN | qNaN | | | -NORM | +INF | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | | | +0 | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | -0 | +INF | +INF | +INF | +INF | qNaN | qNaN | qNaN | qNaN | | | +INF | qNaN | +INF | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | | | -INF | +INF | qNaN | qNaN | qNaN | +INF | qNaN | qNaN | qNaN | | | qNaN | | sNaN | qNaN | qNaN | NORM | qNaN | | 0 | qNaN | | INF | qNaN | | qNaN | | sNaN | qNaN | sNaN | all types | qNaN | sNaN | all types | qNaN | EC : | Flag | | | FS | m2 | | | | |--------|-----------|-------|-------|----|------|------|------|------| | FSm3 | FSm1 | +NORM | -NORM | -0 | +INF | -INF | qNaN | sNaN | | NORM | +NORM | - | - | - | - | - | - | - | | | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | | -0 | - | - | - | - | - | - | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | +0 | +NORM | - | | - | - | - | - | - | | | -NORM | - | | - | - | - | - | - | | | +0 | - | | - | - | - | - | - | | | -0 | - | - | - | - | - | _ | - | | | +INF | - | - | - | - | - | _ | - | | | -INF | - | - | - | - | - | _ | - | | | qNaN | - | - | - | _ | - | _ | - | | | sNaN | - | - | - | _ | - | _ | - | | -0 | +NORM | - | _ | _ | _ | _ | _ | _ | | | -NORM | - | - | - | - | - | - | - | | | +0 | _ | - | _ | _ | _ | _ | - | | | -0 | - | - | _ | - | - | _ | - | | | +INF | - | - | _ | - | - | _ | - | | | -INF | _ | - | - | _ | - | _ | - | | | qNaN | - | - | - | - | - | - | - | | | sNaN | _ | - | _ | - | - | _ | - | | +INF | +NORM | _ | - | _ | _ | _ | _ | _ | | 1111 | -NORM | - | - | - | - | - | - | - | | | +0 | _ | - | _ | _ | _ | _ | _ | | | -0 | _ | - | _ | - | - | _ | - | | | +INF | - | - | _ | - | - | _ | - | | | -INF | _ | _ | _ | _ | _ | _ | _ | | | qNaN | - | - | _ | - | - | - | - | | | sNaN | - | - | - | - | - | - | - | | -INF | +NORM | - | - | - | - | - | - | - | | 11.11 | -NORM | - | - | - | - | - | - | - | | | +0 | - | - | - | - | - | - | - | | | -0 | - | _ | - | - | - | _ | - | | | +INF | - | - | - | - | - | - | - | | | -INF | - | - | - | - | - | - | - | | | qNaN | _ | - | - | - | - | - | _ | | | sNaN | - | - | - | - | - | - | - | | qNaN | NORM | - | - | - | - | - | - | - | | qinain | 0 | | | | | | | | | | INF | - | - | - | - | - | - | - | | | qNaN | - | | - | - | | - | - | | | sNaN | | - | | | - | - | | | sNaN | | - | - | - | - | - | | - | | SINAIN | all types | - | - | - | - | - | - | - | #### (2-1) MAC | Calculation result | Data Output | EC Flag | | | | | |------------------------------------------------------|-------------|---------|--|--|--|--| | v < 0xff7fffff | -INF | - | | | | | | 0xff7fffff ≤v ≤ 0x80800000 | * | - | | | | | | 0x80800000 <v <0<="" td=""><td>-0</td><td>-</td></v> | -0 | - | | | | | | 0 | -0 /+0 | - | | | | | | 0 < v < 0x00800000 | +0 | - | | | | | | $0x00800000 \le v \le 0x7f7fffff$ | * | - | | | | | | 0x7f7fffff < v | +INF | - | | | | | ## FBCC (d8, PC) #### Operation When branch is taken, PC (current instruction address) + (sign\_ext) d8 -> nPC (next instruction PC) 8-bit displacement (d8) is sign-extended and added to the PC, and the result is written into the program counter of the next instruction. (nPC). Even if the addition result overflows, this overflow is ignored and the result is written into the PC. When branch is not taken, The next instruction is executed. PC (current instruction address) + CodeSize -> nPC (next instruction PC) The next instruction is executed. | | | EC flag | | | | | ] | Size | | | | | |--------------------|---------------------|---------|---|---|---|---|---|------|---|---|------|--| | Assembler mnemonic | Note | | Ζ | 0 | U | I | L | G | Ε | U | Size | | | fbeq label | E=1 - | | - | ı | ı | - | - | - | ı | - | 3 | | | fbne label | U=1 or L=1 or G=1 - | | - | 1 | - | - | - | - | - | - | 3 | | | fbgt label | G=1 | | - | - | - | - | - | - | - | - | 3 | | | fbge label | G=1 or E=1 | | - | - | - | - | - | - | - | - | 3 | | | fblt label | L=1 | | - | - | - | - | - | - | - | - | 3 | | | fble label | L=1 or E=1 | | - | - | - | - | - | - | - | - | 3 | | | fbuo label | U=1 | | - | - | - | - | - | - | - | - | 3 | | | fblg label | L=1 or G=1 | | - | - | - | - | - | - | - | - | 3 | | | fbleg label | L=1 or E=1 or G=1 | | - | - | - | - | - | - | - | - | 3 | | | fbug label | U=1 or G=1 | | - | - | - | - | - | - | - | - | 3 | | | fbuge label | U=1 or G=1 or E=1 | | - | - | - | - | - | - | - | - | 3 | | | fbul label | U=1 or L=1 | | - | - | - | - | - | - | - | - | 3 | | | fbule label | U=1 or L=1orE=1 | | - | - | - | - | - | - | - | - | 3 | | | fbue label | U=1 or E=1 | - | - | - | - | - | - | - | - | - | 3 | | #### Flag change VF: This is not changed. ZF: This is not changed. OF: This is not changed. UF: This is not changed. IF: This is not changed. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. # **FLCC** ## Conditional branch only for the loop under the floating-point condition ## **FLCC** #### Operation When conditional branch is taken LAR - 4 -> nPC (next instruction PC) The instruction loaded from the loop instruction register (LIR) is executed and the instruction fetch starts for the address loaded to the loop address register (LAR). At the same time, 4 is subtracted from the instruction fetch address register (LAR) and the result is written into the program counter (PC). Even if the subtract result overflows, this overflow is ignored and the result is written into the program counter (PC). Without coordination with SETLB, the operation cannot be guaranteed. This is used with the SETLB instruction in order to speed up the loop control, and conditionally branches to the start of the loop registered in the SETLB instruction. When branch is not taken PC (current instruction address) + 1 -> nPC (next instruction PC) The next instruction is executed. | | | | Е | C fla | ag | | ] | Size | | | | |--------------------|-------------------|---|---|-------|----|---|---|------|---|---|------| | Assembler mnemonic | Note | | Ζ | 0 | U | I | L | G | Е | U | Size | | fleq | E=1 | - | - | - | - | - | - | - | - | - | 2 | | flne | U=1 or L=1 or G=1 | - | - | - | - | - | - | - | - | - | 2 | | flgt | G=1 | - | - | - | - | - | - | - | - | - | 2 | | flge | G=1 or E=1 | - | - | - | - | - | - | - | - | - | 2 | | filt | L=1 | | - | - | - | - | - | - | - | - | 2 | | flle | L=1 or E=1 | | - | - | - | - | - | - | - | - | 2 | | fluo | U=1 | - | - | - | - | - | - | - | - | - | 2 | | fllg | L=1 or G=1 | - | - | - | - | - | - | - | - | - | 2 | | flleg | L=1 or E=1 or G=1 | - | - | - | - | - | - | - | - | - | 2 | | flug | U=1 or G=1 | | - | - | - | - | - | - | - | - | 2 | | fluge | U=1 or G=1 or E=1 | | - | - | - | - | - | - | - | - | 2 | | flul | U=1 or L=1 | | - | - | - | - | - | - | - | - | 2 | | flule | U=1 or L=1or E=1 | | - | - | - | - | - | - | - | - | 2 | | flue | U=1 or E=1 | - | - | - | - | - | - | - | - | - | 2 | Flag change VF: This is not changed. ZF: This is not changed. OF: This is not changed. UF: This is not changed. IF: This is not changed. LF: This is not changed. GF: This is not changed. EF: This is not changed. UF: This is not changed. Chapter 3 Directions for using instructions ### **Cautions for programming** The 32-bit microcontroller MN103E series has accomplished speedup through the following devices concerning implementations. #### • Speedup of the instruction execution cycle This has accomplished high-speed execution for Lcc/SETLB/RETF through performing the 5-step pipeline processing as well as performing the normal pipeline processing and a different processing with specialized software. #### • Speedup of operational frequencies This has accomplished a speedup of operation frequencies through performing the optimized allocation of the pipeline stage for processing preventing theimprovement of operatinf frequencies such as flag generation and alignment/extension of load data. The description of the pipeline architecture, the cautions for programming about a part of the instruction description, and the recommendations are shown here for the effective use of the above-mentioned speed-up methods. #### 1. Pipeline architecture This describes the pipeline configuration adopted in the 32-bit microcontroller MN103E series and the operations. #### 2. Cautions on the instruction description The cautions are for programming about the instruction description, instruction design and combination. Please thake note that mulfunctions may be caused if these cautions are not followed. #### 3. Recommendations on the instruction description The recommendations are for the instruction description, instruction design and combination. Mulfinctions are not caused even if the recommended requirements are not fulfilled. However, please take note that the imcrease in the number of execution cycles may be caused if the requirements are not fulfilled. #### 4. General on the instruction description The general shows the examples of generally-used programming. 1 ## Pipeline architecture The 32-bit microcontroller MN103E series performs pipeline processing for executing instructions in order to accomplish high-speed operations. Multiple instructions can be overlapped and parallel-executed through the pipeline processing. #### 1-1 Pipeline operation The 32-bit microcontroller MN103E series executes instructions at the following five-step pipeline stage. IF (Instruction fetch) : This takes in instructions from the memory. DEC (Instruction decryption) : This decrypts the instructions taken in. This performs the address calculation of the branch target in a part of the branch instructions. EX (Execution) : This performs the operations or address calculation based on the decryption results. MEM (Memory access) : This accesses memory in the instructions with memory access, and generates and stores flags in the instructions with flag change. WB (Write back) : This stores operation results in registers. This aligns, extends and stores the memory access results in registers. This sets an instruction queue between the IF and DEC stages, precedently stores instructions from memory to the take-in instruction queue. If there are the data necessary to decryption and execution in the instruction queue, the instruction decryption stage is started. When the instruction queue is empty as imediately after branching or it does not have necessary instruction data, The instruction queue wait of at least one cycle occurs. The instruction queue is controlled by hardware, and its function is different depending on core types even in the MN103E series. Therefore, this chapter describes the cases that there are necessary data in the instruction queue. Although any special care is unnecessary at making programs, it is necessary to undestand instruction queue operations of each core at calculating the instruction execution cycle. #### 1-2 Pipeline operations of operations between registers Each pipeline stage of the operation between registers performs the following operations. **DEC** : This decrypts instructions. EX : This executes operations based on the decrypted results. **MEM** : This updates flags based on the operation result in the instruction with flag change. WB : This stores the operation result in registers. The instructions performing this pipeline operation are as follows: addition and subtraction/ logical operation/ shift instruction/ data transfer instruction between CPU registers/ data transfer instruction between CPU and FPU registers/ data transfer instruction between FPU registers. #### 1-3 Pipeline operation of data load Each pipeline stage of the data load performs the following operations. DEC : This decrypts instructions. EX : This executes address calculation based on the decrypted result and at the same time, determines the memory space for memory access. **MEM** : This reads TLB if necessary, and reads data from memory through the changed address. WB : This stores the read data in registers. The instructions performing this pipeline operation are as follows: data transfer instruction between memory and CPU registers/ data transfer instruction between memory and FPU registers. #### 1-4 Pipeline operations of data store Each pipeline stage of data store performs the following operations. DEC : This decrypts instructions. EX : This executes address calculation based on the decrypted result. MEM : This writes data into memory between the memory stages. WB : This does not perform this processing. The instructions performing this pipeline operation are as follows: data transfer instruction between memory and CPU registers/ data transfer instruction between memory and FPU registers. #### 1-5 Branch pipeline operations Each pipeline stage of the branch instruction performs the following operations. DEC : This decrypts instructions, and at the same time performs address calculation for the branch target. This starts reading the branch instruction based on the calculation result after the next cycle. EX : This does not perform this processing. MEM : This does not perform this processing. WB : This does not perform this processing. The instructions performing this pipeline operation are conditional branch instructions and others. The following figure shows the pipeline operations when branching occurs. #### 1-6 Pipeline operations of SETLB and LCC Since the instructions are executed at high speed, the processing is not carried out in the order of IF stage/ DEC stage/ EX stage/ MEM stage/ WB stage as seen in the following pipeline operations of the instructions, and the instructions are executed by using specilized hardware. #### SETLB pipeline operations #### LCC pipeline operations ### 1-7 Number of instruction executing cycles This chapter describes the number of the instruction executing cycle in the MN103E series. This instruction manual has the tables of throughput and latency in the appendix. Throughput shows the minimum number of the cycles necessary to execute each instruction. Latency shows the number of the cycles that the subsequent instruction execution has to wait after the cycle for executing each instruction when each instruction and its subsequent instruction are dependent on each other. There are the following three cases concerning the dependence between instructions. (1) Register dependence between instructions When the destination register of the preceding instruction (the storing-target register of the operation result) matches the source register of the subsequent instruction. (2)Flag dependence between instructions When the subsequent instruction refers to the flag with a possibility of being changed by the preceding instruction. (3) When the FPU instruction is subsequent to the CPU load/store instruction. #### 1-7-1 No dependence between instructions The number of executing cycles for each instruction is shown as THROUGHPUT in another table (MN103E series Throughput & Latency). Some instructions need multiple cycles for the instruction decode, operation, and memory address. [Examples] The case of no dependence between instructions | add 0x80000000,d0 (A)<br>add 0x80,d0 (B)<br>add 0x40,d1 (C) | [Instruction strings to be execute | d] | |-------------------------------------------------------------|------------------------------------|-------------------| | | add | 0x80000000,d0 (A) | | add 0x40,d1 (C) | add | 0x80,d0 ( B ) | | | add | 0x40,d1 ( C ) | In the above examples, THROUGHPUT of instructions (A), (B), and (C) are 2/1/1 respectively, and LATENCY of them are 2/1/1 respectively. The pipeline operation in this example is shown asthe following figure. The number of instruction executing cycles is determined depending on the number of the THROUGHPUT cycles because there is no dependence between the instructions in this example. #### 1-7-2 Register dependence between instructions When the destination register (the storing target register of the operation result) of the preceding instruction is the same as the source register of the subsequent instruction, the susequent instruction cannot be executed until the preceding instruction stores the result. The number of executing cycles for each instruction is shown as THROUGHPUT in another table (MN103E series Throughput & Latency). [Examples] The case that there is register dependence between instructions In the above examples, THROUGHPUT of instructions (A), (B), and (C) are 1/1/1 respectively, and LATENCY of them are 3/1/1 respectively. The pipeline operation in this example is shown as the following figure. The number of instruction executing cycles of (B) is determined depending on the number of (A) latency cycles and the number of the (B) and (C) THROUGHPUT cycles because there is register dependence between (A) and (B). The following example shows that there is register dependence in the preceding instruction after two instructions. [Examples] The case that there is register dependence between instructions | [Instruction strings to be executed | d] | |-------------------------------------|--------------| | mov | (a0), d0 (A) | | add | 0x80, d2 (B) | | mov | d0,d1 (C) | | | | In the above examples, THROUGHPUT of instructions (A), (B), and (C) are 1/1/1 respectively, and LATENCY of them are 3/1/1 respectively. The pipeline operation in this example is shown as the following figure. Instruction (B) of (A) THROUGHPUT number can be executed because there is no register dependence between (A) and (B). On the other hand, (C) cannot be executed until the numbers of (B) THROUGHPUT cycles and (A) LATENCY cycles because there is register dependence between (A) and (C). ### 1-7-3 Flag dependence between instructions The subsequent instruction cannot be executed until flag updating by the preceding instruction when the subsequent instruction refers to the flag state of TPSW and FPCR updated by the preceding instruction. ### [Example] Example of flag independence between instructions [Instruction strings to be executed] div d0, d1 ..... (A) beq (B) zero ..... In the above example, (A) THROUGHPUT is 2, (A) LATENCY is 4, and (B) THROUGHPUT is 3. (B) refers to the flag updated by the operation of (A). Accordingly (B) is executed until the number of the (A) LATENCY cycles. ### 1-7-4 When the FPU instruction is subsequent to CPU load/store instruction When the preceding instruction is the CPU load or store instruction, the following instruction cannnot be executed until CPU completed the load/store instruction, even though there is no trgister and flag dependence between instructions. ### [Example] Example of FPU following CPU load storing instruction | _ | | * | | | |---|----------------|--------------------|----------|-----| | | [Instruction s | strings to be exec | cuted] | | | | | di | v d0, d1 | (A) | | | | be | q zero | (B) | | | | | | | In the above example, (A) THROUGHPUT is 2, (A) LATENCY is 4, and (B) THROUGHPUT is 3. (B) refers to the flag updated by the operation of (A). Accordingly (B) is executed until the number of the (A) LATENCY cycles. # **Cautions on the instruction description** The cautions are not on the programming for instruction description, assignment, and combination. The next section shows "Recommendations on the instruction description". # 3 # **Recommendations on Instruction description** The recommendations are for the instruction description, combination and instruction assignment. For the instruction description of this recommendations, meeting the requirement is not essential, however, when not meeting the requirement, please take note that the increase of the executing cycle number may be caused. The recommendations on instruction description consists of the following parts. #### [Contents] It describes the recommended contents. For some recommended parts, it shows pipeline operation figures. #### [Classification] High-speed processing ### High-speed processing This is recommended in order to execute instructions at high speed through not causing fluctuation of pipeline operations. ### [Examples] It describes the programming examples in the assembly language and the explanation about that. [General example of description] This is an example of programming without considering pipeline fluctuation by the following instrution. [Recommended example of description] This is an example of executing instructions at high speed with considering in order not to occur pipeline fluctuation. #### [Applicable instructions] This describes the applicable instructions for recommendations. In the programming examples, when inserting multiple cycles between instructions, it is not necessary to be INC instruction for easily understanding. An instruction with no dependence with the instructions around inserting can be inserted instead of INC. | Preceding instrcution | Following instruction | Assignment | Recommendations | Position | |-----------------------|-----------------------|------------------------------------------|-----------------------------------------------------|----------| | Allinstructions | - | - | The instructions have two 8-byte instruction buff- | | | | | | ers, and assigns instructions not as to causing a | | | | | | lack of instruction supply. Multiple cycles is nec- | | | | | | essary for the decoding of over-4-byte | | | | | | instructions in order to decode instructions per 4- | l | | | | | byte unit by the instruction decoder. An instruc- | | | | | | tion with a large instruction length should not be | l | | | | | used as much as possible. | | | LCC instruction | | Branch target | Branch target instruction assigns an instruction | 3-1 | | | | | that m of 8n-4+m has a small address, short | | | | | | length, and small instruction consumption per | | | | | | cycle. | | | Branch instructions | | | Branch target instruction assigns an instruction | 3-1 | | except for LCC in- | | | that m of 8n+m has a small address, short length, | (2) | | struction | | | and small instruction consumption per cycle. | | | BCC/LCC | | Subsequent | Non-branch side assigns an instruction that has | 3-1 | | instruction | | 2 33 2 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | short length and small instruction consumption | | | | | | per cycle. | | | | | | per eyere. | | | Instructions except | | | This averages amount of instruction consump- | 3-1 | | for branch instruc- | | | tion. | (4) | | tions | | | | | | MOVM (SP), regs | SETLB Instruction | Subsequent | 1 cycle insertion | 3-2 | | RET/RETF | | Return target | | | | MOV Dm, MD | RETF Instruction | Subsequent | 3 cycle insertion | 3-3 | | EXT instruction | | | | (1) | | MUL/MULU | | | | | | DIV/DIVU | | Subsequent | | 3-3 | | CALL/CALLS | | Branch target | 2 cycle insertion | (2) | | | | | 1 cycle insertion | | | MOVM (SP), regs | | Subsequent | 1 cycle insertion | 3-3 | | RET/RETF | | Return target | | (3) | | CALL/CALLS | MOV MDR, Dn | Branch target | 2 cycle insertion | 3-4 | | | DIV/DIVU | | | | ### 3-1 Instruction assignment subsequent to branch instruction (1) Assignment of branch target instruction in Lcc instruction #### [Contents] The instruction fetch is carried out by a unit of the 8-byte boundary, and 4-byte stores the branch instruction of Lcc instruction in LIR. Therefore, in the case of Lcc, m of [8n-4+m (m,n are integers from 0 to 7)] locates an instruction length with short instruction length and the long number of execution cycle at a small address. ### [Example] | align | 8 | | |-------|---------------|---------------------| | mov | 0x00,a0 | | | clr | d0 | | | setlb | | | | mov | d0,(a0) | <- assigned at 8n-4 | | mov | d0,(0x10,a0) | | | mov | d0, (0x20,a0) | <- assigned at 8n | | mov | d0, (0x30,a0) | | | inc | a0 | | | cmp | 0x10,a0 | | | 11t | | | | | | | The above program is an example when the branch target of LLT is assigned at 8n-4. As the result of this assignment, mov d0, (a0) and mov d0, (0x10, a0) are stored in LIR, and the address 8n is stored in LAR. Therefore, during executing the instructions stored in LIR, CPU core starts a fetch from the beginning of the 8-byte boundary, and can fetch the maximum 8-byte instruction. ### [Applicable instruction] <Pre><Preceding instruction> Lcc instruction <Branch target instruction> All instructions (2) Assignment of branch target instruction in the branch instructions other than LCC #### [Contents] The instruction fetch is carried out by a unit of the 8-byte boundary. Therefore, in the case of the branch instructions except for Lcc, m of [8n-4+m (m,n are integers from 0 to 7)] locates an instruction length with long instruction length and the long number of execution cycle at a small address. #### [Example] | Lixampic | | | | |----------|-------|---------------|-------------------| | | align | 8 | | | | nop | | | | | nop | | | | | nop | | | | | nop | | | | | nop | | | | | mov | 0x00,a0 | | | | clr | d0 | | | LABEL | mov | d0, (a0) | <- assigned at 8n | | | mov | d0,(0x10,a0) | | | | mov | d0, (0x20,a0) | | | | mov | d0, (0x30,a0) | | | | inc | a0 | | | | cmp | 0x10,a0 | | | | blt | LABEL | | | | | | | The above program is an example when the branch target of LLT is assigned at 8n-4. As the result of this assignment, mov d0, (a0) and mov d0, (0x10, a0) are stored in LIR, and the address 8n is stored in LAR. Therefore, during executing the instructions stored in LIR, CPU core starts a fetch from the beginning of the 8-byte boundary, and can fetch the maximum 8-byte instruction. This can decrease a possibility that lack of instruction supply occurs. #### [Applicable instruction] <Pre><Preceding instruction> Bcc, JMP, CALL, CALLS, RET, RETF, RETS, RTI, TRAP All instructions <Branch target instruction> (3) Assignment of the instructions subsequent to Bcc and Lcc #### [Contents] The subsequent instruction, i.e. non-branch side, has a short instruction length and large number of execution cycles. #### [Example] | _ | blt | LABEL | | |---|-----|--------|------------------------------------------| | | MUL | D0, D1 | <- 2-byte instruction and multiple-cycle | | | | | execution | | | | | | The above program is an example when the branch target of MUL is assigned at non-branch side. As the result of this assignment, when BLT is non-branch, CPU core can fetch subsequent instructions during executing MUL instructions. Therefore, it can get a higher performance without the occurence of the pipeline stall due to the lack of instruction supply. #### [Applicable instructions] <Pre><Preceding instruction> Bcc and Lcc instructions <Subsequent instruction> All instructions (4) Assignment of the instructions subsequent to all instructions other than the branch instruction ### [Contents] If the instructions that comsumes multiple-byte instructions once (instructions with long instructions word length) are continuously assigned, instruction comsumption is more than instruction supply and the lack of instruction supply occurs. Therefore, if the instructions are assigned so as to comsume instructions on the average, a higher performance is obtained. #### [Example] | mov | 0x12345678, d0 | <- 6-byte instruction | |-----|----------------|-----------------------| | mov | (a0), d1 | <- 1-byte instruction | | inc | d0 | <- 1-byte instruction | | add | d0, d1 | <- 1-byte instruction | | mov | 0x9abcdef0, d2 | <- 6-byte instruction | | | | | The above program is an example so as not to assign continuously the instructions with long instruction length. As the result of this assignment, instruction comsumption can be average, and pipelkine stall becomes difficult to occur. Accordingly, a higher performance is obtained. #### [Applicable instruction] <Pre><Preceding instruction> All instructions other than the following instructions: Bcc, Lcc, JMP, CALL, CALLS, RET, RETF, RETS, RTI, **TRAP** All instructions <Subsequent instruction> ### 3-2 Instruction assignment subsequent to SETLB SETLB performs write into LIR and LAR at high speed through different processing than normal pipeline processing with special hardware. Therefore, the instructions changing the preceding LIR and LAR are not executed until the change of LIR and LAR has completed. #### [Contents] It is recommended that more than 1 cycle should be inserted between the instructions changing LIR and LAR preceding to SETLB in order to run the pipeline smoothly. ### [Examples] | [Example] | | | | |-----------|-------|--------------|-------------------------------------| | | inc | d2 | | | | movm | (sp),[other] | <- Instruction changing LIR and LAR | | | setlb | | <- SETLB instruction | | | | | | A pipeline stall occurs and the operations of SETLB is delayed until the write of LIR and LAR in MOVM has completed since the operations of SETLB start before the write of LIR and LAR has completed. | [Recommended description ex | xamples] | | | |-----------------------------|----------|--------------|-------------------------------------| | mo | ovm | (sp),[other] | <- Instruction changing LIR and LAR | | inc | c | d2 | | | set | tlb | | <- SETLB instruction | SETLB can be executed without the occurence of pipeline stall since the write of LIR and LAR has already completed when executing SETLB. #### [Applicable instructions] <Pre><Preceding or return target instructions> MOVM (SP), reg, RET, RETF <Subsequent instruction> **SETLB** ## 3-3 Assignment of the instructions preceding RETF RETF performs a branch from the subroutine to the return target at high speed by using the contents of MDR as return address. Therefore, the instructions changing the preceding MDR are not executed until the change of MDR has completed. High-speed processing (1) Assignment of the instructions changing MDFin the final cycle of executing instructions and subsequent RETF. #### [Contents] It is recommended that more than 2 cycles should be inserted between the instructions changing MDR in the final cycle of executing instructions and subsequent RETF in order to run the pipeline smoothly. #### [Examples] | [General description ex | amplesl | | | |-------------------------|----------|------------|----------------------------------------------| | _func | minbioo] | | | | _Ofunc | FUNCINFO | _func,8,[] | | | | inc | a0 | | | | mov | d0,mdr | <- Instructions changing MDR | | | | | in the final cycle of executing instructions | | | inc | a1 | | | | inc | a2 | | | | retf | | <- RETF | | OR | | | | | _func | | | | | _0func | FUNCINFO | _func,8,[] | | | | inc | a0 | | | | inc | a1 | | | | mov | a0,mdr | <- Instructions changing MDR | | | | | in the final cycle of executing instructions | | | inc | a2 | | | | retf | | <- RETF | | OR | | | | | _func | | | | | _0func | FUNCINFO | _func,8,[] | | | | inc | a0 | | | | inc | a1 | | | | inc | a2 | | | | mov | d0,mdr | <- Instructions changing MDR | | | | | in the final cycle of executing instructions | | | retf | | <- RETF | A pipeline stall occurs and the operations of RETF is delayed until the write of MDR in MOV has completed since the operations of RETF start before the write of MDR has completed. | [General description | _func | FUNCINFO | _func,8,[ ] | | |----------------------|--------|----------|-------------|-------------------------------------------| | | _runco | TONCINIO | _rune,o,[ ] | | | | | mov | d0,mdr | <- Instructions changing MDR in the final | | | | | | cycle of executing instructions | | | | inc | a0 | | | | | inc | a1 | | | | | inc | a2 | | | | | retf | | <- RET | RETF can be executed without the occurence of pipeline stall since the write of MDR in MOV has already completed when executing RETF. #### [Applicabel instructions] <Pre><Preceding instructions> MOV Dm, MDR, EXT, MUL, MULU <Subsequent instructions> RETF For the details of the description of FUNCINFO pseudo-instruction, refer to MN103E series cross-assembler user's manual. (2) Assignment of the instructions changing MDFin the final cycle of executing instructions and subsequent RETF High-speed processing ### [Contents] It is recommended that more than 2 cycles should be inserted between the instructions changing MDR at one cycle earlier than the final cycle of the instruction execution and the subsequent RETF. ### [Examples] | [General description example of the control | mples] | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|---------------------------------------------------| | _lab | | | | | LABEL | FUNCINFO | _func,8,[] | | | | inc | a0 | | | | div | d1,d0 | <- Instructions changing MDR in one cycle earlier | | | | | than the final cycle of instruction execution | | | inc | a1 | | | | retf | | <- RET | | OR | | | | | _lab | | | | | LABEL | FUNCINFO | _lab,8,[ ] | | | | inc | a0 | | | | inc | a1 | | | | div | d1,d0 | <- Instructions changing MDR in one cycle earlier | | | | | than the final cycle of instruction execution | | | retf | | <- RETF | A pipeline stall occurs and the operations of RETF is delayed until the write of MDR in DIV has completed since the operations of RETF start before the write of MDR has completed. | [Recommended description examples] _lab | | | | | | | | | | |-----------------------------------------|--------------|-------------------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | LABEL | FUNCINFO inc | _func,8,[ ]<br>a0 | | | | | | | | | | div | d1,d0 | <- Instructions changing MDR in one cycle earlier<br>than the final cycle of instruction execution | | | | | | | | | inc | a0 | · | | | | | | | | | inc | a1 | | | | | | | | | | retf | | <- RET | | | | | | | ### [Applicable instructions] DIV, DIVU, CALL, CALLS <Pre><Preceding instructions, or Branch instructions> **RETF** <Subsequent instructions> For the details of the description of FUNCINFO pseudo-instruction, refer to MN103E series cross-assembler user's manual. (3) Assignment of the instructions changing MDR at 2 cycles earlier than the final cycle of executing instructions and subsequent RETF #### [Contents] It is recommended that more than 1 cycle should be inserted between the instructions changing MDR at 2 cycles earlier than the final cycle of the instruction execution and the subsequent RETF. #### [Examples] A pipeline stall occurs and the operations of RETF is delayed until the write of MDR in MOVM has completed since the operations of RETF start before the write of MDR has completed. | [Recommended d | escription examples] | | | |----------------|----------------------|-------------------------|-------------------------------------------------------------| | LABEL | FUNCINFO<br>movm | _lav,8,[] (sp), [other] | <- Instructions changing MDR in one | | | | (1// ) | cycle earlier than the final cycle of instruction execution | | | inc | d0 | | | | retf | | <- RET | RETF can be executed without the occurence of pipeline stall since the write of MDR in MOVM has already completed when executing RETF. #### [Applicable instructions] <Pre><Preceding instructions, or return target instruction> MOV (SP), reg, RET, RETF <Subsequent instructions> RETF For the details of the description of FUNCINFO pseudo-instruction, refer to MN103E0 series cross-assembler user's manual. ### 3-4 Assignment of the instructions of CALL/CALLS branch targets #### [Contents] CALL/CALLS store the return target address in MDR in order to speed up branching to the return address of RETF. Therefore, the instructions refering to MDR of the branch target are not executed until storing the return target address in MDR has completed. It is recommended that more than 2 cycles should be inserted between CALL/CALLS and the instructions referring to MDR at the branch target in order to run the pipeline smoothly. It is recommended that more than 2 cycles should be inserted between the instructions changing MDR in the final cycle of executing instructions and subsequent RETF in order to run the pipeline smoothly. ### [Examples] | [General description | n examples] | | | |----------------------|-------------|---------|---------------------------------| | | call | LABEL | | | | : | | | | | : | | | | LABEL | inc | a0 | | | | mov | mdr, d0 | <- Instructions refering to MDR | | | inc | a1 | | | | retf | | <- RETF | | OR | | | | | | call | LABEL | | | | : | | | | | : | | | | LABEL | mov | mdr, d0 | <- Instructions refering to MDR | | | inc | a0 | <- Instructions refering to MDR | | | inc | a0 | | | | retf | | <- RETF | A pipeline stall occurs and the operations of MOV is delayed until the write to MDR has completed since the operations of MOV start before the write to MDR in CALL has completed. | [Recommended de | escription examples | s] | | | |-----------------|---------------------|---------|---------------------------------|--| | | call | LABEL | <- CALL/CALLS | | | | : | | | | | | : | | | | | LABEL | inc | a0 | | | | | inc | a1 | | | | | mov | mdr, d0 | <- Instructions refering to MDR | | When executing MOV, MDR can be referred without the occurence of pipeline stall since the write to MDR in CALL has completed. ### [Applicable instructions] <Preceding instructions> CALL, CALLS <Subsequent instructions> MOV, MDR, Dn, DIV, DIVU 4 Chapter 4 Appendix | | | AM33 | -1 | AM33-2/AN | //33-2A | NOTE | |---------|-------------|------------|---------|------------|---------|------| | Assembl | y mnemonic | Throughput | Latency | Throughput | Latency | | | MOV | Am,An | 1 | 1 | 1 | 1 | | | MOV | Dm,Dn | 1 | 1 | 1 | 1 | | | MOV | Am,Dn | 1 | 1 | 1 | 1 | | | MOV | Dm,An | 1 | 1 | 1 | 1 | | | MOV | Am,Rn | 1 | 1 | 1 | 1 | | | MOV | Rm,An | 1 | 1 | 1 | 1 | | | MOV | Dm,Rn | 1 | 1 | 1 | 1 | | | MOV | Rm,Dn | 1 | 1 | 1 | 1 | | | MOV | Rm,Rn | 1 | 1 | 1 | 1 | | | MOV | imm8,An | 1 | 1 | 1 | 1 | | | MOV | imm16,An | 1 | 1 | 1 | 1 | | | MOV | imm32,An | 2 | 2 | 2 | 2 | | | MOV | imm8,Dn | 1 | 1 | 1 | 1 | | | MOV | imm16,Dn | 1 | 1 | 1 | 1 | | | MOV | imm32,Dn | 2 | 2 | 2 | 2 | | | MOV | imm8,Rn | 1 | 1 | 1 | 1 | | | MOV | imm24,Rn | 2 | 2 | 2 | 2 | | | MOV | imm32,Rn | 2 | 2 | 2 | 2 | | | MOV | MDR,Dn | 1 | 1 | 1 | 1 | | | MOV | Dm,MDR | 1 | 1 | 1 | 1 | | | MOV | SP,An | 1 | 1 | 1 | 1 | | | MOV | Am,SP | 1 | 1 | 1 | 1 | | | MOV | PC,An | 1 | 1 | 1 | 1 | | | MOV | (Am),Dn | 1 | 3 | 1 | 3 | | | MOV | (Am),An | 1 | 3 | 1 | 3 | | | MOV | (Rm),Rn | 1 | 3 | 1 | 3 | | | MOV | (d8,Am),Dn | 1 | 3 | 1 | 3 | | | MOV | (d16,Am),Dn | 1 | 3 | 1 | 3 | | | MOV | (d32,Am),Dn | 2 | 4 | 2 | 4 | | | MOV | (d8,Am),An | 1 | 3 | 1 | 3 | | | MOV | (d16,Am),An | 1 | 3 | 1 | 3 | | | MOV | (d32,Am),An | 2 | 4 | 2 | 4 | | | MOV | (d8,Rm),Rn | 1 | 3 | 1 | 3 | | | MOV | (d24,Rm),Rn | 2 | 4 | 2 | 4 | | | MOV | (d32,Rm),Rn | 2 | 4 | 2 | 4 | | | MOV | (Di,Am),Dn | 1 | 3 | 1 | 3 | | | MOV | (Di,Am),An | 1 | 3 | 1 | 3 | | | MOV | (Ri,Rm),Rn | 1 | 3 | 1 | 3 | | | MOV | (abs16),Dn | 1 | 3 | 1 | 3 | | | MOV | (abs32),Dn | 2 | 4 | 2 | 4 | | | MOV | (abs16),An | 1 | 3 | 1 | 3 | | | MOV | (abs32),An | 2 | 4 | 2 | 4 | | | MOV | (abs8),Rn | 1 | 3 | 1 | 3 | | | MOV | (abs24),Rn | 2 | 4 | 2 | 4 | | | MOV | (abs32),Rn | 2 | 4 | 2 | 4 | | | | | AM33- | 1 | AM33-2/AN | //33-2A | NOTE | |-----|---------------|------------|---------|------------|---------|------------------------------| | | ly mnemonic | Throughput | Latency | Throughput | Latency | | | MOV | (d8,SP),Dn | 1 | 3 | 1 | 3 | | | MOV | (d16,SP),Dn | 1 | 3 | 1 | 3 | | | MOV | (d32,SP),Dn | 2 | 4 | 2 | 4 | | | MOV | (d8,SP),An | 1 | 3 | 1 | 3 | | | MOV | (d16,SP),An | 1 | 3 | 1 | 3 | | | MOV | (d32,SP),An | 2 | 4 | 2 | 4 | | | MOV | (SP),Rn | 1 | 3 | 1 | 3 | | | MOV | (d8,SP),Rn | 1 | 3 | 1 | 3 | | | MOV | (d24,SP),Rn | 2 | 4 | 2 | 4 | | | MOV | (d32,SP),Rn | 2 | 4 | 2 | 4 | | | MOV | (d8,Am),SP | 1 | 3 | 1 | 3 | | | MOV | Dm,(An) | 1 | _ | 1 | _ | | | MOV | Am,(An) | 1 | _ | 1 | _ | | | MOV | Rm,(Rn) | 1 | _ | 1 | _ | | | MOV | Dm,(d8,An) | 1 | _ | 1 | _ | | | MOV | Dm,(d16,An) | 1 | _ | 1 | _ | | | MOV | Dm,(d32,An) | 2 | _ | 2 | _ | | | MOV | Am,(d8,An) | 1 | - | 1 | - | | | MOV | | | - | | - | | | | Am,(d16,An) | 1 | - | 1 | - | | | MOV | Am,(d32,An) | 2 | - | 2 | - | | | MOV | Rm,(d8,Rn) | 1 | - | 1 | - | | | MOV | Rm,(d24,Rn) | 2 | - | 2 | - | | | MOV | Rm,(d32,Rn) | 2 | - | 2 | - | | | MOV | Dm,(Di,An) | 1 | - | 1 | - | | | MOV | Am,(Di,An) | 1 | - | 1 | - | | | MOV | Rm,(Ri,Rn) | 1 | - | 1 | - | | | MOV | Dm,(abs16) | 1 | - | 1 | - | | | MOV | Dm,(abs32) | 2 | - | 2 | - | | | MOV | Am,(abs16) | 1 | - | 1 | - | | | MOV | Am,(abs32) | 2 | - | 2 | - | | | MOV | Rm,(abs8) | 1 | - | 1 | - | | | MOV | Rm,(abs24) | 2 | - | 2 | - | | | MOV | Rm,(abs32) | 2 | - | 2 | - | | | MOV | Dm,(d8,SP) | 1 | - | 1 | - | | | MOV | Dm,(d16,SP) | 1 | - | 1 | - | | | MOV | Dm,(d32,SP) | 2 | _ | 2 | _ | | | MOV | Am,(d8,SP) | 1 | _ | 1 | - | | | MOV | Am,(d16,SP) | 1 | _ | 1 | _ | | | MOV | Am,(d32,SP) | 2 | _ | 2 | _ | | | MOV | Rm,(SP) | 1 | _ | 1 | _ | | | MOV | Rm,(d8,SP) | 1 | _ | 1 | _ | | | MOV | Rm,(d24,SP) | 2 | - | 2 | - | | | | | 2 | - | 2 2 | - | | | MOV | Rm,(d32,SP) | | - | | - | | | MOV | SP,(d8,An) | 1 | - | 1 | - | | | MOV | (Rm+,imm8),Rn | 1 | 3 | 1 | 3 | Rm is valid at Latency of 1. | | | | AM33 | -1 | AM33-2/AN | 133-2A | NOTE | |----------|----------------|------------|---------|------------|---------|------------------------------| | Assembly | mnemonic | Throughput | Latency | Throughput | Latency | | | MOV | (Rm+,imm24),Rn | 2 | 4 | 2 | 4 | Rm is valid at Latency of 2. | | MOV | (Rm+,imm32),Rn | 2 | 4 | 2 | 4 | Rm is valid at Latency of 2. | | MOV | (Rm+),Rn | 1 | 3 | 1 | 3 | Rm is valid at Latency of 1. | | MOV | Rm,(Rn+,imm8) | 1 | 1 | 1 | 1 | | | MOV | Rm,(Rn+,imm24) | 2 | 2 | 2 | 2 | | | MOV | Rm,(Rn+,imm32) | 2 | 2 | 2 | 2 | | | MOV | Rm,(Rn+) | 1 | 1 | 1 | 1 | | | MOV | MSP,An | 1 | 1 | 1 | 1 | | | MOV | Am,MSP | 1 | 1 | 1 | 1 | | | MOV | SSP,An | 1 | 1 | 1 | 1 | | | MOV | Am,SSP | 1 | 1 | 1 | 1 | | | MOV | USP,An | 1 | 1 | 1 | 1 | | | MOV | Dm,EPSW | 1 | 1 | 1 | 1 | | | MOV | EPSW,Dn | 1 | 1 | 1 | 1 | | | MOV | Dm,PSW | 1 | 1 | 1 | 1 | | | MOV | PSW,Dn | 1 | 1 | 1 | 1 | | | MOVU | imm8,Rn | 1 | 1 | 1 | 1 | | | MOVU | imm24,Rn | 2 | 2 | 2 | 2 | | | MOVU | imm32,Rn | 2 | 2 | 2 | 2 | | | MOVHU | (Am),Dn | 1 | 3 | 1 | 3 | | | MOVHU | (Rm),Rn | 1 | 3 | 1 | 3 | | | MOVHU | (d8,Am),Dn | 1 | 3 | 1 | 3 | | | MOVHU | (d16,Am),Dn | 1 | 3 | 1 | 3 | | | MOVHU | (d32,Am),Dn | 2 | 4 | 2 | 4 | | | MOVHU | (d8,Rm),Rn | 1 | 3 | 1 | 3 | | | MOVHU | (d24,Rm),Rn | 2 | 4 | 2 | 4 | | | MOVHU | (d32,Rm),Rn | 2 | 4 | 2 | 4 | | | MOVHU | (Di,Am),Dn | 1 | 3 | 1 | 3 | | | MOVHU | (Ri,Rm),Rn | 1 | 3 | 1 | 3 | | | MOVHU | (abs16),Dn | 1 | 3 | 1 | 3 | | | MOVHU | (abs32),Dn | 2 | 4 | 2 | 4 | | | MOVHU | (abs8),Rn | 1 | 3 | 1 | 3 | | | MOVHU | (abs24),Rn | 2 | 4 | 2 | 4 | | | | | | | | | | | MOVHU | (abs32),Rn | 2 | 4 | 2 | 4 | | | MOVHU | (d8,SP),Dn | 1 | 3 | 1 | 3 | | | MOVHU | (d16,SP),Dn | 1 | 3 | 1 | 3 | | | MOVHU | (d32,SP),Dn | 2 | 4 | 2 | 4 | | | MOVIU | (SP),Rn | 1 | 3 | 1 | 3 | | | MOVHU | (d8,SP),Rn | 1 | 3 | 1 | 3 | | | MOVHU | (d24,SP),Rn | 2 | 4 | 2 | 4 | | | MOVHU | (d32,SP),Rn | 2 | 4 | 2 | 4 | | | MOVHU | Dm,(An) | 1 | - | 1 | - | | | MOVHU | Rm,(Rn) | 1 | - | 1 | - | | | MOVHU | Dm,(d8,An) | 1 | - | 1 | - | | | MOVHU | Dm,(d16,An) | 1 | - | 1 | - | | | | | AM33- | 1 | AM33-2/AN | //33-2A | NOTE | |----------|----------------|------------|---------|------------|---------|------------------------------| | Assembly | mnemonic | Throughput | Latency | Throughput | Latency | | | MOVHU | Dm,(d32,An) | 2 | - | 2 | - | | | MOVHU | Rm,(d8,Rn) | 1 | - | 1 | - | | | MOVHU | Rm,(d24,Rn) | 2 | - | 2 | - | | | MOVHU | Rm,(d32,Rn) | 2 | - | 2 | - | | | MOVHU | Dm,(Di,An) | 1 | - | 1 | - | | | MOVHU | Rm,(Ri,Rn) | 1 | - | 1 | - | | | MOVHU | Dm,(abs16) | 1 | - | 1 | - | | | MOVHU | Dm,(abs32) | 2 | - | 2 | - | | | MOVHU | Rm,(abs8) | 1 | - | 1 | - | | | MOVHU | Rm,(abs24) | 2 | - | 2 | - | | | MOVHU | Rm,(abs32) | 2 | - | 2 | - | | | MOVHU | Dm,(d8,SP) | 1 | - | 1 | - | | | MOVHU | Dm,(d16,SP) | 1 | - | 1 | - | | | MOVHU | Dm,(d32,SP) | 2 | - | 2 | - | | | MOVHU | Rm,(SP) | 1 | - | 1 | - | | | MOVHU | Rm,(d8,SP) | 1 | - | 1 | - | | | MOVHU | Rm,(d24,SP) | 2 | - | 2 | - | | | MOVHU | Rm,(d32,SP) | 2 | - | 2 | - | | | MOVHU | (Rm+,imm8),Rn | 1 | 3 | 1 | 3 | Rm is valid at Latency of 1. | | MOVHU | (Rm+,imm24),Rn | 2 | 4 | 2 | 4 | Rm is valid at Latency of 2. | | MOVHU | (Rm+,imm32),Rn | 2 | 4 | 2 | 4 | Rm is valid at Latency of 2. | | MOVHU | (Rm+),Rn | 1 | 3 | 1 | 3 | Rm is valid at Latency of 1. | | MOVHU | Rm,(Rn+,imm8) | 1 | 1 | 1 | 1 | | | MOVHU | Rm,(Rn+,imm24) | 2 | 2 | 2 | 2 | | | MOVHU | Rm,(Rn+,imm32) | 2 | 2 | 2 | 2 | | | MOVHU | Rm,(Rn+) | 1 | 1 | 1 | 1 | | | MOVBU | (Am),Dn | 1 | 3 | 1 | 3 | | | MOVBU | (Rm),Rn | 1 | 3 | 1 | 3 | | | MOVBU | (d8,Am),Dn | 1 | 3 | 1 | 3 | | | MOVBU | (d16,Am),Dn | 1 | 3 | 1 | 3 | | | MOVBU | (d32,Am),Dn | 2 | 4 | 2 | 4 | | | MOVBU | (d8,Rm),Rn | 1 | 3 | 1 | 3 | | | MOVBU | (d24,Rm),Rn | 2 | 4 | 2 | 4 | | | MOVBU | (d32,Rm),Rn | 2 | 4 | 2 | 4 | | | MOVBU | (Di,Am),Dn | 1 | 3 | 1 | 3 | | | MOVBU | (Ri,Rm),Rn | 1 | 3 | 1 | 3 | | | MOVBU | (abs16),Dn | 1 | 3 | 1 | 3 | | | MOVBU | (abs32),Dn | 2 | 4 | 2 | 4 | | | MOVBU | (abs8),Rn | 1 | 3 | 1 | 3 | | | MOVBU | (abs24),Rn | 2 | 4 | 2 | 4 | | | MOVBU | (abs32),Rn | 2 | 4 | 2 | 4 | | | MOVBU | (d8,SP),Dn | 1 | 3 | 1 | 3 | | | MOVBU | (d16,SP),Dn | 1 | 3 | 1 | 3 | | | MOVBU | (d32,SP),Dn | 2 | 4 | 2 | 4 | | | MOVBU | (SP),Rn | 1 | 3 | 1 | 3 | | | | | AM3 | 3-1 | AM33-2/AN | 133-2A | NOTE | |----------|-------------|------------|---------|------------|---------|-----------------------| | Assembly | y mnemonic | Throughput | Latency | Throughput | Latency | | | MOVBU | (d8,SP),Rn | 1 | 3 | 1 | 3 | | | MOVBU | (d24,SP),Rn | 2 | 4 | 2 | 4 | | | MOVBU | (d32,SP),Rn | 2 | 4 | 2 | 4 | | | MOVBU | Dm,(An) | 1 | - | 1 | - | | | MOVBU | Rm,(Rn) | 1 | - | 1 | - | | | MOVBU | Dm,(d8,An) | 1 | - | 1 | - | | | MOVBU | Dm,(d16,An) | 1 | - | 1 | - | | | MOVBU | Dm,(d32,An) | 2 | - | 2 | - | | | MOVBU | Rm,(d8,Rn) | 1 | - | 1 | - | | | MOVBU | Rm,(d24,Rn) | 2 | - | 2 | - | | | MOVBU | Rm,(d32,Rn) | 2 | - | 2 | - | | | MOVBU | Dm,(Di,An) | 1 | - | 1 | - | | | MOVBU | Rm,(Ri,Rn) | 1 | - | 1 | - | | | MOVBU | Dm,(abs16) | 1 | - | 1 | - | | | MOVBU | Dm,(abs32) | 2 | - | 2 | - | | | MOVBU | Rm,(abs8) | 1 | - | 1 | - | | | MOVBU | Rm,(abs24) | 2 | - | 2 | - | | | MOVBU | Rm,(abs32) | 2 | - | 2 | - | | | MOVBU | Dm,(d8,SP) | 1 | - | 1 | = | | | MOVBU | Dm,(d16,SP) | 1 | - | 1 | = | | | MOVBU | Dm,(d32,SP) | 2 | - | 2 | - | | | MOVBU | Rm,(SP) | 1 | - | 1 | = | | | MOVBU | Rm,(d8,SP) | 1 | - | 1 | - | | | MOVBU | Rm,(d24,SP) | 2 | - | 2 | = | | | MOVBU | Rm,(d32,SP) | 2 | - | 2 | = | | | MOVM | (SP),regs | 2+REGs | 2+REGs | 2+REGs | 2+REGs | | | MOVM | (USP),regs | 2+REGs | 2+REGs | 2+REGs | 2+REGs | REGs=Numberofregister | | MOVM | regs,(SP) | 2+REGs | 2+REGs | 2+REGs | 2+REGs | | | MOVM | regs,(USP) | 2+REGs | 2+REGs | 2+REGs | 2+REGs | J | | EXT | Dn | 1 | 1 | 1 | 1 | | | EXT | Rn | 1 | 1 | 1 | 1 | | | EXTH | Dn | 1 | 1 | 1 | 1 | | | EXTH | Rn | 1 | 1 | 1 | 1 | | | EXTH | Rm,Rn | 1 | 1 | 1 | 1 | | | EXTHU | Dn | 1 | 1 | 1 | 1 | | | EXTHU | Rn | 1 | 1 | 1 | 1 | | | EXTHU | Rm,Rn | 1 | 1 | 1 | 1 | | | EXTB | Dn | 1 | 1 | 1 | 1 | | | EXTB | Rn | 1 | 1 | 1 | 1 | | | EXTB | Rm,Rn | 1 | 1 | 1 | 1 | | | EXTBU | Dn | 1 | 1 | 1 | 1 | | | EXTBU | Rn | 1 | 1 | 1 | 1 | | | EXTBU | Rm,Rn | 1 | 1 | 1 | 1 | | | CLR | Dn | 1 | 1 | 1 | 1 | | | CLR | Rn | 1 | 1 | 1 | 1 | | | | | AM33- | 1 | AM33-2/AM | //33-2A | NOTE | |--------|-------------|------------|---------|------------|---------|------| | Assemb | ly mnemonic | Throughput | Latency | Throughput | Latency | | | DCPF | (Rm) | - | - | 1 | - | | | DCPF | (d8,Rm) | - | - | 1 | - | | | DCPF | (d24,Rm) | - | - | 2 | - | | | DCPF | (d32,Rm) | - | - | 2 | - | | | DCPF | (Ri,Rm) | - | - | 1 | - | | | DCPF | (SP) | - | - | 1 | - | | | ADD | Dm,Dn | 1 | 1 | 1 | 1 | | | ADD | Dm,An | 1 | 1 | 1 | 1 | | | ADD | Am,Dn | 1 | 1 | 1 | 1 | | | ADD | Am,An | 1 | 1 | 1 | 1 | | | ADD | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | ADD | Rm,Rn | 1 | 1 | 1 | 1 | | | ADD | imm8,Dn | 1 | 1 | 1 | 1 | | | ADD | imm16,Dn | 1 | 1 | 1 | 1 | | | ADD | imm32,Dn | 2 | 2 | 2 | 2 | | | ADD | imm8,An | 1 | 1 | 1 | 1 | | | ADD | imm16,An | 1 | 1 | 1 | 1 | | | ADD | imm32,An | 2 | 2 | 2 | 2 | | | ADD | imm8,Rn | 1 | 1 | 1 | 1 | | | ADD | imm24,Rn | 2 | 2 | 2 | 2 | | | ADD | imm32,Rn | 2 | 2 | 2 | 2 | | | ADD | imm8,SP | 1 | 1 | 1 | 1 | | | ADD | imm16,SP | 1 | 1 | 1 | 1 | | | ADD | imm32,SP | 2 | 2 | 2 | 2 | | | ADDC | Dm,Dn | 1 | 1 | 1 | 1 | | | ADDC | Rm,Rn | 1 | 1 | 1 | 1 | | | ADDC | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | ADDC | imm8,Rn | 1 | 1 | 1 | 1 | | | ADDC | imm24,Rn | 2 | 2 | 2 | 2 | | | ADDC | imm32,Rn | 2 | 2 | 2 | 2 | | | SUB | Dm,Dn | 1 | 1 | 1 | 1 | | | SUB | Dm,An | 1 | 1 | 1 | 1 | | | SUB | Am,Dn | 1 | 1 | 1 | 1 | | | SUB | Am,An | 1 | 1 | 1 | 1 | | | SUB | Rm,Rn | 1 | 1 | 1 | 1 | | | SUB | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | SUB | imm8,Rn | 1 | 1 | 1 | 1 | | | SUB | imm24,Rn | 2 | 2 | 2 | 2 | | | SUB | imm32,Rn | 2 | 2 | 2 | 2 | | | SUB | imm32,Dn | 2 | 2 | 2 | 2 | | | SUB | imm32,An | 2 | 2 | 2 | 2 | | | SUBC | Dm,Dn | 1 | 1 | 1 | 1 | | | SUBC | Rm,Rn | 1 | 1 | 1 | 1 | | | SUBC | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | SUBC | imm8,Rn | 1 | 1 | 1 | 1 | | | | | AM33 | -1 | AM33-2/AN | //33-2A | NOTE | |------------------|-----------------------------------------|------------|---------|------------|---------|------| | Assemb | ly mnemonic | Throughput | Latency | Throughput | Latency | | | SUBC | imm24,Rn | 2 | 2 | 2 | 2 | | | SUBC | imm32,Rn | 2 | 2 | 2 | 2 | | | MUL | Dm,Dn | 2 | 3 | 2 | 3 | | | MUL | Rm,Rn | 2 | 3 | 2 | 3 | | | MUL | Rm,Rn,Rd1,Rd2 | 2 | 3 | 2 | 3 | | | MUL | imm8,Rn | 2 | 3 | 2 | 3 | | | MUL | imm24,Rn | 3 | 4 | 3 | 4 | | | MUL | imm32,Rn | 3 | 4 | 3 | 4 | | | MULU | Dm,Dn | 2 | 3 | 2 | 3 | | | MULU | Rm,Rn | 2 | 3 | 2 | 3 | | | MULU | Rm,Rn,Rd1,Rd2 | 2 | 3 | 2 | 3 | | | MULU | imm8,Rn | 2 | 3 | 2 | 3 | | | MULU | imm24,Rn | 3 | 4 | 3 | 4 | | | MULU | imm32,Rn | 3 | 4 | 3 | 4 | | | | | | | | | | | DIV | Dm,Dn | | | | | | | (MDR,Dn)=0 | | 4 | 5 | 4 | 5 | | | Value{MDR, | Dn}canspecifyby1-byte. | 14 | 14 | 14 | 14 | | | Value{MDR, | Dn}canspecifyby2-byte. | 22 | 23 | 22 | 23 | | | Value{MDR, | Dn}canspecifyby3-byte. | 30 | 31 | 30 | 31 | | | 1 | Dn}canspecifyby4-byteormore. | 38 | 39 | 38 | 39 | | | | | | | | | | | DIV | Rm,Rn | | | | | | | <br> {MDR,Dn}=0 | · | 4 | 5 | 4 | 5 | | | | Dn}canspecifyby1-byte. | 14 | 14 | 14 | 14 | | | 1 | Dn}canspecifyby2-byte. | 22 | 23 | 22 | 23 | | | | Dn}canspecifyby3-byte. | 30 | 31 | 30 | 31 | | | 1 | Dn}canspecifyby4-byteormore. | 38 | 39 | 38 | 39 | | | , | , , , , , , , , , , , , , , , , , , , , | | | | | | | DIVU | Dm,Dn | | | | | | | {MDR,Dn}=0 | | 4 | 5 | 4 | 5 | | | , , | Dn}canspecifyby1-byte. | 14 | 14 | 14 | 14 | | | | Dn}canspecifyby2-byte. | 22 | 23 | 22 | 23 | | | 1 | Dn}canspecifyby3-byte. | 30 | 31 | 30 | 31 | | | 1 | Dn}canspecifyby4-byteormore. | 38 | 39 | 38 | 39 | | | | , | | | | | | | DIVU | Rm,Rn | | | | | | | {MDR,Dn}=0 | | 4 | 5 | 4 | 5 | | | | Dn}canspecifyby1-byte. | 14 | 14 | 14 | 14 | | | | Dn}canspecifyby2-byte. | 22 | 23 | 22 | 23 | | | | Dn}canspecifyby3-byte. | 30 | 31 | 30 | 31 | | | | OR,Dn} can specify by 4-byte or more | | 39 | 38 | 39 | | | Taido (IVID | | . 00 | | | | | | INC | An | 1 | 1 | 1 | 1 | | | INC | Dn | 1 | 1 | 1 | 1 | | | | ווט | I | ı | ' | 1 | | | | | AM33- | ·1 | AM33-2/AN | //33-2A | NOTE | |----------|---------------------|------------|---------|------------|---------|------| | Assembl | y mnemonic | Throughput | Latency | Throughput | Latency | | | INC | Rn | 1 | 1 | 1 | 1 | | | INC4 | An | 1 | 1 | 1 | 1 | | | INC4 | Rn | 1 | 1 | 1 | 1 | | | CMP | Dm,Dn | 1 | 1 | 1 | 1 | | | CMP | Dm,An | 1 | 1 | 1 | 1 | | | CMP | Am,Dn | 1 | 1 | 1 | 1 | | | CMP | Am,An | 1 | 1 | 1 | 1 | | | CMP | Rm,Rn | 1 | 1 | 1 | 1 | | | CMP | imm8,Dn | 1 | 1 | 1 | 1 | | | CMP | imm16,Dn | 1 | 1 | 1 | 1 | | | CMP | imm32,Dn | 2 | 2 | 2 | 2 | | | CMP | imm8,An | 1 | 1 | 1 | 1 | | | CMP | imm16,An | 1 | 1 | 1 | 1 | | | CMP | imm32,An | 2 | 2 | 2 | 2 | | | CMP | imm8,Rn | 1 | 1 | 1 | 1 | | | CMP | imm24,Rn | 2 | 2 | 2 | 2 | | | CMP | imm32,Rn | 2 | 2 | 2 | 2 | | | AND | Dm,Dn | 1 | 1 | 1 | 1 | | | AND | Rm,Rn | 1 | 1 | 1 | 1 | | | AND | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | AND | imm8,Dn | 1 | 1 | 1 | 1 | | | AND | imm16,Dn | 1 | 1 | 1 | 1 | | | AND | imm32,Dn | 2 | 2 | 2 | 2 | | | AND | imm8,Rn | 1 | 1 | 1 | 1 | | | AND | imm24,Rn | 2 | 2 | 2 | 2 | | | AND | imm32,Rn | 2 | 2 | 2 | 2 | | | AND | imm16,PSW | 1 | 1 | 1 | 1 | | | AND | imm32,EPSW | 2 | 2 | 2 | 2 | | | OR | Dm,Dn | 1 | 1 | 1 | 1 | | | OR | Rm,Rn | 1 | 1 | 1 | 1 | | | OR<br>OR | Rm,Rn,Rd<br>imm8,Dn | 1 | 1 | 1 | 1 | | | OR | imm16,Dn | 1 | 1<br>1 | 1 1 | 1<br>1 | | | OR | imm32,Dn | 2 | 2 | 2 | 2 | | | OR | imm8,Rn | 1 | 1 | 1 | 1 | | | OR | imm24,Rn | 2 | 2 | 2 | 2 | | | OR | imm32,Rn | 2 | 2 | 2 | 2 | | | OR | imm16,PSW | 1 | 1 | 1 | 1 | | | OR | imm32,EPSW | 2 | 2 | 2 | 2 | | | XOR | Dm,Dn | 1 | 1 | 1 | 1 | | | XOR | Rm,Rn | 1 | 1 | 1 | 1 | | | XOR | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | XOR | imm16,Dn | 1 | 1 | 1 | 1 | | | XOR | imm32,Dn | 2 | 2 | 2 | 2 | | | XOR | imm8,Rn | 1 | 1 | 1 | 1 | | | ,,,,,, | | + ' | | · ' - | · | | | | | AM33 | 3-1 | AM33-2/AN | //33-2A | NOTE | |--------|--------------|------------|---------|------------|---------|------| | Assemb | ly mnemonic | Throughput | Latency | Throughput | Latency | | | XOR | imm24,Rn | 2 | 2 | 2 | 2 | | | XOR | imm32,Rn | 2 | 2 | 2 | 2 | | | NOT | Dn | 1 | 1 | 1 | 1 | | | NOT | Rn | 1 | 1 | 1 | 1 | | | BTST | imm8,Dn | 1 | 1 | 1 | 1 | | | BTST | imm16,Dn | 1 | 1 | 1 | 1 | | | BTST | imm32,Dn | 2 | 2 | 2 | 2 | | | BTST | imm8,Rn | 1 | 1 | 1 | 1 | | | BTST | imm24,Rn | 2 | 2 | 2 | 2 | | | BTST | imm32,Rn | 2 | 2 | 2 | 2 | | | BTST | imm8,(d8,An) | 4 | 4 | 4 | 4 | | | BTST | imm8,(abs16) | - | - | 4 | 4 | | | BTST | imm8,(abs32) | 5 | 5 | 5 | 5 | | | BSET | Dm,(An) | 6 | 6 | 6 | 6 | | | BSET | imm8,(d8,An) | 6 | 6 | 6 | 6 | | | BSET | imm8,(abs16) | - | - | 6 | 6 | | | BSET | imm8,(abs32) | 7 | 7 | 7 | 7 | | | BCLR | Dm,(An) | 6 | 6 | 6 | 6 | | | BCLR | imm8,(d8,An) | 6 | 6 | 6 | 6 | | | BCLR | imm8,(abs16) | - | - | 6 | 6 | | | BCLR | imm8,(abs32) | 7 | 7 | 7 | 7 | | | ASR | Dm,Dn | 1 | 1 | 1 | 1 | | | ASR | Rm,Rn | 1 | 1 | 1 | 1 | | | ASR | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | ASR | imm8,Dn | 1 | 1 | 1 | 1 | | | ASR | imm8,Rn | 1 | 1 | 1 | 1 | | | ASR | imm24,Rn | 2 | 2 | 2 | 2 | | | ASR | imm32,Rn | 2 | 2 | 2 | 2 | | | LSR | Dm,Dn | 1 | 1 | 1 | 1 | | | LSR | Rm,Rn | 1 | 1 | 1 | 1 | | | LSR | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | LSR | imm8,Dn | 1 | 1 | 1 | 1 | | | LSR | imm8,Rn | 1 | 1 | 1 | 1 | | | LSR | imm24,Rn | 2 | 2 | 2 | 2 | | | LSR | imm32,Rn | 2 | 2 | 2 | 2 | | | ASL | Dm,Dn | 1 | 1 | 1 | 1 | | | ASL | Rm,Rn | 1 | 1 | 1 | 1 | | | ASL | Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | ASL | imm8,Dn | 1 | 1 | 1 | 1 | | | ASL | imm8,Rn | 1 | 1 | 1 | 1 | | | ASL | imm24,Rn | 2 | 2 | 2 | 2 | | | ASL | imm32,Rn | 2 | 2 | 2 | 2 | | | ASL2 | Dn | 1 | 1 | 1 | 1 | | | ASL2 | Rn | 1 | 1 | 1 | 1 | | | ROR | Dn | 1 | 1 | 1 | 1 | | | | | AM33- | .1 | AM33-2/AN | //33-2A | NOTE | |----------|--------------------|------------|---------|------------|--------------|------------------------------| | Assembly | / mnemonic | Throughput | Latency | Throughput | Latency | | | ROR | Rn | 1 | 1 | 1 | 1 | | | ROL | Dn | 1 | 1 | 1 | 1 | | | ROL | Rn | 1 | 1 | 1 | 1 | | | BEQ | (d8,PC) | 3 | - | 3 | - | | | BNE | (d8,PC) | 3 | - | 3 | - | \ | | BGT | (d8,PC) | 3 | - | 3 | - | | | BGE | (d8,PC) | 3 | - | 3 | _ | | | BLE | (d8,PC) | 3 | _ | 3 | _ | | | BLT | (d8,PC) | 3 | _ | 3 | _ | Throughput is 1 if branch | | BHI | (d8,PC) | 3 | _ | 3 | _ | is not taken. | | BCC | (d8,PC) | 3 | _ | 3 | _ | | | BLS | (d8,PC) | 3 | _ | 3 | _ | | | BCS | (d8,PC) | 3 | | 3 | <u>-</u> | | | BVC | (d8,PC) | 4 | - | 4 | | | | | | | - | | - | | | BVS | (d8,PC) | 4 | - | 4 | - | Throughput is 2 if branch | | BNC | (d8,PC) | 4 | - | 4 | - | is not taken. | | BNS | (d8,PC) | 4 | - | 4 | - | lo not taken. | | BRA | (d8,PC) | 3 | - | 3 | - | ) | | LEQ | | 1 | - | 1 | - | | | LNE | | 1 | - | 1 | - | | | LGT | | 1 | - | 1 | - | | | LGE | | 1 | - | 1 | - | | | LLE | | 1 | - | 1 | - | Throughput is 2 if branch is | | LLT | | 1 | - | 1 | - | not taken. | | LHI | | 1 | - | 1 | - | | | LCC | | 1 | - | 1 | - | | | LLS | | 1 | - | 1 | - | | | LCS | | 1 | - | 1 | - | | | LRA | | 1 | - | 1 | - | J | | SETLB | | 1 | - | 1 | - | | | JMP | (An) | 3 | - | 3 | - | | | JMP | (d16,PC) | 3 | - | 3 | - | | | JMP | (d32,PC) | 4 | - | 4 | _ | | | CALL | (d16,PC),regs,imm8 | 2+REGs | _ | 2+REGs | _ | 755 | | CALL | (d32,PC),regs,imm8 | 3+REGs | _ | 3+REGs | _ | REGs=Numberofregister | | CALLS | (An) | 3 | _ | 3 | _ | | | CALLS | (d16,PC) | 4 | _ | 4 | _ | | | CALLS | (d32,PC) | 4 | _ | 4 | _ | | | RET | regs,imm8 | 5+REGs | - | 5+REGs | - | | | RETF | - | 2+REGs | - | 2+REGs | - | REGs=Numberofregister | | | regs,imm8 | | - | | - | / | | RETS | | 6 | - | 6 | - | | | RTI | | 7 | - | 7 | - | | | TRAP | | 3 | - | 3 | - | | | NOP | | 1 | - | 1 | <del>-</del> | | | SYSCALL | _ imm4 | * | * | * | * | | | | | AM33 | -1 | AM33-2/AN | 133-2A | NOTE | |----------|---------------|------------|---------|------------|---------|------| | Assembly | mnemonic | Throughput | Latency | Throughput | Latency | | | PI | | * | * | * | * | | | DMULH | Rm,Rn | 1 | 2 | 1 | 2 | | | DMULH | Rm,Rn,Rd1,Rd2 | 1 | 2 | 1 | 2 | | | DMULH | imm32,Rn | 2 | 3 | 2 | 3 | | | DMULHU | Rm,Rn | 1 | 2 | 1 | 2 | | | DMULHU | Rm,Rn,Rd1,Rd2 | 1 | 2 | 1 | 2 | | | DMULHU | imm32,Rn | 2 | 3 | 2 | 3 | | | DMACH | Rm,Rn | 1 | 2 | 1 | 2 | | | DMACH | Rm,Rn,Rd | 1 | 2 | 1 | 2 | | | DMACH | imm32,Rn | 2 | 3 | 2 | 3 | | | DMACHU | Rm,Rn | 1 | 2 | 1 | 2 | | | DMACHU | Rm,Rn,Rd | 1 | 2 | 1 | 2 | | | DMACHU | imm32,Rn | 2 | 3 | 2 | 3 | | | MAC | Rm,Rn | 2 | 3 | 2 | 3 | | | MAC | Rm,Rn,Rd1,Rd2 | 2 | 3 | 2 | 3 | | | MAC | imm8,Rn | 2 | 3 | 2 | 3 | | | MAC | imm24,Rn | 3 | 4 | 3 | 4 | | | MAC | imm32,Rn | 3 | 4 | 3 | 4 | | | MACU | Rm,Rn | 2 | 3 | 2 | 3 | | | MACU | Rm,Rn,Rd1,Rd2 | 2 | 3 | 2 | 3 | | | MACU | imm8,Rn | 2 | 3 | 2 | 3 | | | MACU | imm24,Rn | 3 | 4 | 3 | 4 | | | MACU | imm32,Rn | 3 | 4 | 3 | 4 | | | MACH | Rm,Rn | 2 | 3 | 2 | 3 | | | MACH | Rm,Rn,Rd1,Rd2 | 2 | 3 | 2 | 3 | | | MACH | imm8,Rn | 2 | 3 | 2 | 3 | | | MACH | imm24,Rn | 3 | 4 | 3 | 4 | | | MACH | imm32,Rn | 3 | 4 | 3 | 4 | | | MACHU | Rm,Rn | 2 | 3 | 2 | 3 | | | MACHU | Rm,Rn,Rd1,Rd2 | 2 | 3 | 2 | 3 | | | MACHU | imm8,Rn | 2 | 3 | 2 | 3 | | | MACHU | imm24,Rn | 3 | 4 | 3 | 4 | | | MACHU | imm32,Rn | 3 | 4 | 3 | 4 | | | MACB | Rm,Rn | 2 | 3 | 2 | 3 | | | MACB | Rm,Rn,Rd | 2 | 3 | 2 | 3 | | | MACB | imm8,Rn | 2 | 3 | 2 | 3 | | | MACB | imm24,Rn | 3 | 4 | 3 | 4 | | | MACB | imm32,Rn | 3 | 4 | 3 | 4 | | | MACBU | Rm,Rn | 2 | 3 | 2 | 3 | | | MACBU | Rm,Rn,Rd | 2 | 3 | 2 | 3 | | | MACBU | imm8,Rn | 2 | 3 | 2 | 3 | | | MACBU | imm24,Rn | 3 | 4 | 3 | 4 | | | MACBU | imm32,Rn | 3 | 4 | 3 | 4 | | | SWHW | Rm,Rn | 1 | 1 | 1 | 1 | | | SWAP | Rm,Rn | 1 | 1 | 1 | 1 | | | | AM33- | .1 | AM33-2/AN | //33-2A | NOTE | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------|------------|---------|------| | Assembly mnemonic | Throughput | Latency | Throughput | Latency | | | SWAPH Rm,Rn | 1 | 1 | 1 | 1 | | | SAT16 Rm,Rn | 1 | 1 | 1 | 1 | | | SAT24 Rm,Rn | 1 | 1 | 1 | 1 | | | MCSTE Rm,Rn | 1 | 1 | 1 | 1 | | | MCSTE imm8,Rn | 1 | 1 | 1 | 1 | | | BSCH Rm,Rn | 1 | 1 | 1 | 1 | | | BSCH Rm,Rn,Rd | 1 | 1 | 1 | 1 | | | ADD_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_SUB Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_CMP Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_LSRRm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_SUB Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_CMP Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_LSRRm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASL Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ADD imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_SUB imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_CMP imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_MOV imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASR imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_LSRimm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASLimm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ADD imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_SUB imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_CMP imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_MOV imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASR imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD LSRimm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | ADD_ASL imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_SUB Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASLRm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_SUB Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 1 | 1 | | | OWI _AON NITT, INITT, I | <u>'</u> | 1 | | ' | | | | AM33 | -1 | AM33-2/AN | 133-2A | NOTE | |---------------------------|------------|---------|------------|---------|------| | Assembly mnemonic | Throughput | Latency | Throughput | Latency | | | CMP LSR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASLRm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ADD imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_SUB imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_MOV imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASR imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_LSR imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASLimm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ADD imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_SUB imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_MOV imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASR imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_LSR imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | CMP_ASLimm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_SUBRm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_CMP Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASRRm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_SUBRm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_CMP Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASRRm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_LSR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASL Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ADD imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_SUBimm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_CMP imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_MOV imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASRimm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_LSR imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASL imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ADD imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_SUBimm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_CMP imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_MOV imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASRimm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_LSR imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SUB_ASL imm4,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_SUB Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_CMP Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | | AM33-1 | | AM33-2/AM33-2A | | NOTE | |--------------------------------------------------------|------------|----------|----------------|---------|------| | Assembly mnemonic | Throughput | Latency | Throughput | Latency | | | MOV_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_SUB Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_CMP Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_LSR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ASL Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ADD imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_SUB imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_CMP imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_MOV imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ASR imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_LSR imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ASL imm4,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | MOV_ADD imm4,Rn1,imm4,Rn2 | 2 1 | 1 | 1 | 1 | | | MOV_SUB imm4,Rn1,imm4,Rn2 | | 1 | 1 | 1 | | | MOV_CMP imm4,Rn1,imm4,Rn2 | | 1 | 1 | 1 | | | MOV_MOV imm4,Rn1,imm4,Rn2 | | 1 | 1 | 1 | | | MOV_ASR imm4,Rn1,imm4,Rn2 | | 1 | 1 | 1 | | | MOV_LSR imm4,Rn1,imm4,Rn2 | | 1 | 1 | 1 | | | MOV_ASL imm4,Rn1,imm4,Rn2 | 2 1 | 1 | 1 | 1 | | | AND_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | AND_SUB Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | AND_CMP Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | AND_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | AND_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | AND_LSRRm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | AND_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | AND_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | AND_SUB Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | AND_CMP Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | AND_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | AND_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | AND_ASI_Bm1_Rn1.imm4_Rn2 | 1 | T<br>4 | 1 | 1 | | | AND_ASL Rm1,Rn1,imm4,Rn2 | | 1 | | 1 | | | OR_ADD Rm1,Rn1,Rm2,Rn2 | | 1 | | 1<br>4 | | | OR_SUB_Rm1,Rn1,Rm2,Rn2 | 1 | 1 | | 1 | | | OR_CMP Rm1,Rn1,Rm2,Rn2 OR_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | OR_MOV RITT,RITT,RIT2,RIT2 OR_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | ' | 1 | | | OR_ASR RIIIT,RIIT,RIII2,RII2<br>OR_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | '1 | 1 | | | UK_LOK KIIII,KIII,KIIIZ,KIIZ | 1 | <u> </u> | | | 1 | | | AM33 | -1 | AM33-2/AN | //33-2A | NOTE | |----------------------------|------------|---------|------------|---------|------------------------------| | Assembly mnemonic | Throughput | Latency | Throughput | Latency | | | OR_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | OR_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | OR_SUB Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | OR_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | OR_CMP Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | OR_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | OR_LSR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | OR_ASL Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | XOR_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | XOR_SUB Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | XOR_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | XOR_CMP Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | XOR_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | XOR_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | XOR_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | XOR_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | XOR_SUB Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | XOR_CMP Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | XOR_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | XOR_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | XOR_LSR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | XOR_ASL Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | DMACH_ADDRm1,Rn1,Rm2,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_SUBRm1,Rn1,Rm2,Rn2 | 1 | 2 | 1 | 2 | ) | | DMACH_CMPRm1,Rn1,Rm2,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_MOVRm1,Rn1,Rm2,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 2 | 1 | 2 | Rm is valid at Latency of 2. | | DMACH_ADDRm1,Rn1,imm4,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_SUBRm1,Rn1,imm4,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_CMPRm1,Rn1,imm4,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_MOVRm1,Rn1,imm4,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_ASRRm1,Rn1,imm4,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_LSR Rm1,Rn1,imm4,Rn2 | 1 | 2 | 1 | 2 | | | DMACH_ASL Rm1,Rn1,imm4,Rn2 | 1 | 2 | 1 | 2 | | | SWHW_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | J | | SWHW_SUB Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_CMP Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_SUBRm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 11 | | | | AM33- | 1 | AM33-2/AN | //33-2A | NOTE | |----------------------------|------------|---------|------------|---------|-----------------------------------------| | Assembly mnemonic | Throughput | Latency | Throughput | Latency | | | SWHW_CMPRm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_LSR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SWHW_ASL Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_ADD Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_SUB Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_CMP Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_MOV Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_ASR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_LSR Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_ASL Rm1,Rn1,Rm2,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_ADD Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_SUB Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_CMP Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_MOV Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_ASR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_LSR Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | SAT16_ASL Rm1,Rn1,imm4,Rn2 | 1 | 1 | 1 | 1 | | | MOV_LEQ (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | MOV_LNE (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | MOV_LGT (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | MOV_LGE (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | MOV_LLE(Rm+,imm4),Rn | 1 | 3 | 1 | 3 | Rm is valid at Latency of 1. | | MOV_LLT (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | MOV_LHI (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | MOV_LCC (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | Throughput is 2 if branch is not taken. | | MOV_LLS(Rm+,imm4),Rn | 1 | 3 | 1 | 3 | I IIIOL LAKEII. | | MOV_LCS (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | MOV_LRA (Rm+,imm4),Rn | 1 | 3 | 1 | 3 | | | UDF00 Dm,Dn | 2 | 3 | 2 | 3 | / | | UDF00 imm8,Dn | 2 | 3 | 2 | 3 | | | UDF00 imm16,Dn | 2 | 3 | 2 | 3 | | | UDF00 imm32,Dn | 3 | 4 | 3 | 4 | | | UDF01 Dm,Dn | 2 | 3 | 2 | 3 | | | UDFU01 imm8,Dn | 2 | 3 | 2 | 3 | | | UDFU01 imm16,Dn | 2 | 3 | 2 | 3 | | | UDFU01 imm32,Dn | 3 | 4 | 3 | 4 | | | UDF02 Dm,Dn | 1 | 1 | 1 | 1 | | | UDF03 Dm,Dn | 1 | 1 | 1 | 1 | | | UDF04 Dm,Dn | 1 | 1 | 1 | 1 | | | UDF05 Dm,Dn | 1 | 1 | 1 | 1 | | | UDF06 Dm,Dn | 1 | 1 | 1 | 1 | | | UDF07 Dm,Dn | 1 | 1 | 1 | 1 | | | UDF08 Dm,Dn | 1 | 1 | 1 | 1 | | | | | AM33 | -1 | AM33-2/AN | 133-2A | NOTE | |---------|------------------------------------|------------|---------|------------|---------|------| | Assembl | y mnemonic | Throughput | Latency | Throughput | Latency | | | UDF09 | Dm,Dn | 1 | 4 | 1 | 1 | | | UDF12 | Dm,Dn | 1 | 4 | 1 | 1 | | | UDF13 | Dm,Dn | 1 | 1 | 1 | 1 | | | UDF15 | Dm,Dn | 1 | 1 | 1 | 1 | | | FMOV | (Rm),FSn | - | - | 1 | 4 | | | FMOV | (Ri,Rm),FSn | - | - | 1 | 4 | | | FMOV | (d8,Rm),FSn | - | - | 1 | 4 | | | FMOV | (d24,Rm),FSn | - | - | 2 | 5 | | | FMOV | (d32,Rm),FSn | - | - | 2 | 5 | | | FMOV | (d8,SP),FSn | - | - | 1 | 4 | | | FMOV | (d24,SP),FSn | - | - | 2 | 5 | | | FMOV | (d32,SP),FSn | - | - | 2 | 5 | | | FMOV | FSm,(Rn) | - | - | 1 | - | | | FMOV | FSm,(Ri,Rn) | - | - | 1 | - | | | FMOV | FSm,(d8,Rn) | - | - | 1 | _ | | | FMOV | FSm,(d24,Rn) | - | - | 2 | - | | | FMOV | FSm,(d32,Rn) | - | - | 2 | _ | | | FMOV | FSm,(d8,SP) | - | - | 1 | - | | | FMOV | FSm,(d24,SP) | - | - | 2 | _ | | | FMOV | FSm,(d32,SP) | - | _ | 2 | - | | | FMOV | (Rm+),FSn | - | _ | 1 | 4 | | | FMOV | (Rm+,imm8),FSn | - | _ | 1 | 4 | | | FMOV | (Rm+,imm24),FSn | _ | _ | 2 | 5 | | | FMOV | (Rm+,imm32),FSn | - | _ | 2 | 5 | | | FMOV | FSm,(Rn+) | _ | - | 1 | _ | | | FMOV | FSm,(Rn+,imm8) | _ | - | 1 | _ | | | FMOV | FSm,(Rn+,imm24) | _ | - | 2 | _ | | | FMOV | FSm,(Rn+,imm32) | _ | _ | 2 | 5 | | | FMOV | FSm,FSn | - | - | 1 | 4 | | | FMOV | FSm,Rn | _ | _ | 1 | 2 | | | FMOV | Rm,FSn | _ | _ | 1 | 4 | | | FMOV | imm32,FSn | _ | _ | 2 | 5 | | | FMOV | FPCR,Rn | _ | _ | 1 | 2 | | | FMOV | Rm,FPCR | - | _ | 1 | 4 | | | FMOV | imm32,FPCR | _ | _ | 2 | 5 | | | FMOV | (SP),FSn | _ | _ | 1 | 4 | | | FMOV | FSm,(SP) | _ | _ | 1 | - | | | FABS | FSn | _ | _ | 1 | 4 | | | FABS | FSm,FSn | _ | - | 1 | 4 | | | FNEG | FSn | _ | _ | 1 | 4 | | | FNEG | FSm,FSn | _ | _ | 1 | 4 | | | FRSQRT | | _ | _ | 23 | 27 | | | | ut operand is 0,¥,NaN or negative. | _ | _ | 17 | 21 | | | | FSm,FSn | _ | _ | 23 | 27 | | | | ut operand is 0,¥,NaN or negative. | _ | _ | 17 | 21 | | #### **MN103E SERIES THROUGHPUT & LATENCY** | | | AM33 | -1 | AM33-2/AN | //33-2A | NOTE | |------------|-----------------------------------|------------|---------|------------|---------|------| | Assembly | mnemonic | Throughput | Latency | Throughput | Latency | | | FCMP | FSm1,FSm2 | - | - | 1 | 4 | | | FCMP | imm32,FSm | - | - | 2 | 5 | | | FADD | FSm,FSn | - | - | 1 | 4 | | | FADD | FSm1,FSm2,FSn | - | - | 1 | 4 | | | FADD | imm32,FSm,FSn | - | - | 2 | 5 | | | FSUB | FSm,FSn | - | - | 1 | 4 | | | FSUB | FSm1,FSm2,FSn | - | - | 1 | 4 | | | FSUB | imm32,FSm,FSn | - | - | 2 | 5 | | | FMUL | FSm,FSn | - | - | 1 | 4 | | | FMUL | FSm1,FSm2,FSn | - | - | 1 | 4 | | | FMUL | imm32,FSm,FSn | - | - | 2 | 5 | | | FDIV | FSm,FSn | - | _ | 12 | 16 | | | When input | operand is 0,¥,NaN or negative. | - | _ | 9 | 13 | | | · | | | | | | | | FDIV | FSm1,FSm2,FSn | - | _ | 12 | 16 | | | When input | t operand is 0,¥,NaN or negative. | - | - | 9 | 13 | | | | | | | | | | | FDIV | imm32,FSm,FSn | - | - | 13 | 17 | | | When input | t operand is 0,¥,NaN or negative. | - | - | 10 | 14 | | | | | | | | | | | FMADD | FSm1,FSm2,FSm3,FSn | - | - | 1 | 4 | | | FMSUB | FSm1,FSm2,FSm3,FSn | - | - | 1 | 4 | | | FNMADD | FSm1,FSm2,FSm3,FSn | - | - | 1 | 4 | | | FNMSUB | FSm1,FSm2,FSm3,FSn | - | - | 1 | 4 | | | FMOV | (Rm),FDn | - | - | 1 | 4 | | | FMOV | (Ri,Rm),FDn | - | - | 1 | 4 | | | FMOV | (d8,Rm),FDn | - | - | 1 | 4 | | | FMOV | (d24,Rm),FDn | - | - | 2 | 5 | | | FMOV | (d32,Rm),FDn | - | - | 2 | 5 | | | FMOV | (SP),FDn | - | - | 1 | 4 | | | FMOV | (d8,SP),FDn | - | - | 1 | 4 | | | FMOV | (d24,SP),FDn | - | - | 2 | 5 | | | FMOV | (d32,SP),FDn | - | - | 2 | 5 | | | FMOV | FDm,(Rn) | - | - | 1 | - | | | FMOV | FDm,(Ri,Rn) | - | - | 1 | - | | | FMOV | FDm,(d8,Rn) | - | - | 1 | - | | | FMOV | FDm,(d24,Rn) | - | - | 2 | - | | | FMOV | FDm,(d32,Rn) | - | - | 2 | - | | | FMOV | FDm,(SP) | - | - | 1 | - | | | FMOV | FDm,(d8,SP) | - | - | 1 | - | | | FMOV | FDm,(d24,SP) | - | - | 2 | - | | | FMOV | FDm,(d32,SP) | | | 2 | - | | | FMOV | (Rm+),FDn | | | 1 | 4 | | | FMOV | (Rm+,imm8),FDn | | | 1 | 4 | | #### **MN103E SERIES THROUGHPUT & LATENCY** | | | AM33 | -1 | AM33-2/AN | //33-2A | NOTE | |----------|-----------------|------------|---------|------------|---------|------------------------------| | Assembly | y mnemonic | Throughput | Latency | Throughput | Latency | | | FMOV | (Rm+,imm24),FDn | | | 2 | 5 | | | FMOV | (Rm+,imm32),FDn | | | 2 | 5 | | | FMOV | FDm,(Rn+) | | | 1 | - | | | FMOV | FDm,(Rn+,imm8) | | | 1 | - | | | FMOV | FDm,(Rn+,imm24) | | | 2 | - | | | FMOV | FDm,(Rn+,imm32) | | | 2 | - | | | FBEQ | (d8,PC) | | | 3 | - | | | FBNE | (d8,PC) | | | 3 | - | | | FBGT | (d8,PC) | | | 3 | - | | | FBGE | (d8,PC) | | | 3 | - | | | FBLT | (d8,PC) | | | 3 | - | | | FBLE | (d8,PC) | | | 3 | - | | | FBUO | (d8,PC) | | | 3 | - | | | FBLG | (d8,PC) | | | 3 | - | | | FBLEG | (d8,PC) | | | 3 | - | When Throughput is 1,the | | FBUG | (d8,PC) | | | 3 | - | divergence is failure. | | FBUGE | (d8,PC) | | | 3 | - | | | FBUL | (d8,PC) | | | 3 | - | | | FBULE | (d8,PC) | | | 3 | - | | | FBUE | (d8,PC) | | | 3 | _ | | | FLEQ | (, | | | 1 | - | | | FLNE | | | | 1 | - | | | FLGT | | | | 1 | - | IJ. | | FLGE | | | | 1 | - | | | FLLT | | | | 1 | - | | | FLLE | | | | 1 | - | | | FLUO | | | | 1 | - | | | FLLG | | | | 1 | - | | | FLLEG | | | | 1 | - | | | FLUG | | | | 1 | - | Throughput is 2 if branch is | | FLUGE | | | | 1 | - | not taken. | | FLUL | | | | 1 | - | | | FLULE | | | | 1 | - | | | FLUE | | | | 1 | - | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Machine Code | | 1001 AmAn | 1000 DmDn | 1111 0001 1101 AmDn | 1111 0001 1110 DmAn | 1111 0101 00Am Rn | 1111 0101 10RmAn | 1111 0101 01Dm Rn | 1111 0101 11RmDn | 1111 1001 0000 1000 Rm Rn | 1001 AnAn imm8 | 3 0010 01An imm16 | 6 1111 1100 110111An imm32 | 1000 DnDnimm8 | 0010 11Dn imm16 | 1111 1100 1100 11Dn imm32 | 1111 1011 0000 1000 Rn imm8 | 1111 1101 0000 1000 Rn imm24 | 1111 1110 0000 1000 Rn imm32 | 1111 0010 1110 00Dn | 1111 0010 1111 Dm10 | 0011 11An | 1111 1001 1110 1000 0000 Rn | 1111 0010 1111 Am00 | 0000 | | 1101 1111 1000 0000 | 1110 1111 1000 | 1110 1000 | Rm. | 1000 | | 1111 1110 1111 1000 0001 imm32 | 1111 1001 1110 1000 0010 Rn | 1000 Rm | 1111 1011 1111 1000 0010 imm8 | |--------------|-----|-----------|-----------|---------------------|---------------------|-------------------|------------------|-------------------|------------------|---------------------------|--------------------|---------------------|------------------------------|-------------------|--------------------|---------------------------|-----------------------------|------------------------------|------------------------------|---------------------|---------------------|--------------|-----------------------------|---------------------|--------|--------------------|---------------------|----------------|-----------|-----------|----------------------|-----------------------|--------------------------------|-----------------------------|-----------------------|-----------------------------------| | Code | 200 | - | _ | | 2 1 | 2 1 | 2 | 2 1 | | | 2 | 3 0 | 6 1 | 2 | 3 0 | 6 1 | | | | | 2 1 | <del>_</del> | | | | | 9 | | | 3 1 | 4 | 9 | 7 1 | 3 | - | 4 | | ZF | | 1 | ı | ı | - | - | | - | - | - | - | - | ı | - | - | - | ı | ı | - | - | 1 | ı | ı | 1 | - | 1 | ı | 1 | Δ | - | | 1 | - | | 1 | 1 | | Hag<br>는 | - | ' | ' | ' | - - | - | ' | - | | | - | | 1 | - | 1 | | 1 | 1 | | 1 | 1 | ' | 1 | 1 | - | 1 | ' | ' | 0 | | 1 | 1 | - | 1 | | 1 | | VF/ | | ı | , | , | - | , | , | - | - | - | , | - | ı | , | ı | - | ı | ı | - | , | , | , | ı | ı | - | ı | 1 | 1 | 0 | ı | | , | ı | | | , | | Operation | | Am->An | Dm->Dn | Am->Dn | Dm->An | Am->Rn | Rm->An | Dm->Rn | Rm->Dn | Rm->Rn | (zero_ext)imm8->An | (zero_ext)imm16->An | imm32->An | sign_ext)imm8->Dn | sign_ext)imm16->Dn | imm32->Dn | sign_ext)imm8->Rn | sign_ext)imm24->Rn | imm32->Rn | MDR->Dn | Dm->MDR | SP->An | SP->Rn | Am->SP | Rm->SP | (zero_ext)imm8->SP | (zero_ext)imm24->SP | imm32->SP | MDRQ->Rn | Rm->MDRQ | (zero_ext)imm8->MDRQ | (zero_ext)imm24->MDRQ | imm32->MDRQ | MCRH->Rn,MCVF->EPSW.V | Rm->MCRH,EPSW.V->MCVF | (zero_ext)imm8->MCRH,EPSW.V->MCVF | | Mnemonic | | V Am,An | V Dm,Dn | V Am,Dn | V Dm,An | V Am,Rn | V Rm,An | | | V Rm,Rn | V imm8,An | V imm16,An | V imm32,An | V imm8,Dn | V imm16,Dn | V imm32,Dn | | V imm24,Rn | V imm32,Rn | V MDR,Dn | V Dm,MDR | V SP,An | | V Am,SP | | V imm8,SP | | V imm32,SP | | V Rm,MDRQ | V imm8,MDRQ | V imm24,MDRQ | V imm32,MDRQ | V MCRH,Rn | | MOV imm8,MCRH | | | | MOV | M0V | M0V | MOV M0\ | MOV | MOV | MOV | MOV | MOV | M<br>0<br>M | MOV <u>}</u> | | Group | 1 | _ | | _ | _ | | _ | | _ | | _ | | | | | | _ | | | | _ | | | | | | _ | | | | | | | | | | | e Code | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |------------------------|------------------------------------|-------------------------------|-------------------------------|-----------------------------------|------------------------------------|------------------------------------|----------------------------------|-------------------------------|---------------------------------|----------------------------------|----------------------------------|-----------------------|---------------|-----------------------|--------------------------|----------------------------|-----------------------------|---------------------------|----------------------------|-----------------------------|---------------------------|----------------------------------|---------------------------------|---------------------------------|------------------|-------------------------|--------------------------------|----------------------------|------------------|----------------------------|-----------------------------|---------------------------|--------------------------------|------------------|----------------------------| | Code Machine Code Size | 7 1111 1110 1111 1000 0010 imm32 | 3 1111 1001 1110 1000 0011 Rn | 3 1111 1001 1111 1000 Rm 0011 | 4 1111 1011 1111 1000 0011 imm8 | 6 1111 1101 1111 1000 0011 imm24 | 7 1111 1110 1111 1000 0011 imm32 | 3 1111 1001 1110 1000 0100 Rn | 3 1111 1001 1111 1000 Rm 0100 | 4 1111 1011 1111 1000 0100 imm8 | 6 1111 1101 1111 1000 0100 imm24 | 7 1111 1110 1111 1000 0100 imm32 | 2 1111 0000 0010 11An | 1 0111 DnAm | 2 1111 0000 0000 AnAm | 3 1111 1001 0000 1010 Rn | 3 1111 1000 0000 DnAm d8 | 4 1111 1010 0000 DnAm d16 | 6 1111 1100 0000 DnAm d32 | 3 1111 1000 0010 AnAm d8 | 4 1111 1010 0010 AnAm d16 | 6 1111 1100 0010 AnAm d32 | 4 1111 1011 0000 1010 Rn Rm d8 | 6 1111 1101 0000 1010 Rn Rm d24 | 7 1111 1110 0000 1010 Rn Rm d32 | | 2 1111 0011 10An DiAm | 4 1111 1011 1000 1110 Ri Rm Rn | 3 0011 00Dn abs16 | | | 6 1111 1100 1010 00An abs32 | | 6 1111 1101 0000 1110 Rn abs24 | | 2 0101 10Dn d8 | | Flag Code | 1 | | | | | 1 | 1 | 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | | 1 1 | 1 1 | 1 1 | 1 1 | 1 | 1 1 | 1 1 | 1 1 | 1 1 | 1 1 | | Operation | imm32->MCRH,EPSW.V->MCVF | MCRL->Rn,MCVF->EPSW.V | Rm->MCRL,EPSW.V->MCVF | (zero_ext)imm8->MCRL,EPSW.V->MCVF | (zero_ext)imm24->MCRL,EPSW.V->MCVF | imm32->MCRL,EPSW.V->MCVF | MCVF->Rn[0],0x00000000->Rn[31:1] | Rm[0]->MCVF | imm8[0]->MCVF | imm24[0]->MCVF | imm32[0]->MCVF | PC->An | mem32(Am)->Dn | mem32(Am)->An | mem32(Rm)->Rn | mem32(Am+(sign_ext)d8)->Dn | mem32(Am+(sign_ext)d16)->Dn | mem32(Am+d32)->Dn | mem32(Am+(sign_ext)d8)->An | mem32(Am+(sign_ext)d16)->An | mem32(Am+d32)->An | mem32(Rm+(sign_ext)d8)->Rn | mem32(Rm+(sign_ext)d24)->Rn | mem32(Rm+d32)->Rn | mem32(Di+Am)->Dn | mem32(Di+Am)->An | mem32(Ri+Rm)->Rn | mem32((zero_ext)abs16)->Dn | mem32(abs32)->Dn | mem32((zero_ext)abs16)->An | mem32(abs32)->An | mem32((zero_ext)abs8)->Rn | mem32((zero_ext)abs24)->Rn | mem32(abs32)->Rn | mem32(SP+(zero_ext)d8)->Dn | | Mnemonic | MOV imm32,MCRH | MOV MCRL,Rn | MOV Rm,MCRL | MOV imm8,MCRL | MOV imm24,MCRL | MOV imm32,MCRL | MOV MCVF,Rn | MOV Rm,MCVF | MOV imm8,MCVF | MOV imm24,MCVF | MOV imm32,MCVF | MOV PC,An | MOV (Am), Dn | MOV (Am),An | MOV (Rm),Rn | MOV (d8,Am),Dn | MOV (d16,Am),Dn | MOV (d32,Am)Dn | MOV (d8,Am),An | MOV (d16,Am),An | MOV (d32,Am)An | MOV (d8,Rm),Rn | MOV (d24,Rm),Rn | MOV (d32,Rm),Rn | MOV (Di,Am),Dn | MOV (Di,Am),An | MOV (Ri,Rm),Rn | MOV (abs16),Dn | MOV (abs32),Dn | MOV (abs16),An | MOV (abs32),An | MOV (abs8),Rn | MOV (abs24),Rn | | MOV (d8,SP),Dn | | Group | MOV | | 2 | 2 | 2 | 2 | | | | 2 | 2 | | 2 | | | | | | | | | | | 2 | 2 | 2 | 2 | | 2 | 2 | | | 2 | 2 | 2 | | Group | Mnemonic | Operation | į | | j<br>L | Wachine Code | |---------|-------------|----------------------------------------|------|---------------|--------|-----------------------------------| | | | | ΛΗ̈́ | VFCFNFZF Size | ZFS | ize | | MOV MOV | (d16.SP) Dn | mem32/SP+(zero ext)d16)->Dn | - | - | | 4 1111 1010 1011 01Dn d16 | | NO N | 1 | | | | | 6 1111 1100 1011 01Dn d32 | | MOV | 1 | mem32(SP+(zero ext)d8)->An | | 1 | 1 | 2 010111And8 | | MOV | (d16,SP),An | mem32(SP+(zero_ext)d16)->An | | | | 4 1111 1010 1011 00An d16 | | MOV | (d32,SP),An | | ı | 1 | | 6 1111 1100 1011 00An d32 | | MOV | (SP),Rn | mem32(SP)->Rn | | 1 | | 3 1111 1001 1000 1010 Rn | | MOV | | mem32(SP+(zero_ext)d8)->Rn | 1 | - | - | | | MOV | | mem32(SP+(zero_ext)d24)->Rn | ı | | | 6 1111 1101 1000 1010 Rn d24 | | MOV | (d32,SP),Rn | mem32(SP+d32)->Rn | ı | 1 | | 7 1111 1110 1000 1010 Rn d32 | | MOV | (d8,Am),SP | mem32(Am+(sign_ext)d8) | ı | 1 | - | 3 1111 1000 1111 00Am d8 | | MOV | Dm,(An) | Dm->mem32(An) | ı | - | - | 1 0110 DmAn | | MOV | Am,(An) | Am->mem32(An) | ı | - | - | 2 1111 0000 0001 AmAn | | MOV | Rm,(Rn) | Rm->mem32(Rn) | ı | 1 | - | | | MOV | Dm,(d8,An) | Dm->mem32(An+(sign_ext)d8) | ı | | - | 3 1111 1000 0001 DmAn d8 | | MOV | Dm,(d16,An) | Dm->mem32(An+(sign_ext)d16) | ı | - | - | | | MOV | Dm,(d32,An) | Dm->mem32(An+d32) | ı | - | - | | | MOV | Am,(d8,An) | Am->mem32(An+(sign_ext)d8) | ı | 1 | 1 | 3 1111 1000 0011 AmAn d8•c | | MOV | Am,(d16,An) | Am->mem32(An+(sign_ext)d16) | ı | 1 | | 4 1111 1010 0011 AmAn d16 | | MOV | | Am->mem32(An+d32) | 1 | 1 | | | | MOV | Rm,(d8,Rn) | Rm->mem32(Rn+(sign_ext)d8) | 1 | 1 | | | | MOV | Rm,(d24,Rn) | Rm->mem32(Rn+(sign_ext)d24) | ı | 1 | | 6 1111 1101 0001 1010 Rm Rn d24 | | MOV | Rm,(d32,Rn) | Rm->mem32(Rn+d32) | | - | - | 7 1111 1110 0001 1010 Rm Rn d32 | | MOV | Dm,(Di,An) | Dm->mem32(Di+An) | - | | - | 2 1111 0011 01Dm DiAn | | MOV | Am,(Di,An) | Am->mem32(Di+An) | 1 | 1 | | | | MOV | Rm,(Ri,Rn) | Rm->mem32(Ri+Rn) | - | | - | 4 1111 1011 1001 1110 Ri Rn Rm | | MOV | Dm,(abs16) | Dm->mem32((zero_ext)abs16) | 1 | - | - | 3 0000 Dm01 abs16 | | MOV | Dm,(abs32) | Dm->mem32(abs32) | 1 | - | - | | | MOV | Am,(abs16) | Am->mem32((zero_ext)abs16) | 1 | | | 4 1111 1010 1000 Am00 abs16 | | MOV | Am,(abs32) | Am->mem32(abs32) | - | | - | 6 1111 1100 1000 Am00 abs32 | | MOV | Rm,(abs8) | Rm->mem32((zero_ext)abs8) | - | - | • | 4 1111 1011 0001 1110 Rm abs8 | | MOV | Rm,(abs24) | Rm->mem32((zero_ext)abs24) | ı | | | 6 1111 1101 0001 1110 Rm abs24 | | MOV | Rm,(abs32) | Rm->mem32(abs32) | ı | 1 | | | | MOV | Dm,(d8,SP) | Dm->mem32(SP+(zero_ext)d8) | 1 | 1 | | | | MOV | Dm,(d16,SP) | Dm->mem32(SP+(zero_ext)d16) | 1 | | | 4 1111 1010 1001 Dm01 d16 | | MOV | Dm,(d32,SP) | Dm->mem32(SP+d32) | | 1 | | 6 1111 1100 1001 Dm01 d32 | | | (00 00) 22 | \0\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | | | | 2 0400 Am11 d8 | | qe | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |--------------|-----------------------------|-------------------------|------------------------|----------------------------|----------------------------|----------------------------|----------------------------|---------------------------------------|----------------------------------------|---------------------------------|---------------------------|---------------------------------------|----------------------------------------|-----------------------------------|---------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|-----------------------|---------------------|---------------------|-------------------------------|------------------------------|------------------------------|---------------------------------------|---------------------------------------|----------------------------------------------------------|-----------------------------------------------------------|----------------------------| | Machine Code | 4 1111 1010 1001 Am00 d16 | 1111 1100 1001 Am00 d32 | 1111 1001 1001 1010 Rm | 1111 1011 1001 1010 Rm d8 | 1111 1101 1001 1010 Rm d24 | 1111 1110 1001 1010 Rm d32 | 1111 1000 1111 01An d8 | 1111 1011 0110 1010 Rn Rm imm8 | 1111 1101 0110 1010 Rn Rm imm24 | 1111 1110 0110 1010 Rn Rm imm32 | 1111 1001 0110 1010 Rn Rm | 1111 1011 0111 1010 Rm Rn imm8 | 1111 1101 0111 1010 Rm Rn imm24 | 7 1111 1110 0111 1010 Rm Rn imm32 | 1111 1001 0111 1010 Rm Rn | 1111 0000 0010 10An | 1111 0000 0011 Am10 | 1111 0000 0010 01An | 1111 0000 0011 Am01 | 1111 0000 0010 00An | 1111 0000 0011 Am00 | 1111 0010 1110 11Dn | 2 1111 0010 1111 Dm01 | 1111 0010 1110 01Dn | 1111 0010 1111 Dm11 | 3 1111 1011 0001 1000 Rn imm8 | 1111 1101 0001 1000 Rn imm24 | 1111 1110 0001 1000 Rn imm32 | 1111 0000 0110 DnAm | 1111 1001 0100 1010 Rn Rm | 1111 1000 0110 DnAm d8 | 1111 1010 0110 DnAm d16 | 1111 1100 0110 DnAm d32 | | Flag Code | | 9 | | 4 | | . 2 - - - | 3 | - - - | | | . E | 4 | 9 | | | 2 | | 2 | | 2 | | 2 | 2 | 2 | 2 | | 9 - | | | | r<br>-<br>- | - 4 | 9 | | Operation | Am->mem32(SP+(zero ext)d16) | | Rm->mem32(SP) | Rm->mem32(SP+(zero ext)d8) | | | SP->mem32(An+(sign_ext)d8) | mem32(Rm)->Rn,Rm+(sign_ext)imm8->Rm - | mem32(Rm)->Rn,Rm+(sign_ext)imm24->Rm - | mem32(Rm)->Rn,Rm+imm32->Rm | mem32(Rm)->Rn,Rm+4->Rm | Rm->mem32(Rn),Rn+(sign_ext)imm8->Rn - | Rm->mem32(Rn),Rn+(sign_ext)imm24->Rn - | Rm->mem32(Rn),Rn+imm32->Rn - | Rm->mem32(Rn),Rn+4->Rn | MSP->An | - Am->MSP | SSP->An | - Am->SSP | USP->An | - Am->USP | EPSW->Dn | - Dm->EPSW | PSW->Dn | - Dm->PSW | (zero_ext)imm8->Rn | (zero_ext)imm24->Rn | imm32->Rn | mem16(Am)->Dn[15:0],0x0000->Dn[31:16] | mem16(Rm)->Rn[15:0],0x0000->Rn[31:16] | mem16(Am+(sign_ext)d8)->Dn[15:0], -<br>0x0000->Dn[31:16] | mem16(Am+(sign_ext)d16)->Dn[15:0], -<br>0x0000->Dn[31:16] | mem16(Am+d32)->Dn[15:0], - | | Mnemonic | MOV Am,(d16,SP) | MOV Am,(d32,SP) | MOV Rm,(SP) | MOV Rm,(d8,SP) | MOV Rm,(d24,SP) | MOV Rm,(d32,SP) | MOV SP,(d8,An) | MOV (Rm+,imm8),Rn | MOV (Rm+,imm24),Rn | MOV (Rm+,imm32),Rn | MOV (Rm+),Rn | MOV Rm,(Rn+,imm8) | MOV Rm, (Rn+, imm24) | MOV Rm, (Rn+, imm32) | MOV Rm,(Rn+) | MOV MSP,An | MOV Am,MSp | MOV SSP,An | MOV Am,SSP | MOV USP,An | MOV Am,USP | MOV EPSW,Dn | | MOV PSW,Dn | MOV Dm,PSW | MOVU MOVU imm8,Rn | MOVU imm24,Rn | MOVU imm32,Rn | l | MOVHU (Rm),Rn | MOVHU (d8,Am),Dn | MOVHU (d16,Am),Dn | MOVHU (d32,Am),Dn | | Group | MOV | | | | · | | | | · | | | · | | | | · | | | | 1 | | | | ' | | MOVU | - | | MOVHU | | | | | | Mem16(Rm+(sign_ext)d8)->Rn[15:0], - - - | | | | E C | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------|---------------------------------------------------------|----------|--------------------------------| | Rn mem16(Rm+(sign_ext)d8)->Rn[15:0], 4 0x00000->Rn[31:16] 7 0x00000->Rn[31:16] 7 0x00000->Rn[31:16] 7 0x00000->Rn[31:16] 2 0x00000->Rn[31:16] 2 0x00000->Rn[31:16] 2 0x0000->Rn[31:16] 3 0x0000->Rn[31:16] | irouk | | Operation | VFCFNFZF | | | mem16(Rm+(sign_ext)d8)->Rn[15:0], - 4 mem16(Rm+(sign_ext)d8)->Rn[15:0], - - mem16(Rm+(sign_ext)d16)->Rn[15:0], - - 0x0000->Rn[31:16] - - - 0x0000->Rn[31:16] - - - 0x0000->Rn[31:16] - - - 0x0000->Rn[31:16] - - - 0x0000->Rn[31:16] - - - - 0x0000->Rn[31:16] - - - mem16(Ren - ext)abs 16)->Dn[15:0], - - - - 0x0000->Rn[31:16] - 0x0000-Rn[31:16] - - - - - 0x0000-Rn[31:16] - - - - - 0x0000-Rn[31:16] - - - - - 0x0000-Rn[31:16] - - - - - 0x0000-Rn[31:16] - - - - - 0x0000-Rn[31:16] - - - - 0x0000-Rn[31:16] - - 0x0000-Rn[31:16] - - - - - - 0x0000-Rn[31:16] - - - - - - 0x0000-Rn[31:16] - - - - - - - 0x0000-Rn[31:16] - - - - - - - 0x0000-Rn[31:16] - - - - - - - 0x0000-Rn[31:16] - - - - - - - 0x0000-Rn[31:16] - - - - - - - - 0x0000-Rn[31:16] - - - - - - - - - | | | | | | | N. Namen 16(Rm+(sign_ext)d16)->Rn[15:0], - - - - | MOVHL | MOVHU (d8,Rm),Rn | mem16(Rm+(sign_ext)d8)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | 4 1111 1011 0100 1010 Rn Rm d8 | | Dn mem16(Rm+d32)-FRI[15:0], Coordo-SRI[31:16] Coordo-SRI[31: | | MOVHU (d24,Rm),Rn | mem16(Rm+(sign_ext)d16)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | | | Dn mem16(Di+Am)+>Dn[15:0], accorded by the control of t | | MOVHU (d32,Rm),Rn | mem16(Rm+d32)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | | | Rn mem16(Ri+Rm)->Rn[15:0], | | MOVHU (Di,Am),Dn | mem16(Di+Am)->Dn[15:0],<br>0x0000->Dn[31:16] | 1 | | | Dn mem16((zero_ext)abs16)->Dn[15:0], ox0000->Dn[31:16] 3 001110Dn abs16 Dn mem16(abs32)->Dn[15:0], ox0000->Rn[31:16] 6 11111100 1010 1110 Rn In mem16(zero_ext)abs24)->Rn[15:0], ox0000->Rn[31:16] 6 11111101 0100 1110 Rn Rn mem16(zero_ext)abs24)->Rn[15:0], ox0000->Rn[31:16] 7 11111100 100 1110 Rn Rn mem16(zero_ext)abs24)->Rn[15:0], ox0000->Rn[31:16] 7 11111100 100 1110 Rn Dn mem16(zero_ext)abs24)->Rn[15:0], ox0000->Rn[31:16] 7 11111100 100 1110 Rn Dn mem16(zP+(zero_ext)d8)->Dn[15:0], ox0000->Dn[31:16] 7 11111100 101111Dn d8 Dn mem16(zP+(zero_ext)d8)->Dn[15:0], ox0000->Dn[31:16] 3 1111100 101111Dn d10111Dn d8 Dx0000->Dn[31:16] 3 1111100 101111Dn d10111Dn d1010 Rn Dx0000->Rn[31:16] | | MOVHU (Ri,Rm),Rn | mem16(Ri+Rm)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | | | Dn mem16(abs32)->Dn[15:0], 6 1111 1100 1010 11Dn abs32 | | MOVHU (abs16),Dn | _ | 1 | 3 0011 10Dn abs16 | | mem16((Zero_ext)abs8)->Rn[15:0], | | MOVHU (abs32),Dn | mem16(abs32)->Dn[15:0],<br>0x0000->Dn[31:16] | 1 | | | Rn mem16((zero_ext)abs24)->Rn[15:0], 6 11111101010101110 Rn 0x0000->Rn[31:16] Rn mem16(abs32)->Rn[15:0], 7 11111110 0100 1110 Rn 0x0000->Rn[31:16] mem16(SP+(zero_ext)d8)->Dn[15:0], 7 11111100 101111Dn d8 Dn mem16(SP+(zero_ext)d16)->Dn[15:0], 4 1111100 101111Dn d16 0x0000->Dn[31:16] mem16(SP+d32)->Dn[15:0], 6 11111100 101111Dn d16 0x0000->Dn[31:16] mem16(SP)->Rn[15:0], 6 11111100 101111Dn d32 0x0000->Rn[31:16] mem16(SP)-Xn[15:0], 3 1111100 1010 Rn 0x0000->Rn[31:16] mem16(SP+(zero_ext)d8)->Rn[15:0], 4 11111101 1100 1010 Rn 0x0000->Rn[31:16] mem16(SP+(zero_ext)d24)->Rn[15:0], 7 11111101 1100 1010 Rn 0x0000->Rn[31:16] mem16(SP+d32)->Rn[15:0], 7 11111101 1100 1010 Rn 0x0000->Rn[31:16] mem16(SP+d32)->Rn[15:0], 7 11111101 1100 1010 Rn 0x0000->Rn[31:16] mem16(SP+d32)->Rn[16:0], 3 11111001 1010 Rn 0x0000->Rn[31:16] mem16(SP+d32)->Rn[16:0], 3 11111001 1010 Rn 0x0000->Rn[31:16] mem16(SP+d32)->Rn[16:0], | | MOVHU (abs8),Rn | mem16((zero_ext)abs8)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | 4 1111 1011 0100 1110 Rn abs8 | | Rn mem16(abs32)->Rn[15:0], - - 7 111111001001110 Rn Dn mem16(SP+(zero_ext)d8)->Dn[15:0], - - - 3 11111000 101111Dn d8 ),Dn mem16(SP+(zero_ext)d16)->Dn[15:0], - - - 4 1111100 101111Dn d18 ),Dn mem16(SP+d32)->Dn[15:0], - - - 4 1111100 101111Dn d18 ),Dn mem16(SP+d32)->Dn[15:0], - - - 4 1111100 101111Dn d18 0x0000->Rn[31:16] - - - - - 4 1111100 1010 Rn 0x0000->Rn[31:16] - - - - - 4 1111100 1010 Rn 0x0000->Rn[31:16] - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -< | | MOVHU (abs24),Rn | | 1 | 1111 1101 0100 1110 Rn | | Dn mem16(SP+(Zero_ext)d8)->Dn[15:0], 3 0x0000->Dn[31:16] 0,Dn mem16(SP+(Zero_ext)d16)->Dn[15:0], 4 0x0000->Dn[31:16] 0x0000->Dn[31:16] mem16(SP+d32)->Dn[15:0], 6 0x0000->Rn[31:16] Rn mem16(SP+(Zero_ext)d8)->Rn[15:0], 3 0x0000->Rn[31:16] Rn mem16(SP+(Zero_ext)d8)->Rn[15:0], 6 0x0000->Rn[31:16] | | MOVHU (abs32),Rn | mem16(abs32)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | | | ),Dn mem16(SP+(zero_ext)d16)->Dn[15:0], 4 0x0000->Dn[31:16] 6 0x0000->Dn[31:16] 6 0x0000->Dn[31:16] 3 0x0000->Rn[31:16] 3 0x0000->Rn[31:16] 4 0x0000->Rn[31:16] 4 0x0000->Rn[31:16] 7 3 Rm[15:0]->mem16(Rn) 3 | | MOVHU (d8,SP),Dn | mem16(SP+(zero_ext)d8)->Dn[15:0],<br>0x0000->Dn[31:16] | 1 | 3 1111 1000 1011 11Dn d8 | | h.Dn mem16(SP+d32)-Dn[15:0], 6 | | MOVHU (d16,SP),Dn | mem16(SP+(zero_ext)d16)->Dn[15:0],<br>0x0000->Dn[31:16] | 1 | 4 1111 1010 1011 11Dn d16 | | Rn mem16(SP)->Rn[15:0], 3 0x0000->Rn[31:16] 4 Rn mem16(SP+(zero_ext)d8)->Rn[15:0], 4 0x0000->Rn[31:16] 6 0x0000->Rn[31:16] 7 0x0000->Rn[31:16] 7 0x0000->Rn[31:16] 7 0x0000->Rn[31:16] 7 0x0000->Rn[31:16] 3 Rm[15:0]->mem16(Rn) 3 | | MOVHU (d32,SP),Dn | mem16(SP+d32)->Dn[15:0],<br>0x0000->Dn[31:16] | 1 | 6 1111 1100 1011 11Dn d32 | | mem16(SP+(zero_ext)d8)->Rn[15:0], 4<br>0x0000->Rn[31:16]<br>mem16(SP+(zero_ext)d24)->Rn[15:0], 6<br>0x0000->Rn[31:16]<br>mem16(SP+d32)->Rn[15:0], 7<br>0x0000->Rn[31:16]<br>Dm[15:0]->mem16(An) 2<br>Rm[15:0]->mem16(Rn) 3 | | MOVHU (SP),Rn | mem16(SP)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | 3 1111 1001 1100 1010 Rn | | mem16(SP+(zero_ext)d24)->Rn[15:0], 6<br>0x0000->Rn[31:16]<br>mem16(SP+d32)->Rn[15:0], 7<br>0x0000->Rn[31:16]<br>Dm[15:0]->mem16(An) 2<br>Rm[15:0]->mem16(Rn) 3 | | MOVHU (d8,SP),Rn | mem16(SP+(zero_ext)d8)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | | | mem16(SP+d32)->Rn[15:0], 7 0x0000->Rn[31:16] 2 Dm[15:0]->mem16(Rn) 3 | | MOVHU (d24,SP),Rn | mem16(SP+(zero_ext)d24)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | 1111 1101 1100 1010 Rn | | Dm[15:0]->mem16(An) 2<br>Rm[15:0]->mem16(Rn) 3 | | MOVHU (d32,SP),Rn | mem16(SP+d32)->Rn[15:0],<br>0x0000->Rn[31:16] | 1 | 7 1111 1110 1100 1010 Rn d32 | | Rm[15:0]->mem16(Rn) - - - 3 | | MOVHU Dm,(An) | Dm[15:0]->mem16(An) | 1 | 2 1111 0000 0111 DmAn | | | | MOVHU Rm,(Rn) | Rm[15:0]->mem16(Rn) | 1 | 3 1111 1001 0101 1010 Rm Rn | | Machine Code | | | | : | 1111 | 1010 | | | | | | 4 | 2 | | | | | | | | 18 | | 124 | 132 | | | 80 | | 124 | | 132 | | | | |--------------|----------------------------------|-------------------|----------------------------|----------------------------------|-----------------------------------|---------------------------------|-------------------------|-------------------------------|----------------------------------|-------------------------------|---------------------------------|----------------------------------|--------------------------------|----------------------------------|-----------------------------------|-----------------------------|----------------------------|----------------------------------|-----------------------------------|------------------------------|-------------------------------------|-----------------------------------------|------------------------------------------------------------------|------------------------------------|--------------------------------|------------------------------------------------------|------------------------------------|-------------------------|-------------------------------------|------------------------|----------------------------------|------------------------------|--------------------------------------|--------------------------| | Code ZF Size | - 3 1111 1000 0111 DmAn d8 | | - 6 11111100 0111 DmAn d32 | - 4 11111011 0101 1010 Rm Rn d8 | - 6 1111 1101 0101 1010 Rm Rn d24 | - 7 111111100101 1010 Rm Rn d32 | - 2 1111 0100 11Dm DiAn | - 4 1111 1011 1101 1110 Ri Rm | - 3 0000 Dm11 abs16 | - 6 1111 1100 1000 Dm11 abs32 | - 4 1111101101011110 Rm abs8 | - 6 1111 1101 0101 1110 Rm abs24 | - 7 1111111001011110 Rm abs32. | - 3 1111 1000 1001 Dm11 d8 | - 4 1111 1010 1001 Dm11 d16 | - 6 1111 1100 1001 Dm11 d32 | - 3 1111 1001 1101 1010 Rm | - 4 1111 1011 1101 1010 Rm d8 | - 6 1111 1101 1101 1010 Rm d24 | - 7 111111101101 1010 Rm d32 | - 4 1111 1011 1110 1010 Rn Rm imm8. | | - 6 1111 1101 1110 1010 Rn Rm imm24 | - 7 111111101110 1010 Rn Rm imm32. | | - 3 1111 1001 1110 1010 Rn Rm | - 4 1111 1011 1111 1010 Rm Rn imm8 | | - 6 1111 1101 1111 1010 Rm Rn imm24 | | | | | 3 1111 1001 0010 1010 Bm | | Flag Code | 1 | 1 | 1 | 1 | 1 | - | 1 | 1 | - | 1 | - | 1 | - | 1 | 1 | | 1 | 1 | 1 | 1 | 1 | _ | '<br>' | 1 | | 1 1 | 1 | | 1 | | - - - น | 1 | 1 | | | Operation | Dm[15:0]->mem16(An+(sign_ext)d8) | | Dm[15:0]->mem16(An+d32) | Rm[15:0]->mem16(Rn+(sign_ext)d8) | | | Dm[15:0]->mem16(Di+An) | Rm[15:0]->mem16(Ri+Rn) | Dm[15:0]->mem16((zero_ext)abs16) | Dm[15:0]->mem16(abs32) | Rm[15:0]->mem16((zero_ext)abs8) | | Rm[15:0]->mem16(abs32) | Dm[15:0]->mem16(SP+(zero_ext)d8) | Dm[15:0]->mem16(SP+(zero_ext)d16) | Dm[15:0]->mem16(SP+d32) | Rm[15:0]->mem16(SP) | Rm[15:0]->mem16(SP+(zero_ext)d8) | Rm[15:0]->mem16(SP+(zero_ext)d24) | Rm[15:0]->mem16(SP+d32) | | 0x0000->Rn[31:16],Rm+(sign_ext)imm8->Rm | mem16(Rm)->Rn[15:0],<br>0x0000->Rn[31:16].Rm+(sign_ext)imm24->Rm | mem16(Rm)->Rn[15:0], | 0x0000->Rn[31:16],Rm+imm32->Rm | mem16(Rm)->Rn[15:0],<br> 0<0000 >Bn[31:16] Bm±2 >Bm | WI(15:01->mem16(Rn) | Kinf(sign_ext)jimm8->Rn | Rm[15:0]->mem16(Rn), | Rn+(sign_ext)imm24->Rn | Rm[15:0]->mem16(Rn),Rn+imm32->Rn | Rm[15:0]->mem16(Rn),Rn+2->Rn | mem8(Am)->Dn[7:0],0x000000->Dn[31:8] | mome/Dm) | | Mnemonic | MOVHI MOVHU Dm.(d8.An) | MOVHU Dm.(d16.An) | MOVHU Dm,(d32,An) | MOVHU Rm,(d8,Rn) | | MOVHU Rm,(d32,Rn) | MOVHU Dm,(Di,An) | MOVHU Rm,(Ri,Rn) | MOVHU Dm,(abs16) | MOVHU Dm,(abs32) | MOVHU Rm,(abs8) | MOVHU Rm,(abs24) | MOVHU Rm, (abs32) | MOVHU Dm,(d8,SP) | MOVHU Dm,(d16,SP) | MOVHU Dm,(d32,SP) | MOVHU Rm,(SP) | MOVHU Rm,(d8,SP) | MOVHU Rm,(d24,SP) | MOVHU Rm,(d32,SP) | MOVHU (Rm+,imm8),Rn | | MOVHU (Rm+,imm24),Rn | MOVHU (Rm+,imm32),Rn | | MOVHU (Rm+),Rn | MOVHIJ Rm (Rn+ imm8) | (2) | MOVHU Rm,(Rn+,imm24) | | MOVHU Rm,(Rn+,imm32) | | - 1 | MO\/DII /Dw\ Dr | | Group | HVOW | ) | | | | | | | | | | | | | | | | | | | • | | | | | | , | | , | | | | MOVBU | | | | VFCFNFZF Size | Size Machine Code | |------------------------------------------------------------------------|---------------|---------------------------------| | mem8(Am+(sign_ext)d8)->Dn[7:0], - - - - - | 1 | 3 1111 1000 0100 DnAm d8 | | mem8(Am+(sign_ext)d16)->Dn[7:0], 00x000000->Dn[31:8] | 1 | 4 1111 1010 0100 DnAm d16 | | mem8(Am+d32)->Dn[7:0], 0x000000->Dn[31:8] | 1 | 6 1111 1100 0100 DnAm d32 | | mem8(Rm+(sign_ext)d8)->Rn[7:0], 0x0000000->Rn[31:8] | ı | 4 1111 1011 0010 1010 Rn Rm d8 | | mem8(Rm+(sign_ext)d24)->Rn[7:0], 0x0000000->Rn[31:8] | ı | 6 1111 1101 0010 1010 Rn Rm d24 | | mem8(Rm+d32)->Rn[7:0], 0.0000000->Rn[31:8] | ı | 7 1111 1110 0010 1010 Rn Rm d32 | | mem8(Di+Am)->Dn[7:0];0x000000->Dn[31:8] | ı | 2 1111 0100 00Dn DiAm | | mem8(Ri+Rm)->Rn[7:0],0x000000->Rn[31:8] | ı | 4 1111 1011 1010 1110 Ri Rm Rn | | mem8((zero_ext)abs16)->Dn[7:0], - - - - - - - - - - - - - | 1 | 3 0011 01Dn abs16 | | mem8(abs32)->Dn[7:0],0x000000->Dn[31:8] | ı | 6 1111 1100 1010 10Dn abs32 | | mem8((zero_ext)abs8)->Rn[7:0], - - - - - - - - - - - - - | ı | 4 1111 1011 0010 1110 Rn abs8 | | mem8((zero_ext)abs24)->Rn[7:0], 0x0000000->Rn[31:8] | 1 | 6 1111 1101 0010 1110 Rn abs24 | | mem8(abs32)-Pn[7:0],0x000000->Rn[31:8] | ı | 7 1111 1110 0010 1110 Rn abs32 | | mem8(SP+(zero_ext)d8)->Dn[7:0], 0x0000000->Dn[31:8] | 1 | 3 1111 1000 1011 10Dn d8 | | mem8(SP+(zero_ext)d16)->Dn[7:0], - - - - - - - - - - - - - | 1 | 4 1111 1010 1011 10Dn d16 | | mem8(SP+d32)->Dn[7:0], 0x0000000->Dn[31:8] | 1 | 6 1111 1100 1011 10Dn d32 | | mem8(SP)->Rn[7:0],0x000000->Rn[31:8] | 1 | 3 1111 1001 1010 1010 Rn | | mem8(SP+(zero_ext)d8)->Rn[7:0], 0x0000000->Rn[31:8] | 1 | 4 1111 1011 1010 1010 Rn d8 | | mem8(SP+(zero_ext)d24)->Rn[7:0], 0x0000000->Rn[31:8] | ı | 6 1111 1101 1010 1010 Rn d24 | | mem8(SP+d32)->Rn[7:0], | ı | 7 1111 1110 1010 1010 Rn d32 | | Dm[7:0]->mem8(An) | , | 2 1111 0000 0101 DmAn | | Group | Mnemonic | Operation | Flag Code Machine Code VFCFNFZF Size | |-------|-------------------------------|-----------------------------------------------------|------------------------------------------------------------------------| | | | | | | MOVB | MOVBU MOVBU Rm.(Rn) | Rm[7:0]->mem8(Rn) | - - - 3 1111 1001 0011 1010 Rm Rn | | | MOVBU Dm.(d8.An) | Dm[7:0]->mem8(An+(sign_ext)d8) | | | | MOVBU Dm,(d16,An) | Dm[7:0]->mem8(An+(sign_ext)d16) | 4 11111010 0101 DmAn d16 | | | MOVBU Dm,(d32,An) | | 6 1111 1100 0101 DmAn d32 | | | MOVBU Rm,(d8,Rn) | Rm[7:0]->mem8(Rn+(sign_ext)d8) | - - - 4 111 1011 0011 1010 Rm Rn d8 | | | MOVBU Rm,(d24,Rn) | Rm[7:0]->mem8(Rn+(sign_ext)d24) | - - - 6 1111 1101 0011 1010 Rm Rn d24 | | | MOVBU Rm,(d32,Rn) | Rm[7:0]->mem8(Rn+d32) | - - - - 7 111111000111010Rm Rn d32 | | | MOVBU Dm,(Di,An) | Dm[7:0]->mem8(Di+An) | - - - 2 1111 0100 01Dm DiAn | | | MOVBU Rm,(Ri,Rn) | Rm[7:0]->mem8(Ri+Rn) | - - - - 4 1111 1011 1011 1110 Ri Rn Rm | | | MOVBU Dm,(abs16) | Dm[7:0]->mem8((zero_ext)abs16) | | | | MOVBU Dm,(abs32) | Dm[7:0]->mem8(abs32) | - - - 6 1111 1100 1000 Dm10 abs32 | | | MOVBU Rm,(abs8) | Rm[7:0]->mem8((zero_ext)abs8) | - - - - 4 1111101100111110 Rm abs8 | | | MOVBU Rm,(abs24) | Rm[7:0]->mem8((zero_ext)abs24) | - - - - 6 11111110100111110 Rmabs24 | | | MOVBU Rm,(abs32) | Rm[7:0]->mem8(abs32) | - - - - 7 111111000111110Rmabs32 | | | MOVBU Dm,(d8,SP) | Dm[7:0]->mem8(SP+(zero_ext)d8) | - - - - 3 1111 1000 1001 Dm10 d8 | | | MOVBU Dm,(d16,SP) | Dm[7:0]->mem8(SP+(zero_ext)d16) | - - - 4 111110101001 Dm10 d16 | | | MOVBU Dm,(d32,SP) | Dm[7:0]->mem8(SP+d32) | - - - - 6 1111 1100 1001 Dm10 d32 | | | MOVBU Rm,(SP) | Rm[7:0]->mem8(SP) | - - - 3 1111 1001 1011 1010 Rm | | | MOVBU Rm,(d8,SP) | Rm[7:0]->mem8(SP+(zero_ext)d8) | | | | MOVBU Rm,(d24,SP) | Rm[7:0]->mem8(SP+(zero_ext)d24) | | | | MOVBU Rm,(d32,SP) | Rm[7:0]->mem8(SP+d32) | - - - - 7 1111111010111010 Rm d32 | | MOV | MOVM MOVM (SP),[reg1,,,,regn] | See "MOVM" page | 2 11001110regs | | | MOVM [reg1,,,,regn],(SP) | See "MOVM" page | 2 11001111regs | | | MOVM (USP),[reg1,,,regn] | | - - - - 3 1111 1000 1100 1110 regs | | | MOVM [reg1,,,regn],(USP) | | | | EXT | EXT Dn | (sign_ext)(Dn)->{MDR,Dn} | - - - - 2 1111 0010 1101 00Dn | | | EXT Rn | if(Rn.bp31=0)0x0->MDR | - - - 3 1111 1001 0001 1000 Rn | | | $\overline{}$ | ,else 0xFFFFFFF->MDR | | | EXTH | EXTH Dn | if(Dn.bp15=0)Dn&0xFFFF->Dn | - - - 1 000110Dn | | | | ,else Dn 0xFFFF0000->Dn | | | | EXTH Rn | if(Rn.bp15=0)Rn&0xFFFF->Dn | - - - 3 1111 1001 0100 1000 Rn Rn | | | | ,else Rn 0xFFFF0000->Rn | | | | EXTH Rm,Rn | if(Rm.bp15=0)Rm&0xFFFF->Rn<br>else Rml0xFFFF000->Rn | - - - 3 1111 1001 0100 1000 Rm Rn | | EXTHU | EXTHU Dn | Dn&0xFFFF->Dn | 1 | | | EXTHU | Rn&0xFFF->Rn | 3 1111 1001 0101 1000 Rm Rn | | | | | | | | | | VFCFINFZF Size | |-------------|---------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | EXTHU Rm,Rn | Rm&0xFFFF->Rn | - - - 3 1111 1001 0101 1000 Rm Rn | | | 3 Dn | if(Dn.bp7=0)Dn&0xFF->Dn<br>.else Dnl0xFF000000->Dn | 1 0001 00Dn | | | 3 Rn | if(Rn.bp7=0)Rn&0xFF->Dn<br>else Rnl0xFF000000->Rn | 3 1111 1001 0010 1000 Rn Rn | | | 3 Rm,Rn | if(Rm.bp7=0)Rm&0xFF->Rn<br>else Rml0xFF000000->Rn | 3 1111 1001 0010 1000 Rm Rn | | EXTBU EXTBU | SU Dn | Dn&0xFF->Dn | 1 0001 01Dn | | EXTBU | 3U Rn | Rn&0xFF->Rn | - - - 3 1111 1001 0011 1000 Rn Rn | | EXTE | EXTBU Rm,Rn | Rm&0xFF0>Rn | - - - 3 1111 1001 0011 1000 Rm Rn | | CLR CLR | Dn | 0x0000000->Dn | - - - 1 0000 Dn00 | | CLR Rn | Rn | 0x00000000->Rn | | | DCPF DCPF | DCPF (Rm) | mem_cline(Rm)->[DataCache] | - - - - 3 1111100110100110 Rm | | DCPF | DCPF (d8,Rm) | mem_cline(Rm+(sign_ext)d8)->[DataCache] | | | DCPF | DCPF (d24,Rm) | mem_cline(Rm+(sign_ext)d24)->[DataCache] | - - - - 6 1111 1101 1010 0111 Rm d24 | | DCPF | DCPF (d32,Rm) | mem_cline(Rm+d32)->[DataCache] | - - - - 7 1111 1110 0100 0110 Rm d32 | | DCPF | DCPF (Ri,Rm) | mem_cline(Rm+Ri)->[DataCache] | - - - - 4 1111 1011 1010 0110 Ri Rm | | DCPF | DCPF (SP) | mem_cline(SP)->[DataCache] | - - - - 3 1111 1001 1010 0111 | | ADD ADD | Dm,Dn | Dm+Dn->Dn | | | ADD | Dm,An | Dm+An->An | | | ADD | Am,Dn | Am+Dn->Dn | $\Delta oxedskip \Delta A o$ | | ADD | Am,An | Am+An->An | $\Delta \mid_\Delta \mid_\Delta \mid_\Delta$ 1111 0001 0111 AmAn | | ADD | Rm,Rn | Rm+Rn->Rn | ∆ ∆ ∆ ∆ 3 1111 1001 0111 1000 Rm Rn | | ADD | Rm,Rn,Rd | Rm+Rn->Rd | | | ADD | imm8,Dn | (sign_ext)imm8+Dn->Dn | $\Delta egin{array}{ c c c c c c c c c c c c c c c c c c c$ | | ADD | imm16,Dn | (sign_ext)imm16+Dn->Dn | | | ADD | imm32,Dn | imm32+Dn->Dn | $\Delta \mid \Delta \mid \Delta \mid \Delta \mid \Delta \mid \Delta$ | | ADD | imm8,An | (sign_ext)imm8+An->An | | | ADD | imm16,An | (sign_ext)imm16+An->An | $\Delta \mid_\Delta \mid_\Delta \mid_\Delta \mid$ 4 1111 1010 1101 00An imm16 | | ADD | imm32,An | imm32+An->An | $\Delta \mid_\Delta \mid_\Delta \mid_\Delta \mid$ 6 1111 1100 1101 00An imm32 | | ADD | imm8,Rn | (sign_ext)imm8+Rn->Rn | ∆ ∆ ∆ ∆ A 1111 1011 0111 1000 Rn Rm imm8 | | ADD | imm24,Rn | (sign_ext)imm24+Rn->Rn | $\Delta \mid_\Delta \mid_\Delta \mid_\Delta \mid_\Delta \mid$ 6 1111 1101 0111 1000 Rn Rm imm24 | | ADD | imm32,Rn | imm32+Rn->Rn | | | ADD | imm8,SP | (sign_ext)imm8+SP->SP | | | ADD | imm16,SP | (sign_ext)imm16+SP->SP | - - - - 4 1111 1010 1111 1110 imm16 | | ADD | imm32,SP | imm32+SP->SP | $\Delta \mid \Delta \mid \Delta \mid \Delta \mid \Delta \mid \Delta$ | | Group | Mnemonic | Operation | Flag Code Machine Code VFCFNFZF Size | |-------|--------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | ADDC | ADDC Dm,Dn | Dm+Dn+EPSW.C->Dn | \( \lambda \ | | | | Rm+Rn+EPSW.C->Rn | $\Delta$ $\Delta$ $\Delta$ $\Delta$ 1111 1001 1000 1000 Rm Rn | | | ADDC Rm,Rn,Rd | Rm+Rn+EPSW.C->Rd | $\Delta$ $\Delta$ $\Delta$ $\Delta$ 4 1111 1011 1000 1100 Rm Rn Rd | | | ADDC imm8,Rn | (sign_ext)imm8+Rn+EPSW.C->Rn | $\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}\mid$ 4 111 1011 1000 1000 Rn Rm imm8 | | | ADDC imm24,Rn | (sign_ext)imm24+Rn+EPSW.C->Rn | $\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}\mid$ 6 1111 1101 1000 1000 Rn Rm imm24 | | | ADDC imm32,Rn | imm32+Rn+EPSW.C->Rn | $\Delta$ $\Delta$ $\Delta$ $\Delta$ $\Delta$ 11111110 1000 1000 Rn Rm imm32 | | SUB | SUB Dm,Dn | Dn-Dm->Dn | $\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}$ | | | SUB Dm,An | An-Dm->An | $\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}$ | | | SUB Am,Dn | Dn-Am->Dn | $\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}\mid_{\Delta}$ | | | SUB Am,An | An-Am->An | $\mid \Delta \mid \Delta \mid \Delta \mid \Delta \mid \Delta \mid$ 1111 0001 0011 AmAn | | | SUB Rm,Rn | Rn-Rm->Rn | $\Delta$ $\Delta$ $\Delta$ $\Delta$ $\Delta$ 1111100110011001 Rm Rn | | | SUB Rm,Rn,Rd | Rn-Rm->Rd | $\Delta$ $\Delta$ $\Delta$ $\Delta$ 4 111 1011 1001 1100 Rm Rn Rd | | | SUB imm32,Dn | Dn-imm32->Dn | $\mid \Delta \mid \Delta$ | | | SUB imm32,An | An-imm32->An | \( \lambda \) | | | SUB imm8,Rn | Rn-(sign_ext)imm8->Rn | $\Delta$ $\Delta$ $\Delta$ $\Delta$ 4 11111011 1001 1000 Rn Rm imm8 | | | SUB imm24,Rn | Rn-(sign_ext)imm24->Rn | $\mid \Delta \mid \Delta \mid \Delta \mid \Delta \mid \Delta \mid \Delta$ | | | SUB imm32,Rn | Rn-imm32->Rn | | | SUBC | SUBC Dm,Dn | Dn-Dm-EPSW.C->Dn | | | | SUBC Rm,Rn | Rn-Rm-EPSW.C->Rn | $\Delta$ $\Delta$ $\Delta$ $\Delta$ $\Delta$ 11111001101001001000 Rm Rn | | | SUBC Rm,Rn,Rd | Rn-Rm-EPSW.C->Rd | $\Delta$ $\Delta$ $\Delta$ $\Delta$ 4 1111 1011 1010 1100 Rm Rn Rd | | | SUBC imm8,Rn | Rn-(sign_ext)imm8-EPSW.C->Rn | | | | SUBC imm24,Rn | Rn-(sign_ext)imm24-EPSW.C->Rn | $\mid \Delta \mid \Delta$ | | | SUBC imm32,Rn | Rn-imm32-EPSW.C->Rn | $\Delta$ $\Delta$ $\Delta$ $\Delta$ $\Delta$ 1111111010100 Rn Rm imm32 | | | MUL Dm,Dn | Dm*Dn->{MDR,Dn} | | | MOL | MUL Rm,Rn | Rm*Rn->{MDR,Rn} | ? ? $\Delta$ $\Delta$ $\Delta$ 11111001101011001 Rm Rn | | | MUL Rm,Rn,Rd1,Rd2 | Rm*Rn->{Rd1,Rd2} | ? ? $\Delta$ $\Delta$ 4 111110111010 1101 Rm Rn Rd1. Rd2. | | | MUL imm8,Rn | (sign_ext)imm8*Rn->{MDR,Rn} | | | | MUL imm24,Rn | sign_ext)imm24*Rn->{MDR,Rn} | $ \ ?\ \ S\ _{\Delta}\ _{\Delta}\ _{\Delta}\ _{\Delta}$ | | | MUL imm32,Rn | imm32*Rn->{MDR,Rn} | ? ^ ^ \ | | <br> | | Dm*Dn->{MDR,Dn} | | | 5 | MULU Rm,Rn | Rm*Rn->{MDR,Rn} | | | | MULU Rm,Rn,Rd1,Rd2 | Rm*Rn->{MDR,Rn} | ? ? $\Delta$ $\Delta$ 4 1111101110111101 Rm Rn Rd1. Rd2. | | | MULU imm8,Rn | (zero_ext)imm8*Rn->{MDR,Rn} | 1 | | | MULU imm24,Rn | cero_ext)imm24*Rn->{MDR,Rn} | $ \ ?\ \ ?\ _{\Delta}\ _{\Delta}\ _{\Delta}\ $ | | | MULU imm32,Rn | imm32*Rn->{MDR,Rn} | 2 7 7 6 | | DIV | DIV Dm,Dn | {MDR,Dn}/Dm->Dn,{MDR,Dn}%Dm->MDR | $ 0/1 $ ? $ \Delta P_{0} $ 2 1111 0010 0110 DmDn | | | | | | | MIDRIANIAN MIDRIANIANIAN MIDRIANIANIAN MIDRIANIANIAN MIDRIANIANIAN MIDRIANIANIAN MIDRIANIANIANIAN MIDRIANIANIANIANIANIANIANIANIANIANIANIANIANI | נוסים | | Citorogo | Flag Code | Charles Considered | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|----------------------------------|-----------------------------------------|------------------------------| | DIVU Rm,Rn | 5 | | Operation | VFCFNFZF Size | Macillia Code | | DIV Rm.Rn 4MDR.RnJvRm->Rn_4MDR.RnJv8Rm->MDR 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 | | | | | | | DIVU Dm,Dn | | | {MDR,Rn}/Rm->Rn,{MDR,Rn}%Rm->MDR | ? A? A? 3 | 1 1001 1100 1001 Rm Rn | | INC | | - 1 | {MDR,Dn}/Dm->Dn,{MDR,Dn}%Dm->MDR | 2 47 47 2 | 10010 0111 DmDn | | INC | | $\neg$ | {MUK,Kn}/Km->Kn,{MUK,Kn}%Km->MUK | , NY NY . | | | INC | ာ<br>N | | Un+1->Un | | UDUOU | | INC Rn | | | An+1->An | _ | 0 An01 | | INC4 An Rn+4->An INC4 Rn Inch | | | Rn+1->Rn | Δ Δ Δ 3 | 1 1001 1011 1000 Rm Rn | | INC4 Rn | | | An+4->An | | 1 00An | | CMP Dm,Dn Dn-Dm: EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | Rn+4->Rn | A A A 3 | 1 1001 1100 1000 Rm Rn | | CMP Dm,An An-Dm: EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | CMP | | Dn-Dm : EPSW | 1 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 0 DmDn | | CMP Am, Dn Dn-Am: EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | : | | An-Dm : EPSW | $\Delta$ $\Delta$ $\Delta$ 2 | 1 0001 1010 DmAn | | CMP Am,An Am-An : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | Dn-Am : EPSW | $\Delta$ $\Delta$ $\Delta$ $\Delta$ | 1 0001 1001 AmDn | | CMP Rm,Rn Rm-Rn: EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | Am-An : EPSW | \ | 1 AmAn | | CMP imm8,Dn Dn-(sign ext)imm8 : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | Rm-Rn : EPSW | S \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 1001 1101 1000 Rm Rn | | CMP imm16,Dn Dn-(sign ext)imm16 : EPSW A A A A A A A A A A A A A A B CMP Imm32,Dn Dn-imm32 : EPSW A A B B CMP Imm8,An An -(Zero_ext)imm8 : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | Dn-(sign_ext)imm8 : EPSW | $\Delta$ $\Delta$ $\Delta$ 2 | 0 DnDn imm8 | | CMP imm32,Dn Dn-imm32 : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A </td <td></td> <td></td> <td>Dn-(sign_ext)imm16 : EPSW</td> <td>4 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \</td> <td>1 1010 1100 10Dn imm16</td> | | | Dn-(sign_ext)imm16 : EPSW | 4 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 1010 1100 10Dn imm16 | | CMP imm8,An An-(Zero_ext)imm8 : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A < | | | Dn-imm32 : EPSW | 9 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 1100 1100 10Dn imm32 | | CMP imm16,An An-(zero_ext)imm16 : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | An-(zero_ext)imm8 : EPSW | $ \Delta \Delta \Delta$ | 1 AnAn imm8 | | CMP imm32,An An-imm32 : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A </td <td></td> <td></td> <td>An-(zero_ext)imm16 : EPSW</td> <td>Δ Δ Δ 4</td> <td>1 1010 1101 10An imm16</td> | | | An-(zero_ext)imm16 : EPSW | Δ Δ Δ 4 | 1 1010 1101 10An imm16 | | CMP imm8,Rn Rn-(sign_ext)imm8 : EPSW A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A B A A B A A B A A B A A B A A B A A A A A A A A A A A A A A A A A A A A A A A A A A A B A A A A A A A A A A A A A A A A A A A A A A | | | An-imm32 : EPSW | 9 V V V | 1 1100 1101 10An imm32 | | CMP imm24,Rn Rn-(sign_ext)imm24 : EPSW A A A A B T CMP imm32,Rn Rn-imm32 : EPSW A A A A A A A B A A A A A A B A A B A A A A A A A B B A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | Rn-(sign_ext)imm8 : EPSW | 4 A A 4 | 1 1011 1101 1000 Rn imm8 | | CMP imm32,Rn Rn-imm32 : EPSW A A A B A B B A B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B </td <td></td> <td></td> <td>Rn-(sign_ext)imm24 : EPSW</td> <td>2 9 V V V</td> <td>1 1101 1101 1000 Rn imm24</td> | | | Rn-(sign_ext)imm24 : EPSW | 2 9 V V V | 1 1101 1101 1000 Rn imm24 | | AND Dm,Dn Dm&Dn->Dn A 3 AND Rm,Rn Rm&Rn->Rn 0 0 0 0 4 3 AND Rm,Rn,Rd Rm&Rn->Rd 0 0 0 0 0 4 4 AND imm8,Dn (zero_ext)imm8&Dn->Dn 0 0 0 0 0 4 4 AND imm32,Dn imm32&Dn->Dn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | Rn-imm32 : EPSW | $\Delta$ $\Delta$ $\Delta$ $\Delta$ | 1 1110 1101 1000 Rn imm32 | | AND Rm,Rn Rm&Rn->Rn Rm &Rn->Rn A 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 6 A A A A A A A A A A A A A A A A A A A A A A <td>AND</td> <td></td> <td>Dm&amp;Dn-&gt;Dn</td> <td>0 \ \( \Delta \ \)</td> <td>1 0010 0000 DmDn</td> | AND | | Dm&Dn->Dn | 0 \ \( \Delta \ \) | 1 0010 0000 DmDn | | AND Rm,Rn,Rd Rm&Rn->Rd 0 0 A 4 AND imm8,Dn (zero_ext)imm8&Dn->Dn 0 0 0 0 0 4 6 AND imm16,Dn (zero_ext)imm16&Dn->Dn 0 0 0 0 0 4 6 AND imm32,Dn imm32&Dn->Dn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | Rm&Rn->Rn | 0 4 4 3 | 1 1001 0000 1001 Rm Rn | | AND imm8,Dn (zero_ext)imm8&Dn->Dn 0 0 0 0 4 AND imm16,Dn (zero_ext)imm16&Dn->Dn 0 0 0 0 0 0 4 6 AND imm32,Dn imm32&Dn->Dn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | Rm&Rn->Rd | 0 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 1011 0000 1101 Rm Rn Rd | | AND imm16,Dn (zero_ext)imm16&Dn->Dn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | (zero_ext)imm8&Dn->Dn | 9 7 7 0 | 1 1000 1110 00Dn imm8 | | AND imm32,Dn imm32&Dn->Dn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | (zero_ext)imm16&Dn->Dn | 4 A A 4 | 1 1010 1110 00Dn imm16 | | AND imm8,Rn (zero_ext)imm8&Rn->Rn 0 0 A 7 AND imm24,Rn (zero_ext)imm24&Rn->Rn 0 0 A 4 6 AND imm32,Rn imm32&Rn->Rn 0 0 A A 2 3 AND imm16,PSW imm16 & EPSW[15:0]->EPSW[15:0] A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A <t< td=""><td></td><td></td><td>imm32&amp;Dn-&gt;Dn</td><td>9 V V 0</td><td>1 1100 1110 00Dn imm32</td></t<> | | | imm32&Dn->Dn | 9 V V 0 | 1 1100 1110 00Dn imm32 | | AND imm24,Rn (zero_ext)imm24&Rn->Rn 0 0 4 6 AND imm32,Rn imm32&Rn->Rn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | (zero_ext)imm8&Rn->Rn | 7 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 1011 0000 1001 Rn Rm imm8 | | AND imm32,Rn imm32&Rn->Rn 0 0 0 2 3 AND imm16,PSW imm16 & EPSW[15:0]->EPSW[15:0] A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | (zero_ext)imm24&Rn->Rn | 0 4 0 4 6 | 1 1101 0000 1001 Rn Rm imm24 | | AND imm16,PSW imm16 & EPSW[15:0]->EPSW[15:0] A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | | | imm32&Rn->Rn | 0 4 4 2 3 | 1 1110 0000 1001 Rn Rm imm32 | | AND imm32,EPSW imm32 & EPSW -> EPSW A A A A A OR Dm,Dn Dm Dn->Dn 0 0 A A OR Rm,Rn Rm Rn->Rn 0 0 A A OR Rm,Rn,Rd Rm Rn->Rd 0 0 A A | | | $\overline{}$ | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 1010 1111 1100 imm16 | | OR Dm,Dn Dm Dn->Dn OR Rm,Rn Rm Rn->Rn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0< | | | imm32 & EPSW -> | $\nabla$ $\nabla$ $\nabla$ | 1 1100 1111 1100 imm32 | | OR Rm,Rn Rm Rn->Rn 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | OR | | Dm Dn->Dn | 0 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 0010 0001 DmDn | | Rm,Rn,Rd Rm Rn->Rd 0 $\Delta$ $\Delta$ | ) | | Rm Rn->Rn | 0 \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | 1 1001 0001 1001 Rm Rn | | | | | Rm Rn->Rd | V V 0 | 1 1011 0001 1101 Rm Rn Rd | | Group | | Mnemonic | Operation | Flag Code<br>VFCFNFZF Size | Machine Code | | |----------|------|-------------------|--------------------------------------------------------------|--------------------------------------------|------------------------------------|---| | | | | | | | | | OR | OR | imm8,Dn | (zero_ext)imm8 Dn->Dn | 0 0 \( \Delta \) \( \Delta \) \( \Delta \) | 3 1111 1000 1110 01Dn imm8 | | | | OR | imm16,Dn | (zero_ext)imm16 Dn->Dn | 0 0 4 4 1 | 1111 1010 1110 01Dn imm16 | | | | OR | imm32,Dn | imm32 Dn->Dn | 0 0 4 4 6 1 | 1111 1100 1110 01Dn imm32 | | | | OR. | imm8,Rn | (zero_ext)imm8 Rn->Rn | 0 0 4 1 | 1111 1011 0001 1001 Rn Rm imm8 | | | | OR | imm24,Rn | (zero_ext)imm24 Rn->Rn | 9 7 7 0 | 1111 1101 0001 1001 Rn Rm imm24 | | | | OR | imm32,Rn | imm32 Rn->Rn | 0 0 4 4 7 7 1 | 1111 1110 0001 1001 Rn Rm imm32 | | | | OR | imm16,PSW | imm16 EPSW[15:0]->EPSW[15:0] | Δ Δ Δ 4 1 | 1111 1010 1111 1101 imm16 | | | | OR | imm32,EPSW | imm32 EPSW -> EPSW | V | 6 1111 1100 1111 1101 imm32 | | | XOR | XOR | Dm,Dn | Dm^Dn->Dn | | 1111 0010 0010 DmDn | | | | XOR | Rm,Rn | Rm^Rn->Rn | 0 0 4 4 3 1 | 1111 1001 0010 1001 Rm Rn | | | | XOR | Rm,Rn,Rd | Rm^Rn->Rd | 0 0 4 4 4 1 | 1111 1011 0010 1101 Rm Rn Rd | | | | XOR | imm16,Dn | (zero_ext)imm16^Dn->Dn | 0 0 0 0 | 1111 1010 1110 10Dn imm16 | | | | XOR | imm32,Dn | imm32^Dn->Dn | 0 0 4 4 6 1 | 1111 1100 1110 10Dn imm32 | | | | XOR | imm8,Rn | (zero_ext)imm8^Rn->Rn | 0 0 4 4 1 | 4 1111 1011 0010 1001 Rn Rm imm8 | | | | XOR | imm24,Rn | (zero_ext)imm24^Rn->Rn | 0 0 4 4 6 1 | 1111 1101 0010 1001 Rn Rm imm24 | | | | XOR | imm32,Rn | imm32^Rn->Rn | 0 0 4 4 7 7 1 | 1111 1110 0010 1001 Rn Rm imm32 | | | NOT | NOT | Du | Dn ^ 0xFFFFFFF -> Dn | | 1111 0010 0011 00Dn | | | <u>.</u> | NOT | R | Rn ^ 0xFFFFFFF-> Rn | က | 1111 1001 0011 1001 Rm Rn | | | BTST | | BTST imm8,Dn | (zero_ext)imm8&Dn :EPSW | 0 0 \( \Delta \) \( \Delta \) \( \Delta \) | 1111 1000 1110 11Dn imm8 | | | ) | | BTST imm16,Dn | (zero_ext)imm16&Dn :EPSW | 0 0 4 4 1 | 4 1111 1010 1110 11Dn imm16 | | | | BTST | BTST imm32,Dn | imm32 & Dn : EPSW | 0 0 4 4 6 1 | 1111 1100 1110 11Dn imm32 | | | | BTST | BTST imm8,Rn | (zero_ext)imm8&Rn :EPSW | 0 0 \( \Delta \) \( \Delta \) \( \Delta \) | 1111 1011 1110 1001 Rn imm8 | | | | BTST | BTST imm24,Rn | (zero_ext)imm24&Rn :EPSW | 9 | 1111 1101 1110 1001 Rn imm24 | | | | BTST | BTST imm32,Rn | imm32 & Rn : EPSW | 2 V V 0 | 1111 1110 1110 1001 Rn imm32 | | | | BTST | BTST imm8,(d8,An) | mem8(An+(sign_ext)d8)->TMP[7:0], | 0 0 0 0 4 1 | 1111 1010 1111 10An d8 imm8 | | | | | | 0x000000->TMP[31:8], | | | | | | | | sign_ext)imm8 & TMP : EPSW | | | | | | BTST | BTST imm8,(abs16) | mem8((zero_ext)abs16)->TMP[7:0], | 0 0 4 4 5 1 | 5 11111110 1000 0010 abs16 imm8 | | | | | | 0x000000->TMP[31:8], | | | | | | | | (sign_ext)imm8 & TMP : EPSW | | | | | | BTS1 | BTST imm8,(abs32) | mem8(abs32)->TMP[7:0], | 0 0 0 0 1 | 1111 1110 0000 0010 abs32 imm8 | | | | | | (sign_ext)imm8 & TMP : EPSW | | | | | BSET | | BSET Dm,(An) | mem8(An)->TMP[7:0], | 0 0 0 0 2 1 | 1111 0000 1000 DmAn | | | | | | 0x000000->TMP[31:8],TMP&Dn:EPSW<br> ,(TMP Dn)[7:0]->mem8(An) | | | | | | | | | - | | _ | Machine Code Flag Code VFCFNFZF Size Operation Mnemonic Group | | | | | į | | |------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------------------------|--------------------------------------| | | | | | | | | BSET | BSET Imm8,(d8,An) | mem8(An+(sign_ext)d8)->TMP[7:0],<br>0x000000->TMP[31:8],<br>TMP&(sign_ext)imm8 : EPSW,<br>(TMP (zero_ext)imm8)[7:0]<br>->mem8(An+(sign_ext)d8) | 0 0 0 | <b>V</b> | 4 1111 1010 1111 00An d8 imm8 | | | BSET imm8,(abs16) | mem8((zero_ext)abs16)->TMP[7:0],<br>0x000000->TMP[31:8],<br>TMP&(sign_ext)imm8 : EPSW,<br>(TMP (zero_ext)imm8)[7:0]<br>->mem8((zero_ext)abs16) | 0 0 0 | < < > < < < < < < < < < < < < < < < < < | 5 1111 1110 1000 0000 abs16 imm8 | | | BSET imm8,(abs32) | mem8(abs32)->TMP[7:0],<br>0x000000->TMP[31:8],<br>TMP&(sign_ext)imm8:EPSW,<br>(TMP (zero_ext)imm8)[7:0]<br>->mem8(abs32) | 0 0 0 | ✓ | 7 1111 1110 0000 0000 abs32 imm8 | | BCLR | BCLR Dm,(An) | mem8(An)->TMP[7:0],<br>0x000000->TMP[31:8],<br>TMP&Dn:EPSW,<br>(TMP&(Dn^0xFFFFFFF))[7:0]<br>->mem8(An) | 0 0 0 | | 2 1111 0000 1001 DmAn | | | BCLR imm8,(d8,An) | mem8(An+(sign_ext)d8)->TMP[7:0],<br>0x000000->TMP[31:8],<br>TMP&(sign_ext)imm8: EPSW,<br>(TMPI((zero_ext)imm8^0xFFFFFFF)[7:0] | 0 0 | √ | 4 1111 1010 1111 01An d8 imm8 | | | BCLR imm8,(abs16) | mem8((zero_ext)abs16)->TMP[7:0],<br>0x000000->TMP[31:8],<br>TMP&(sign_ext)imm8 : EPSW,<br>(TMPI((zero_ext)imm8^0xFFFFFFFF))[7:0]<br>->mem8((zero_ext)abs16) | 0 0 0 | 2 | i 1111 1110 1000 0001 abs16 imm8 | | | BCLR imm8,(abs32) | mem8(abs32)->TMP[7:0], 0x000000->TMP[31:8], TMP&(sign_ext)imm8:EPSW, (TMPI((zero_ext)imm8^0xFFFFFFF)[7:0] ->mem8(abs32) | 0 0 0 | ∇ | 1111 1110 0000 0001 abs32imm8 | | | | : | Flag | | about . | Г | |-----|----------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------|---| | | Mnemonic | Operation | VF CF NF ZF | FIZF S | Size Machine Code | | | | | | | | | | | ASR | Dm,Dn | IF((Dm&0x0000001F)i=0),Dn[0]->EPSW.C, ? (Dn>>(Dm&0x0000001F))(sign_ext)->Dn, else shift operation is not performed | Δ? Δ? | < □ | 2 1111 0010 1011 DmDn | | | ASR | Rm,Rn | N.C,<br>∵Rn, | √ | 4 | 3 1111 1001 0100 1001 Rm Rn | | | ASR | Rm,Rn,Rd | V.C,<br>VRd, | ∇ V V E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E E <p< td=""><td>4</td><td>4 1111 1011 0100 1101 Rm Rd</td><td></td></p<> | 4 | 4 1111 1011 0100 1101 Rm Rd | | | ASR | imm8,Dn | ≻Dn, | | ⊲ | 3 1111 1000 1100 10Dn imm8 | | | ASR | imm8,Rn | ≻Rn, | ∇ ∇ V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V V <p< td=""><td>◁</td><td>4 1111 1011 0100 1001 Rn Rm imm8</td><td></td></p<> | ◁ | 4 1111 1011 0100 1001 Rn Rm imm8 | | | ASR | imm24,Rn | ->Rn | | ⊲ | 6 1111 1101 0100 1001 Rn Rm imm24 | | | ASR | imm32,Rn | ->Rn | ∇ ∇ 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 <p< td=""><td>⊲</td><td>7 1111 1110 0100 1001 Rn Rm imm32</td><td></td></p<> | ⊲ | 7 1111 1110 0100 1001 Rn Rm imm32 | | | LSR | Dm,Dn | | ∇ <i>i</i> /∇ <i>i</i> | 4 | 2 1111 0010 1010 DmDn | | | LSR | Rm,Rn | | ∇ | 4 | 3 1111 1001 0101 1001 Rm Rn | | | LSR | Rm,Rn,Rd | | ∇ | <b>4</b> | 4 1111 1011 0101 1101 Rm Rd | | | Machine Code | | · | n imm8 | n. imm24 | n. imm32 | | Ü | n. Rd | | n imm8 | n. imm24 | n. imm32 | | |--------------|------|-----------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|----------------------------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------|-------------| | Code | Size | 3 1111 1000 1100 01Dn imm8 | 4 1111 1011 0101 1001 Rn Rm imm8 | 6 1111 1101 0101 1001 Rn. Rm imm24 | 7 1111 1110 0101 1001 Rn Rm imm32. | 2 1111 0010 1001 DmDn | 3 1111 1001 0110 1001 Rm. Rn. | 4 1111 1011 0110 1101 Rm Rn Rd. | 3 1111 1000 1100 00Dn imm8 | 4 1111 1011 0110 1001 Rn Rm imm8 | 6 1111 1101 0110 1001 Rn Rm imm24 | 7 1111 1110 0110 1001 Rn Rm imm32 | 1 0101 01Dn | | Flag | | V V V V V | Δ? Δ | \times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\times_\t | Δ? Δ | ∇<br>∇<br>¿ | ∇<br>∇<br>¿ | ∇<br>∇<br>¿ | ∇<br>∇<br>¿ | ∇<br>∇<br>¿ | ∇ ∇ ¿ | ∇<br>∇<br>¿ | < < | | Operation | > | IF((imm8&0x0000001F)!=0), Dn[0]->EPSW.C, (Dn>>(imm8&0x0000001F))(zero_ext)->Dn, else shift operation is not performed | ?<br>>Rn, | <i>~</i> | ?<br>t)->Rn, | IF((Dm&0x00001F)!=0), (Dn<<(Dm&0x00001F))->Dn else shift operation is not performed | IF((Rm&0x00001F)!=0), ? (Rn<<(Rm&0x00001F))->Rn else shift operation is not performed | IF((Rm&0x00001F)!=0), ? (Rn<<(Rm&0x00001F))->Rd else shift operation is not performed | ن<br>وم | IF((imm8&0x00001F)!=0), (Rn<<(imm8&0x00001F))->Rn, imm=0 shift operation is not performed | IF((imm24&0x00001F)!=0), (Rn<<(imm24&0x00001F))->Rn, imm=0 shift operation is not performed | ;<br>med | Dn<<2->Dn | | Mnemonic | | LSR imm8,Dn | LSR imm8,Rn | LSR imm24,Rn | LSR imm32,Rn | ASL Dm,Dn | ASL Rm,Rn | ASL Rm,Rn,Rd | ASL imm8,Dn | ASL imm8,Rn | ASL imm24,Rn | ASL imm32,Rn | ASI 2 Dn | | Group | | LSR | | | <b>-1</b> | ASL A | | | | | | 1 | ASI 2 | | | | | | l | | | |-------|------|----------|------------------------------------------------------------|----------------------------|-------------------------------|--| | Group | | Mnemonic | Operation | Flag Code<br>VFCFNFZF Size | Code Machine Code Size | | | | | | | | | | | ASL2 | ASL2 | Rn | Rn<<2->Rn | 2 2 4 | 3 1111 1001 0111 1001 Rm Rn | | | ROR | ROR | Dn | {EPSW.C,Dn[31:0]}->{Dn[31:0],EPSW.C} | 0 0 0 0 | 2 1111 0010 1000 01Dn | | | | ROR | Rn | {EPSW.C,Rn[31:0]}->{Rn[31:0],EPSW.C} | 0 2 2 2 | 3 1111 1001 1000 1001 Rm Rn | | | ROL | ROL | Dn | {Dn[31:0],EPSW.C}->{EPSW.C,Dn[31:0]} | 0 4 4 4 | 2 1111 0010 1000 00Dn | | | | ROL | Rn | {Rn[31:0],EPSW.C}->{EPSW.C,Dn[31:0]} | V V V 0 | 3 1111 1001 1001 1001 Rm Rn | | | Bcc | BEQ | label | IF(Z=1orZFlagSet), | 1 1 | 2 1100 1000 d8 | | | | | | PC+((sign_ext)d8)->nPC,<br> else PC+CodeSize->nPC | | | | | | BNE | label | IF(Z!=1orZFlagCleared), | 1 1 | 2 1100 1001 d8 | | | | | | PC+((sign_ext)d8)->nPC, | | | | | | | | eise PC+CodeSize-VIPC | | 0770000077 | | | | | label | IF(~(Z (N^V))), | 1 1 | Z 1100 0001 d8 | | | | | | PC+((sign_ext)ds)->nPC,<br>else PC+CodeSize->nPC | | | | | | BGE | label | IF(~(N^V)),PC+((sign_ext)d8)->nPC, | 1 1 | 2 1100 0010 d8 | | | | | | else PC+CodeSize->nPC | | | | | | BLE | label | IF(Z (N^V)),PC+((sign_ext)d8)->nPC, | 1 1 | 2 1100 0011 d8 | | | | | | else PC+CodeSize->nPC | | | | | | BLT | label | IF(N^V),PC+((sign_ext)d8)->nPC, else<br> PC+CodeSize->nPC | 1 1 1 | 2 1100 0000 d8 | | | | BHI | label | IF(~(C Z)),PC+((sign_ext)d8)->nPC, | 1 | 2 1100 0101 d8 | | | | | | else PC+CodeSize->nPC | | | | | | ВСС | label | IF(~C),PC+((sign_ext)d8)->nPC,<br>else PC+CodeSize->nPC | 1 1 1 | 2 1100 0110 d8 | | | | BLS | label | IF(C Z),PC+((sign_ext)d8)->nPC, else PC+CodeSize->nPC | 1 1 | 2 1100 0111 d8 | | | | BCS | label | IF(C),PC+((sign_ext)d8)->nPC, | 1 1 | 2 1100 0100 d8 | | | | BVC | label | IF(~V),PC+((sign_ext)d8)->nPC, | 1 | 3 1111 1000 1110 1000 d8 | | | | | | else PC+CodeSize->nPC | | | | | | BVS | label | IF(V),PC+((sign_ext)d8)->nPC, | 1 1 | 3 1111 1000 1110 1001 d8 | | | | | | else PC+CodeSize->nPC | | | | | | BNC | label | IF(~N),PC+((sign_ext)d8)->nPC, | 1 1 | 3 1111 1000 1110 1010 d8 | | | | | - | else PC+CodeSize->nPC | | | | | | BNS | label | IF(N),PC+((sign_ext)d8)->nPC,<br>else PC+CodeSize->nPC | 1 1 | 3 1111 1000 1110 1011 d8 | | | | BRA | label | PC+((sign_ext)d8)->nPC | 1 1 | 2 1100 1010 d8 | | | | | | | - | | | | Group | Mnemonic | Operation | Flag Code | Code | Machine Code | |----------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------|-----------------------------| | 1 | | | | | | | $\vdash$ | LEQ | IF(Z),LAR-4->nPC,else PC+1->nPC | | 1 1101 1000 | | | | LNE<br>HNI | IF(~Z),LAR-4->nPC,else PC+1->nPC | 1 | 1 1101 1001 | | | | LGT | IF(~(Z (N^V)),LAR-4->nPC,<br>else PC+1->nPC | 1 1 | 1 1101 0001 | | | 1 | LGE | IF(~(N^V)),LAR-4->nPC,<br>else PC+1->nPC | 1 1 | 1 1101 0010 | | | | LLE | IF(Z (N^V)),LAR-4->nPC,<br>else PC+1->nPC | 1 1 | 1 1101 0011 | | | | LLT | IF(N^V),LAR-4->nPC,else PC+1->nPC | 1 | 1 1101 0000 | | | | 핌 | IF(~(C Z)),LAR-4->nPC,<br>else PC+1->nPC | 1 | 1 1101 0101 | | | | LCC | IF(~C),LAR-4->nPC,else PC+1->nPC | 1 | 1 1101 0110 | | | | LLS | IF(C Z),LAR-4->nPC,else PC+1->nPC | | 1 1101 0111 | | | | rcs | IF(C),LAR-4->nPC,else PC+1->nPC | | 1 1101 0100 | | | - | LRA | LAR-4->nPC | | 1 1101 1010 | | | SETLB | SETLB | set loop buffer | - | 1 1101 1011 | | | ب | JMP (An) | An->nPC | | | 01An | | ت | JMP label(d16,PC) | PC+((sign_ext)d16)->nPC | | | | | | JMP label(d32,PC) | PC+d32->nPC | 1 | 5 1101 1100 d32 | Ε | | CALL | CALL (d16,PC),regs,imm8 | PC+(sign_ext)d16->nPC,PC+CodeSize->(SP),<br>PC+CodeSize->MDR, | 1 1 | 5 1100 1101 d16 regs imm8. | regs imm8 | | | | Multiple address specified by regs-><br>Lower address memory following(SP-1),<br>SP-(zero_ext)imm8->SP | | | | | | CALL (d32,PC),regs,imm8 | | 1 | 7 1101 1101 d32. | 7 1101 1101 d32 regs imm8 | | | | Industrial By registration of registration of registration of the second | | | | | (0 | CALLS CALLS (An) | An->nPC,PC+CodeSize->mem32(SP), PC+CodeSize->MDR | 1 | 2 1111 0000 1111 00An | 00An | | | CALLS (d16,PC) | PC+((sign_ext)d16)->nPC,<br>PC+CodeSize->(SP),PC+CodeSize->MDR | 1 1 | 4 1111 1010 1111 1111 d16 | 1111 d16 | | | CALLS (d32,PC) | PC+d32->nPC,<br>PC+CodeSize->(SP),PC+CodeSize->MDR | 1 1 | 6 1111 1100 1111 1111 d32 | 1111 d32 | | Group | Mnemonic | ပ | Operation | Flag | Code | Machine Code | |---------|---------------|----------|---------------------------------------------------------------------------|---------------|--------|----------------------------------| | _ 1 | | | | VFCFNFZF Size | F Size | | | | | | | | | | | | RET | | (SP+(zero_ext)imm8)->nPC, | 1 | 3 | 1101 1111 regs imm8 | | | | | Multiple registers specified by regs, SP+(zero_ext)imm8->SP | | | | | 1 | RETE RETE | | MDR->nPC(next instruction PC), | 1 | က | 1101 1110 regs imm8 | | | | | Lower address memory following(SP-1)-> | | | | | | | | Multiple registers specified by regs, SP+(zero_ext)imm8->SP | | | | | 100 | RETS RETS | | mem32(SP)->nPC | ' | - 2 | 1111 0000 1111 1100 | | | RTI | | mem32(SP)->EPSW,mem32(SP+4)->nPC, | 1 | 7 | 1111 0000 1111 1101 | | | TDAD | | JF+8-52F<br>JTBB[34:24] 0×0000101-5nBC | | 0 | 1111 0000 1111 1110 | | n | TRAP I RAP | | { DR[S .24],0x0000 0}-7 FC,<br> PC+CodeSize->mem32(SP) | 1 | | | | NOP | NOP | | PC+CodeSize->nPC | 1 | | 1100 1011 | | SYSCALL | SYSCALL imm4 | 14 | PC->mem32(SP),EPSW->mem32(SP-4), | | 2 | 1111 0000 1110 imm4 | | | | | SP-8->SP, | | | | | - 1 | | | {1BR[31:24],(0x00300 imm4x8)}->nPC | | | | | | 础 | | PC->mem32(SP-4),EPSW->mem32(SP-8),<br>SP-8->SP,{TBR[31.24],0x000008}->nPC | 1 1 | | 111111 | | T . | DMULH RM,Rn | ,Rn | (sign_ext)Rm[31:16])*((sign_ext)Rn[31:16]) | | က | 1111 1001 1000 1011 Rm Rn | | | | | -7mD/C,<br>((sign_ext)Rm[15:0]*((sign_ext)Rn[15:0])<br>->Rn | 1 | | | | | рмигн | | (sign_ext)Rm[31:16])*((sign_ext)Rn[31:16])<br>->Rd1. | | 4 | 1111 1011 1000 1111 Rm Rd1. Rd2. | | | Rm,Rn,Rd1,Rd2 | | ((sign_ext)Rm[15:0]*((sign_ext)Rn[15:0])<br>->Rn2 | 1 | | | | | mmi H INMO | imm32 Rn | (sign_ext)imm32[31:16])*((sign_ext)Rn[31:16])<br>->MDRO | | _ | 1111 1110 1000 1011 Rn Rm imm32 | | | | <u>.</u> | ((sign_ext)imm32[15:0]*((sign_ext)Rn[15:0])<br>->Rn | 1 | | | | DMULHU | | | ((zero_ext)Rm[31:16])*((zero_ext)Rn[31:16])<br>->MDRQ, | | က | 1111 1001 1001 1011 Rm Rn | | | DMULHU Rm | Rm,Rn | ((zero_ext)Rm[15:0])*((zero_ext)Rn[15:0]) | | | | | | | | ->Kn | ·<br>· | | | Operation Mnemonic Group Machine Code | 2012 | 16])*((zero_ext)Rn[31:16]) - | | 1:16])*((zero_ext)Rn[31:16]) 7 11111111010011011 Rn Rm imm32 | | 16]*(sign_ext)Rn[15:0]) 3 1111 1001 0110 1011 Rm Rn<br>5:0]*(sign_ext)Rn[15:0]) | 16]*(sign_ext)Rn[15:0]) | 1 1 | 16]*(zero_ext)Rn[15:0]) 3 1111 1001 0111 1011 Rm Rn<br>5:0]*(zero_ext)Rn[15:0]) | 16]*(zero_ext)Rn[15:0]) | 31:16]*(zero_ext)Rn[15:0]) 7 11111110011110 Rn imm32 | 1111 | - - - 4 1111 | *Rn)+{MCRH,MCRL}-> - - - 4 1111 1011 0000 1011 Rnimm8 | |------|-------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------|--------------------------------------------------------------| | OIZE | | | | | | 4 | | | 4 | _ | 3 1111 | 4 1111 | 4 | | - | | | | | | | | | | | | - | 1 | | 5 | | | | | | | | | | 1 | | | ı | | • | ((zero_ext)Rm[31:16])*((zero_ext)Rn[31:16])<br>->Rd1, | ((zero_ext)Rm[15:0])*((zero_ext)Rn[15:0])<br>->Rd2 | | ((zero_ext)imm32[15:0])*((zero_ext)Rn[15:0])<br>->Rn | ((sign_ext)Rm[31:16]*(sign_ext)Rn[31:16])<br>+((sign_ext)Rm[15:0]*(sign_ext)Rn[15:0])<br>+MCRL->MCRL | ((sign_ext)Rm[31:16]*(sign_ext)Rn[31:16]) | ((sign_ext)imm32[31:16]*(sign_ext)Rn[31:16])<br>+((sign_ext)imm32[15:0]*(sign_ext)Rn[15:0])<br>+MCRL->MCRL | ((zero_ext)Rm[31:16]*(zero_ext)Rn[31:16])<br>+((zero_ext)Rm[15:0]*(zero_ext)Rn[15:0])<br>+MCRL->MCRL | ((zero_ext)Rm[31:16]*(zero_ext)Rn[31:16]) | ((zero_ext)imm32[31:16]*(zero_ext)Rn[31:16])<br>+((zero_ext)imm32[15:0]*(zero_ext)Rn[15:0])<br>+MCRL->MCRL | (Rm*Rn)+{MCRH,MCRL}->{MCRH,MCRL} | | ((sign_ext)imm8*Rn)+{MCRH,MCRL}-> -<br> {MCRH.MCRL} | | | DMULHU BMULHU Rm,Rn,Rd1,Rd2 | | DMULHU imm32,Rn | | DMACH DMACH Rm,Rn | DMACH Rm,Rn,Rd | DMACH imm32,Rn | DMACHU Rm,Rn | DMACHU Rm,Rn,Rd | DMACHU imm32,Rn | MAC Rm,Rn | MAC Rm,Rn,Rd1,Rd2 | MAC imm8,Rn | | | ОМИГНИ | | | | <b>DMACH</b> | | | DMACHU | | | MAC | | | | Machine Code | 6 1111 1101 0000 1011 Rn imm24 | 1011 Rn imm32 | 1011 Rm Rn | 1111 1011 0001 1111 Rm Rn Rd1. Rd2. | 1111 1011 0001 1011 Rn imm8 | 6 1111 1101 0001 1011 Rn imm24 | 7 1111 1110 0001 1011 Rn imm32 | 1011 Rm Rn | 4 1111 1011 0100 1111 Rm Rn Rd1. Rd2. | 4 1111 1011 0100 1011 Rn imm8 | 6 1111 1101 0100 1011 Rn imm24 | 7 1111 1110 0100 1011 Rn imm32 | 1011 Rm Rn | 1111 1011 0101 1111 Rm Rn Rd1. Rd2. | 1111 1011 0101 1011 Rn imm8 | 11111101 0101 1011 Rn imm24 | 1111 1110 0101 1011 Rn imm32 | 1011 Rm Rn | 4 1111 1011 0010 1111 Rm Rn Rd | |--------------|--------------------------------------------------------|-----------------------------------------|----------------------------------|-------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------|----------------------------------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------------------|-------------------------------------------| | Code ZF Size | - 6 111111010000 | - 7 1111111000001011 | - 3 1111 1001 0001 1011 Rm Rn. | - 4 1111 1011 0001 | - 4 111110110001 | - 6 111111010001 | - 7 111111100001 | - 3 1111 1001 0100 1011 Rm Rn. | - 4 111110110100 | - 4 111110110100 | - 6 111111010100 | - 7 111111100100 | - 3 1111 1001 0101 1011 Rm Rn | - 4 1111101101010 | - 4 11111011010101 | - 6 111111010101 | - 7 111111100101 | - 3 1111 1001 0010 1011 Rm Rn. | - 4 1111 1011 0010 | | Flag Code | 1 | | 1 | Δ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | 1 | 1 | | | Operation | ((sign_ext)imm24*Rn)+{MCRH,MCRL}-> - {MCRH,MCRL}-> | (imm32*Rn)+{MCRH,MCRL}->{MCRH,MCRL} - | (Rm*Rn)+{MCRH,MCRL}->{MCRH,MCRL} | | ((zero_ext)imm8*Rn)+{MCRH,MCRL}-> -{MCRH,MCRL}- | ((zero_ext)imm24*Rn)+{MCRH,MCRL}-> -{MCRH,MCRL} | (imm32*Rn)+{MCRH,MCRL}->{MCRH,MCRL} | (((sign_ext)Rm[15:0])*((sign_ext)Rn[15:0])) -<br>+{MCRH,MCRL}->{MCRH,MCRL} | (((sign_ext)Rm[15:0])*((sign_ext)Rn[15:0])) | (((sign_ext)imm8[15:0])*((sign_ext)Rn[15:0]))-<br>+{MCRH,MCRL}->{MCRH,MCRL} | (((sign_ext)imm24[15:0])*((sign_ext)Rn[15:0]))<br>+{MCRH.MCRL}->{MCRH.MCRL} | ((imm32[15:0])*((sign_ext)Rn<br>[15:0])+{MCRH,MCRL}>{MCRH,MCRL} | (((zero_ext)Rm[15:0])*((zero_ext)Rn[15:0])) -<br>+{MCRH,MCRL}->{MCRH,MCRL} | | (((zero_ext)imm8[15:0])*((zero_ext)Rn[15:0]))<br>+{MCRH,MCRL}->{MCRH,MCRL} | (((zero_ext)imm24[15:0])*((zero_ext)Rn[15:0]))<br>+{MCRH,MCRL}->{MCRH,MCRL} | ((imm32[15:0])*((zero_ext)Rn<br>[15:0]))+{MCRH,MCRL}>{MCRH,MCRL} | (((sign_ext)Rm[7:0])*((sign_ext)Rn[7:0])) +<br>HMCRL->MCRL | (((sign_ext)Rm[7:0])*((sign_ext)Rn[7:0])) | | Mnemonic | MAC imm24,Rn | MAC imm32,Rn | MACU Rm,Rn | MACU Rm,Rn,Rd1,Rd2 | MACU imm8,Rn | MACU imm24,Rn | MACU imm32,Rn | MACH Rm,Rn | MACH Rm,Rn,Rd1,Rd2 | MACH imm8,Rn | MACH imm24,Rn | MACH imm32,Rn | MACHU Rm,Rn | MACHU Rm,Rn,Rd1,Rd2 | MACHU imm8,Rn | MACHU imm24,Rn | MACHU imm32,Rn | MACB Rm,Rn | MACB MACB Rm,Rn,Rd | | Group | MAC N | _ | MACU | _ | | | | масн масн | | _ | <u></u> | _ | MACHU | | <u> </u> | <u> </u> | <u></u> | | MACB | | | | | Ē | C | | |-------|-------------------|--------------------------------------------------------------------------------------------|---------------|-----------------|----------------------------------| | Group | Mnemonic | Operation | VFCFNFZF Size | Code<br>ZF Size | Machine Code<br>e | | | | | | | | | MACB | MACB imm8,Rn | (((sign_ext)imm8[7:0])*((sign_ext)Rn[7:0])) -<br>+MCRL->MCRL | 1 1 | ı | 4 1111 1011 0010 1011 Rn imm8 | | | MACB imm24,Rn | (((sign_ext)imm24[7:0])*((sign_ext)Rn[7:0])) -<br>+MCRL->MCRL | 1 | ı | 6 1111 1101 0010 1011 Rn imm24 | | | MACB imm32,Rn | (((sign_ext)imm32[7:0])*((sign_ext)Rn[7:0])) -<br>+MCRL->MCRL | 1 | ı | 7 1111 1110 0010 1011 Rn imm32 | | MACBU | MACBU RM,Rn | (((zero_ext)Rm[7:0])*((zero_ext)Rn[7:0]))<br>+MCRL->MCRL | 1 | 1 | 3 1111 1001 0011 1011 Rm. Rn | | | MACBU Rm,Rn,Rd | (((zero_ext)Rm[7:0])*((zero_ext)Rn[7:0]))<br>+Rd->Rd | - V | 1 | 4 1111 1011 0011 1111 Rm Rn Rd | | | MACBU imm8,Rn | (((zero_ext)imm8[7:0])*((zero_ext)Rn[7:0]))<br>+MCRL->MCRL | 1 1 | 1 | 4 1111 1011 0011 1011 Rnimm8 | | | MACBU imm24,Rn | (((zero_ext)imm24[7:0])*((zero_ext)Rn[7:0]))-<br>+MCRL->MCRL | - | 1 | 6 1111 1101 0011 1011 Rn imm24 | | | MACBU imm32,Rn | (((zero_ext)imm32[7:0])*((zero_ext)Rn[7:0]))-<br>+MCRL->MCRL | 1 | 1 | 7 1111 1110 0011 1011 Rn imm32 | | SWHW | SWHW SWHW Rm,Rn | Rm[31:16]->Rn[15:0],Rm[15:0]->Rn[31:16] | 1 | | 3 1111 1001 1110 1011 Rm. Rn | | SWAP | SWAP SWAPRm,Rn | Rm[31.24]->Rn[7:0],Rm[23:16]->Rn[15:8],<br>Rm[15:8]->Rn[23:16],Rm[7:0]->Rn[31:24] | 1 | 1 | 3 1111 1001 1100 1011 Rm Rn | | SWAPH | SWAPH SWAPH Rm,Rn | Rm[31:24]->Rn[23:16],Rm[23:16]->Rn[31:24],<br>Rm[15:8]->Rn[7:0],Rm[7:0]->Rn[15:8] | 1 1 | 1 | 3 1111 1001 1101 1011 Rm. Rn | | SAT16 | SAT16 SAT16Rm,Rn | if(Rm>=0x7FFF)then 0x7FFF->Rn,<br>else if(Rm<=0xFFF8000)then<br>0xFFF8000->Rn.else Rm>Rn | ∇ ¿ ¿ | ◁ | 3 1111 1001 1010 1011 Rm Rn | | SAT24 | SAT24 SAT24Rm,Rn | if(Rm>=0x7FFFFF)then 0x7FFFFF->Rn, else if(Rm<=0xFF800000)then 0xFF800000->Rn,else Rm,->Rn | | ⊲ | 4 1111 1011 1010 1111 Rm Rn | | MCSTE | MCSTE MCSTE Rm,Rn | See "MCSTE" page | 0/1 0 3 | خ | 3 1111 1001 1011 1011 Rm Rn | | | MCSTE imm8,Rn | See "MCSTE" page | 0/1 0 3 | ر. | 4 1111 1011 1011 1011 Rn imm8 | | BSCH | BSCH BSCH Rm,Rn | See "BSCH" page | | ۲. | 3 1111 1001 1111 1011 Rm. Rn | | | BSCH Rm,Rn,Rd | See "BSCH" page | ? 0/1 ? | <i>ر</i> . | 4 1111 1011 1111 1111 Rm Rn Rd | | Group | Mnemonic | Operation | Flag Code VFCFNFZF Size | Flag | ZFS | Code | Machine Code | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | L K | ADD ADD Rm1,Rn1,Rm2,Rn2 ADD ADD Rm1,Rn1,Imm4,Rn2 ADD SUB Rm1,Rn1,Imm4,Rn2 ADD SUB Rm1,Rn1,Imm4,Rn2 ADD CMP Rm1,Rn1,Imm4,Rn2 ADD CMP Rm1,Rn1,Imm4,Rn2 ADD CMP Rm1,Rn1,Imm4,Rn2 ADD ASR Rm1,Rn1,Imm4,Rn2 ADD ASR Rm1,Rn1,Imm4,Rn2 ADD ASR Rm1,Rn1,Imm4,Rn2 ADD ASR Rm1,Rn1,Imm4,Rn2 ADD ASR Rm1,Rn1,Imm4,Rn2 ADD ASL Imm4,Rn1,Rm2,Rn2 ADD SUB Imm4,Rn1,Imm4,Rn2 ASR Imm4,Rn1,Imm4,Rn2 ADD ASR Imm4,Rn1,Imm4,Rn2 ADD ASR Imm4,Rn1,Imm4,Rn2 ADD ASR Imm4,Rn1,Imm4,Rn2 ADD ASR Imm4,Rn1,Imm4,Rn2 CMP ADD Rm1,Rn1,Imm4,Rn2 CMP ADD Rm1,Rn1,Imm4,Rn2 CMP SUB MON Rm1,Rn1,Imm4,Rn2 CMP MON Rm1,Rn1,Imm4,Rn2 CMP MON Rm1,Rn1,Imm4,Rn2 CMP MON Rm1,Rn1,Imm4,Rn2 | Rm1+Rn1->Rn1 with Rm2+Rn2->Rn2 Rm1+Rn1->Rn1 with Rm2+Rn2->Rn2 Rm1+Rn1->Rn1 with Rn2-Rm2->Rn2 Rm1+Rn1->Rn1 with Rn2-Sim2->Rn2 Rm1+Rn1->Rn1 with Rn2-Sim2->Rn2 Rm1+Rn1->Rn1 with Rn2-Sign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2-Sign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2-Sign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2->Rn2 Rm1+Rn1->Rn1 with Rn2->Cign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2->Cign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2->Cign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2->Cign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2->Cign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2->Cign ext)imm4->Rn2 Rm1+Rn1->Rn1 with Rn2->Rn2 Rm1+Rn1->Rn1 with Rn2->Rn2 Rigin ext)imm4-Rn1->Rn1 Rn1-Rm1:EPSWJwith | | | | A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A A | 1111 0111 0000 0000 Rm1. Rn1. Rm2. Rn2. 1111 0111 0010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 0010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 01010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 0110 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 0110 0000 Rm1. Rn1. Rm2. Rn2. 1111 0111 0110 0000 Rm1. Rn1. Rm2. Rn2. 1111 0111 0110 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 1010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 1010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 1010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 1010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 1010 0000 Rm1. Rn1. imm4 Rn2. 1111 0111 1010 0000 Imm4 Rn1. imm4 Rn2. 1111 0111 0101 0100 imm4 Rn1. imm4 Rn2. 1111 0111 0101 0100 imm4 Rn1. imm4 Rn2. 1111 0111 0101 0100 imm4 Rn1. imm4 Rn2. 1111 0111 0110 0100 imm4 Rn1. imm4 Rn2. 1111 0111 0110 0100 imm4 Rn1. imm4 Rn2. 1111 0111 1010 0100 imm4 Rn1. imm4 Rn2. 1111 0111 1010 0100 imm4 Rn1. imm4 Rn2. 1111 0111 1010 0100 imm4 Rn1. imm4 Rn2. 1111 0111 1010 0100 imm4 Rn1. imm4 Rn2. 1111 0111 1010 0100 imm4 Rn1. imm4 Rn2. 1111 0111 1011 0000 0001 Rm1. Rn1. imm4 Rn2. 1111 0111 1011 0000 0001 Rm1. Rn1. imm4 Rn2. 1111 0111 0111 0001 0001 Rm1. Rn1. imm4 Rn2. 1111 0111 0111 0001 0001 Rm1. Rn1. imm4 Rn2. 1111 0111 0111 0001 0001 Rm1. Rn1. imm4 Rn2. 1111 0111 0111 0001 0001 Rm1. Rn1. imm4 Rn2. 1111 0111 0111 0110 0001 Rm1. Rn1. imm4 Rn2. | | | CMP_ASR Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1:EPSW]with Rn2>>Rm2->Rn2 | 1 | 1 | - | 4 | 1111 0111 1000 0001 Rm1. Rn1. Rm2. Rn2. | imm4\*1:1st operand imm4\*2:3rd operand | Group | p Mnemonic | Operation | Flag Code | Code<br>ZF Size | Machine Code | |-------|----------------------------|------------------------------------------------------------|---------------------------------|-----------------|-----------------------------------------| | | - | | | | | | ΜI | CMP ASR Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1:EPSW]with Rn2>>(zero_ext)imm4->Rn2 | | - 4 | 1111 0111 1001 0001 Rm1. Rn1. imm4 Rn2. | | | CMP LSR Rm1, Rn1, Rm2, Rn2 | [Rn1-Rm1:EPSW]with Rn2>>Rm2->Rn2 | 1 | 4 | 1111 0111 1010 0001 Rm1. Rn1. Rm2. Rn2. | | | CMP_LSR Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1:EPSW]with Rn2>>(zero_ext)imm4->Rn2 | | 4 | | | | CMP ASL Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1:EPSW]with Rn2< <rm2->Rn2</rm2-> | | - 4 | 1111 0111 1100 0001 Rm1. Rn1. Rm2. Rn2. | | | CMP ASL Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1:EPSW]with Rn2<<(zero_ext)imm4->Rn2 | 1 | - 4 | 1111 0111 1101 0001 Rm1. Rn1. imm4 Rn2. | | | CMP ADD imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4:EPSW]with Rm2+Rn2->Rn2 | | 4 | 1111 0111 0000 0101 imm4 Rn1. Rm2. Rn2. | | | CMP ADD imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1:EPSW]with (sign_ext)imm4*2+Rn2->Rn2 | | 4 | 1111 0111 0001 0101 imm4 Rn1. imm4 Rn2. | | | CMP_SUB imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4:EPSW]with Rn2-Rm2->Rn2 | $ \Delta \Delta \Delta $ | 4 | 1111 0111 0010 0101 imm4 Rn1. Rm2. Rn2. | | | CMP_SUB imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1:EPSW]with Rn2-(sign_ext)imm4*2->Rn2 | $\Delta \Delta \Delta = \Delta$ | 4 4 | 1111 0111 0011 0101 imm4 Rn1. imm4 Rn2. | | | CMP_MOV imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4:EPSW]with Rm2->Rn2 | $\Delta \Delta \Delta$ | 4 | 1111 0111 0110 0101 imm4 Rn1. Rm2. Rn2. | | | CMP_MOV imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*¹:EPSW]with (sign_ext)imm4*²->Rn2 | | 4 | 1111 0111 0111 0101 imm4 Rn1. imm4 Rn2. | | | CMP_ASR imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4:EPSW]with Rn2>>Rm2->Rn2 | $\Delta \Delta \Delta = \Delta$ | 4 4 | 1111 0111 1000 0101 imm4 Rn1. Rm2. Rn2. | | | CMP_ASR imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1:EPSW]with Rn2>>(sign_ext)imm4*2->Rn2 | $\Delta$ $\Delta$ | 4 | 1111 0111 1001 0101 imm4 Rn1. imm4 Rn2. | | | CMP_LSR imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4:EPSW]with Rn2>>Rm2->Rn2 | $\Delta \Delta \Delta$ | 4 | 1111 0111 1010 0101 imm4 Rn1. Rm2. Rn2. | | | CMP_LSR imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1:EPSW]with Rn2>>(zero_ext)imm4*2->Rn2 | $\Delta$ $\Delta$ | 4 | 1111 0111 1011 0101 imm4 Rn1. imm4 Rn2. | | | CMP_ASL imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4:EPSW]with Rn2< <rm2->Rn2</rm2-> | $\nabla \nabla \nabla $ | 4 4 | 1111 0111 1100 0101 imm4 Rn1. Rm2. Rn2. | | | CMP_ASL imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1:EPSW]with Rn2<<(zero_ext)imm4*2->Rn2 | $\Delta$ $\Delta$ | 4 | 1111 0111 1101 0101 imm4 Rn1. imm4 Rn2. | | | SUB_ADD Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1->Rn1]with Rm2+Rn2->Rn2 | | - 4 | | | | SUB_ADD Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1->Rn1]with (sign_ext)imm4+Rn2->Rn2 | 1 | - 4 | | | | SUB_SUB Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1->Rn1]with Rn2-Rm2->Rn2 | | 4 | 1111 0111 0010 0010 Rm1. Rn1. Rm2. Rn2. | | | SUB_SUB Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1->Rn1]with Rn2-(sign_ext)imm4->Rn2 | | - 4 | | | | SUB_CMP Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1->Rn1]with Rn2-Rm2:EPSW | $\Delta$ $\Delta$ | 4 | | | | SUB_CMP Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1->Rn1]with Rn2-(sign_ext)imm4:EPSW | $\Delta$ $\Delta$ | 4 | 1111 0111 0101 0010 Rm1. Rn1. Rm2. Rn2. | | | SUB_MOV Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1->Rn1]with Rm2->Rn2 | 1 | - 4 | | | | SUB_MOV Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1->Rn1]with (sign_ext)imm4->Rn2 | | - 4 | | | | SUB_ASR Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1->Rn1]with Rn2>>Rm2->Rn2 | - | 4 | | | | SUB_ASR Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1->Rn1]with Rn2>>(zero_ext)imm4->Rn2 | | - 4 | | | | SUB_LSR Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1->Rn1]with Rn2>>Rm2->Rn2 | | - 4 | | | | SUB_LSR Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1->Rn1]with Rn>>(zero_ext)imm4->Rn2 | | - 4 | 1111 0111 1011 0010 Rm1. Rn1. imm4 Rn2. | | | SUB_ASL Rm1,Rn1,Rm2,Rn2 | [Rn1-Rm1->Rn1]with Rn2< <rm2->Rn2</rm2-> | | - 4 | | | | SUB_ASL Rm1,Rn1,imm4,Rn2 | [Rn1-Rm1->Rn1]with Rn2<<(zero_ext)imm4->Rn2 | | 7 - | 1111 0111 1101 0010 Rm1. Rn1. imm4 Rn2. | | | SUB_ADD imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4->Rn1]with Rm2+Rn2->Rn2 | - | - 4 | | | | SUB_ADD imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1->Rn1]with (sign_ext)imm4*2+Rn2->Rn2 | | 4 | | | | SUB_SUB imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4->Rn1]with Rn2-Rm2->Rn2 | 1 | - 4 | | | | SUB_SUB imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1->Rn1]with Rn2-(sign_ext)imm4*2->Rn2 | | - | | | | SUB_CMP imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4->Rn1]with Rn2-Rm2:EPSW | $\Delta$ | 4 | 1111 0111 0100 0110 imm4 Rn1. Rm2. Rn2. | imm4\*1:1st operand imm4\*2:3rd operand | Group | Mnemonic | Operation | Flag Code | Flag | ZFS | Code | Machine Code | |-------|-----------------------------|------------------------------------------------------------|---------------------------|-----------------------------------------------------------|----------|------|-----------------------------------------| | | | | | | | | | | ΜI | SUB CMP imm4,Rn1,imm4,Rn2 | [Rn1-(sign ext)imm4*1->Rn1]with Rn2-(sign ext)imm4*2:EPSW | | \[ \begin{array}{c} \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | <b>∇</b> | 4 | 1111 0111 0101 0110 imm4 Rn1. imm4 Rn2. | | | SUB_MOV imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4->Rn1]with Rm2->Rn2 | - | - | ٠ | 4 | 1111 0111 0110 0110 imm4 Rn1. Rm2. Rn2. | | | SUB MOV imm4,Rn1,imm4,Rn2 | Rn1-(sign_ext)imm4*1->Rn1]with (sign_ext)imm4*2->Rn2 | 1 | - | - | 4 | 1111 0111 0111 0110 imm4 Rn1. imm4 Rn2. | | | SUB ASR imm4, Rn1, Rm2, Rn2 | [Rn1-(sign_ext)imm4->Rn1]with Rn2>>Rm2->Rn2 | - | - | - | 4 | 1111 0111 1000 0110 imm4 Rn1. Rm2. Rn2. | | | SUB_ASR imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1->Rn1]with Rn2>>(zero_ext)imm4*2->Rn2 | 1 | - | - | 44 | 1111 0111 1001 0110 imm4 Rn1. imm4 Rn2. | | | SUB_LSR imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4->Rn1]with Rn2>>Rm2->Rn2 | 1 | i | ı | 4 | 1111 0111 1010 0110 imm4 Rn1. Rm2. Rn2. | | | SUB_LSR imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1->Rn1]with Rn>>(zero_ext)imm4*2->Rn2 | 1 | ı | | 4 | 1111 0111 1011 0110 imm4 Rn1. imm4 Rn2. | | | SUB_ASL imm4,Rn1,Rm2,Rn2 | [Rn1-(sign_ext)imm4->Rn1]with Rn2< <rm2->Rn2</rm2-> | - | - | - | 4 | 1111 0111 1100 0110 imm4 Rn1. Rm2. Rn2. | | | SUB_ASL imm4,Rn1,imm4,Rn2 | [Rn1-(sign_ext)imm4*1->Rn1]with Rn2<<(zero_ext)imm4*2->Rn2 | 1 | ı | 1 | 4 | 1111 0111 1101 0110 imm4 Rn1. imm4 Rn2. | | | MOV_ADD Rm1,Rn1,Rm2,Rn2 | [Rm1->Rn1]with Rm2+Rn2->Rn2 | 1 | 1 | - | 4 | 1111 0111 0000 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_ADD Rm1,Rn1,imm4,Rn2 | [Rm1->Rn1]with (sign_ext)imm4+Rn2->Rn2 | - | - | - | 4 | 1111 0111 0001 0011 Rm1. Rn1. imm4 Rn2. | | | MOV_SUB Rm1,Rn1,Rm2,Rn2 | [Rm1->Rn1]with Rn2-Rm2->Rn2 | 1 | 1 | - | 4 | 1111 0111 0010 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_SUB Rm1,Rn1,imm4,Rn2 | [Rm1->Rn1]with Rn2-(sign_ext)imm4->Rn2 | 1 | - | - | 4 | 1111 0111 0011 0011 Rm1. Rn1. imm4 Rn2. | | | MOV_CMP Rm1,Rn1,Rm2,Rn2 | [Rm1->Rn1]with Rn2-Rm2:EPSW | \[ \dag{\pi} | ٥ | ◁ | 4 | 1111 0111 0100 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_CMP Rm1,Rn1,imm4,Rn2 | [Rm1->Rn1]with Rn2-(sign_ext)imm4:EPSW | $\nabla \mid \nabla \mid$ | \[\nabla\] | 7 | 4 | 1111 0111 0101 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_MOV Rm1,Rn1,Rm2,Rn2 | [Rm1->Rn1]with Rm2->Rn2 | 1 | ı | ı | 4 | 1111 0111 0110 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_MOV Rm1,Rn1,imm4,Rn2 | [Rm1->Rn1]with (sign_ext)imm4->Rn2 | 1 | ı | 1 | 4 | 1111 0111 0111 0011 Rm1. Rn1. imm4 Rn2. | | | MOV_ASR Rm1,Rn1,Rm2,Rn2 | [Rm1->Rn1]with Rn2>>Rm2->Rn2 | - | ı | | 4 | 1111 0111 1000 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_ASR Rm1,Rn1,imm4,Rn2 | [Rm1->Rn1]with Rn2>>(zero_ext)imm4->Rn2 | 1 | ı | | 4 | 1111 0111 1001 0011 Rm1. Rn1. imm4 Rn2. | | | MOV_LSR Rm1,Rn1,Rm2,Rn2 | [Rm1->Rn1]with Rn2>>Rm2->Rn2 | 1 | ı | , | 4 | 1111 0111 1010 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_LSR Rm1,Rn1,imm4,Rn2 | [Rm1->Rn1]with Rn2>>(zero_exr)imm4->Rn2 | 1 | ı | 1 | 4 | 1111 0111 1011 0011 Rm1. Rn1. imm4 Rn2. | | | MOV_ASL Rm1,Rn1,Rm2,Rn2 | [Rm1->Rn1]with Rn2< <rm2->Rn2</rm2-> | 1 | ı | , | 4 | 1111 0111 1100 0011 Rm1. Rn1. Rm2. Rn2. | | | MOV_ASL Rm1,Rn1,imm4,Rn2 | [Rm1->Rn1]with Rn2<<(zero_ext)imm4->Rn2 | - | ı | - | 4 | 1111 0111 1101 0011 Rm1. Rn1. imm4 Rn2. | | | MOV_ADD imm4,Rn1,Rm2,Rn2 | [(sign_ext)imm4->Rn1]with Rm2+Rn2->Rn2 | 1 | , | , | 4 | 1111 0111 0000 0111 imm4 Rn1. Rm2. Rn2. | | | MOV_ADD imm4,Rn1,imm4,Rn2 | [(sign_ext)imm4*1->Rn1]with (sign_ext)imm4*2+Rn2->Rn2 | - | - | - | 4 | 1111 0111 0001 0111 imm4 Rn1. imm4 Rn2. | | | MOV_SUB imm4,Rn1,Rm2,Rn2 | [(sign_ext)imm4->Rn1]with Rn2-Rm2->Rn2 | - | - | - | 4 | 1111 0111 0010 0111 imm4 Rn1. Rm2. Rn2. | | | MOV_SUB imm4,Rn1,imm4,Rn2 | [(sign_ext)imm4*1->Rn1]with Rn2-(sign_ext)imm4*2->Rn2 | - | - | - | 4 | 1111 0111 0011 0111 imm4 Rn1. imm4 Rn2. | | | MOV_CMP imm4,Rn1,Rm2,Rn2 | [(sign_ext)imm4->Rn1]with Rn2-Rm2 | $\nabla \mid \nabla \mid$ | Δ , | ∇ | 4 | 1111 0111 0100 0111 imm4 Rn1. Rm2. Rn2. | | | MOV_CMP imm4,Rn1,imm4,Rn2 | [(sign_ext)imm4*1->Rn1]with Rn2-(sign_ext)imm4*2 | $\nabla \mid \nabla \mid$ | ۷ . | <b>∇</b> | 4 | 1111 0111 0101 0111 imm4 Rn1. imm4 Rn2. | | | MOV_MOV imm4,Rn1,Rm2,Rn2 | [(sign_ext)imm4->Rn1]with Rm2->Rn2 | - | - | - | 4 | 1111 0111 0110 0111 imm4 Rn1. Rm2. Rn2. | | | MOV_MOV imm4,Rn1,imm4,Rn2 | [(sign_ext)imm4*1->Rn1]with (sign_ext)imm4*2->Rn2 | - | - | - | 4 | 1111 0111 0111 0111 imm4 Rn1. imm4 Rn2. | | | MOV_ASR imm4,Rn1,Rm2,Rn2 | [(sign_ext)imm4->Rn1]with Rn2>>Rm2->Rn2 | 1 | ı | | 4 | 1111 0111 1000 0111 imm4 Rn1. Rm2. Rn2. | | | MOV_ASR imm4,Rn1,imm4,Rn2 | [(sign_ext)imm4*¹->Rn1]with Rn2>>(sign_ext)imm4*2->Rn2 | - | - | - | 4 | 1111 0111 1001 0111 imm4 Rn1. imm4 Rn2. | | | MOV_LSR imm4,Rn1,Rm2,Rn2 | [(sign_ext)imm4->Rn1]with Rn2>>Rm2->Rn2 | 1 | ı | ı | 4 | 1111 0111 1010 0111 imm4 Rn1. Rm2. Rn2. | | | MOV_LSR imm4,Rn1,imm4,Rn2 | | 1 | ı | | 4 | 1111 0111 1011 0111 imm4 Rn1. imm4 Rn2. | | | MOV_ASL imm4,Rn1,Rm2,Rn2 | [(sign_ext)imm4->Rn1]with Rn2< <rm2->Rn2</rm2-> | | - | - | 4 | 1111 0111 1100 0111 imm4 Rn1. Rm2. Rn2. | | | | | | | | | | imm4\*1:1st operand imm4\*2:3rd operand | Machine Code | |----------------| | | | Code | | ZF | | Flag | | VF | | Operation | | | | Group Mnemonic | imm4\*1:1st operand imm4\*2:3rd operand | Group | Mnemonic | Operation | VFC | Flag | Flag Code | le Machine Code | |-------|-----------------------------------------------------------|------------------------------------------------------------------------------------|-----|--------|-----------|------------------------------------------------------------------------------------| | ΓIM | SWHW_LSR Rm1,Rn1,Rm2,Rn2 | [Rm1[15:0]->Rn1[31:16],Rm1[31:16]->Rn1[15:0]]<br>with Rn2>>Rm2->Rn2 | 1 | 1 | 1 | 4 1111 0111 1010 1011 Rm1. Rn1. Rm2. Rn2. | | | SWHW_LSR Rm1,Rn1,imm4,Rn2 | [Rm1[15:0]->Rn1[31:16],Rm1[31:16]->Rn1[15:0]]<br>with Rn2>>(zero_ext)imm4->Rn2 | 1 | ı | 1 | 4 11110111 1011 1011 Rm1. Rn1. imm4 Rn2. | | | SWHW_ASL Rm1,Rn1,Rm2,Rn2 | [Rm1[15:0]->Rn1[31:16],Rm1[31:16]->Rn1[15:0]]<br>with Rn2< <rm2->Rn2</rm2-> | 1 | 1 | 1 | 4 1111 0111 1100 1011 Rm1. Rn1. Rm2. Rn2. | | | SWHW_ASLRm1,Rn1,imm4,Rn2 | [Rm1[15:0]->Rn1[31:16],Rm1[31:16]->Rn1[15:0]]<br>with Rn2<<(zero ext)imm4->Rn2 | 1 | | , | 4 1111 0111 1101 1011 Rm1. Rn1. imm4 Rn2. | | | SAT16_ADDRm1,Rn1,Rm2,Rn2 | [(SAT16Op.)Rm->Rn]with Rm2+Rn2->Rn2 | 1 | , | 1 | 4 1111 0111 0000 1101 Rm1. Rn1. Rm2. Rn2. | | | SAT16_ADDRm1,Rn1,imm4,Rn2 | [(SAT16Op.)Rm->Rn]with (sign_ext)imm4+Rn2->Rn2 | - | , | - | 4 1111 0111 0001 1101 Rm1. Rn1. imm4 Rn2. | | | SAT16_SUBRm1,Rn1,Rm2,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2-Rm2->Rn2 | 1 | ı | 1 | 4 1111 0111 0010 1101 Rm1. Rn1. Rm2. Rn2. | | | SAT16_SUBRm1,Rn1,imm4,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2-(sign_ext)imm4->Rn2 | 1 | - | , | | | | SAT16_CMPRm1,Rn1,Rm2,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2-Rm2:EPSW | | ∇<br>∇ | ◁ | | | | SAT16_CMPRm1,Rn1,imm4,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2-(sign_ext)imm4:EPSW | | ∇<br>∇ | □ | | | | SAI 16 MOV Rm1, Rn1, Rm2, Rn2 | [(SAT16Op.)Km->Kn]with Km2->KnZ | + | | | | | | SAT16_MOVEM1, Rn1, IMM4, Rn2<br>SAT16_ASR Rm1_Rn1_Rm2_Rn2 | [(SAT16Op.)Km->Kn]with (sign_ext)imm4->Knz<br>[(SAT16Op.)Rm->Rn]with Rn2>>Rm2->Rn2 | | | , , | 4 1111 0111 0111 1101 Rm1. Rn1. Imm4 Rn2.<br>4 1111 0111 1000 1101 Rm1 Rn1 Rn2 Rn2 | | | SAT16_ASRRm1,Rn1,imm4,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2>>(zero_ext)imm4->Rn2 | + | ı | 1 | | | | SAT16_LSRRm1,Rn1,Rm2,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2>>Rm2->Rn2 | - | ı | | 4 1111 0111 1010 1101 Rm1. Rn1. Rm2. Rn2. | | | SAT16_LSRRm1,Rn1,imm4,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2>>(zero_ext)imm4->Rn2 | 1 | | | 4 1111 0111 1011 1101 Rm1. Rn1. imm4 Rn2. | | | SAT16_ASLRm1,Rn1,Rm2,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2< <rm2->Rn2</rm2-> | 1 | 1 | - | 4 1111 0111 1100 1101 Rm1. Rn1. Rm2. Rn2. | | | SAT16_ASLRm1,Rn1,imm4,Rn2 | [(SAT16Op.)Rm->Rn]with Rn2<<(zero_ext)imm4->Rn2 | 1 | ı | | 4 1111 0111 1101 1101 Rm1. Rn1. imm4 Rn2. | | | MOV_LEQ(Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with leq operation | 1 | - | , | | | | MOV_LNE (Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with Ine operation | 1 | 1 | | 4 1111 0111 1110 0000 Rn Rm imm4 1001 | | | MOV_LGT (Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with lgt operation | 1 | | | 4 1111 0111 1110 0000 Rn Rm imm4 0001 | | | MOV_LGE(Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with Ige operation | - | - | - | 4 1111 0111 1110 0000 Rn Rm imm4 0010 | | | MOV_LLE (Rm+,imm4),Rn | | - | - | | 4 1111 0111 1110 0000 Rn Rm imm4 0011 | | | MOV_LLT (Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with IIt operation | 1 | ı | | 4 1111 0111 1110 0000 Rn Rm imm4 0000 | | | | mem32(Rm)->Rn,Rm+4->Rm,with Ihi operation | - | - | | 4 1111 0111 1110 0000 Rn Rm imm4 0101 | | | MOV_LCC(Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with Icc operation | - | - | - | 4 1111 0111 1110 0000 Rn Rm imm4 0110 | | | II | mem32(Rm)->Rn,Rm+4->Rm,with IIs operation | 1 | | | 4 1111 0111 1110 0000 Rn Rm imm4 0111 | | | MOV_LCS (Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with Ics operation | 1 | 1 | | | | | MOV_LRA(Rm+,imm4),Rn | mem32(Rm)->Rn,Rm+4->Rm,with Ira operation | 1 | | - | 4 1111 0111 1110 0000 Rn Rm imm4 1010 | | Group | dp Mnemonic | Operation | Flag Code<br>VFCFINFZF Size | Machine Code | |---------|----------------------------------|-------------------------------------------|-------------------------------------------------------------------------------------------|--------------| | <u></u> | r | | - | | | 7 | UDF00 Dm,Dn (MULQ Dm,Dn) | Dm*Dn->{MDRQ,Dn} | ? S A A 2 1111 0110 0000 DmDn | DmDn | | | UDF00 imm8,Dn (MULQ imm8,Dn) | (sign_ext)imm8*Dn->{MDRQ,Dn} | ? ? $\Delta$ $\Delta$ 3 111110010000 00Dn imm8 | 30Dn imm8 | | | UDF00 imm16,Dn (MULQ imm16,Dn) | (sign_ext)imm16*Dn->{MDRQ,Dn} | ? ? ∆ ∆ 4 1111 1011 0000 00Dn imm16 | 30Dn imm16 | | | UDF00 imm32,Dn (MULQ imm32,Dn) | imm32*Dn->{MDRQ,Dn} | $\left \begin{array}{c cccccccccccccccccccccccccccccccccc$ | 30Dn imm32 | | | UDF01 Dm,Dn (MULQU Dm,Dn) | Dm*Dn->{MDRQ,Dn} | $ \ \ \ \ \ \ \ _{\Delta} \ \ \ _{\Delta} \ \ \ \ \ \ \ \ \ \ \ \ $ | DmDn | | | UDFU01 imm8,Dn (MULQUimm8,Dn) | (zero ext)imm8*Dn->{MDRQ,Dn} | $\begin{vmatrix} ? & ? & \Delta & \Delta \end{vmatrix}$ 3 1111 1001 0001 00Dn imm8 | 30Dn imm8 | | | UDFU01 imm16,Dn (MULQU imm16,Dn) | (zero_ext)imm16*Dn->{MDRQ,Dn} | $\begin{vmatrix} ? & ? & \Delta & \Delta & 4 \end{vmatrix}$ 1111 1011 0001 00Dn imm16. | 00Dn imm16 | | | UDFU01 imm32,Dn (MULQU imm32,Dn) | imm32*Dn->{MDRQ,Dn} | $ig ? ig A ig \Delta ig \Delta ig $ 6 1111 1101 0001 01Dn imm32 | 01Dn imm32 | | | UDF02 Dm,Dn | Satulate Dm({MCRH,MCRL})->Dn | 0/1 0 ? ? 2 111101100010DmDn | DmDn | | | (MCST32 Dn/MCst16 Dn/MCST8 Dn) | | | | | | UDF03 Dm,Dn (MCST9 Dn) | Satulate9(MCRL)->Dn | 0/1 0 ? ? 2 111101100011DmDn | DmDn | | | UDF04 Dm,Dn (SAT16 Dm,Dn) | Satulate16(Dm)->Dn | $ \ ?\ \ ?\ \ \Delta \ \Delta \ \Delta $ 2 1111 0110 0100 DmDn | DmDn | | | UDF05 Dm,Dn (SAT24 Dm,Dn) | Satulate24(Dm)->Dn | ? ? ∆ ∆ 2 1111 0110 0101 DmDn | DmDn | | | UDF06 Dm, Dn (MCST48 Dn) | Satulate48({MCRH,MCRL})>>16->Dn | 0/1 0 ? ? 2 1111 0110 0110Dn | Dn | | | UDF07 Dm,Dn (BSCH Dm,Dn) | bit search | ? 0/1 ? ? 2 111101100111DmDn | DmDn | | | UDF08 Dm,Dn (SWAP Dm,Dn) | Dm[31:24]->Dn[7:0],Dm[23:16]->Dn[15:8] | - - - 2 1111 0110 1000 DmDn | DmDn | | | | Dm[15:8]->Dn[23:16],Dm[7:0]->Dn[31:24] | | | | | UDF09 Dm,Dn (SWAPH Dm,Dn) | Dm[31:24]->Dn[23:16],Dm[23:16]->Dn[31:24] | - - - - 2 1111 0110 1001 DmDn | DmDn | | | | Dm[15:8]->Dn[7:0],Dm[7:0]->Dn[15:8] | | | | | UDF12 Dm,Dn (GETCHX Dn) | MCRH->Dn,MCVF->EPSW.V | \( \lambda \right \( 0 \right ? \right ? \right 2 \right 111101101100Dn | -Dn | | | UDF13 Dm,Dn (GETCLX Dn) | MCRL->Dn,MCVF->EPSW.V | | -Dn | | | UDF15 Dm,Dn (GETX Dn) | MCRQ->Dn | $ 0 0 \Delta \Delta \Delta $ 2 11110110 1111 Dn | Dn | | | | : | " | FC. Flag | ק | | I C | FCC Flag | Code | <u>a</u> | | | | | | |-------|----------------------|---------------------------------------|-------------|----------|----------|----------|-----|---------------|------|----------------------|----------------------------|------------|---------------------------------|-----------------------|----------| | Group | Mnemonic | Operation | VF ZF OF UF | FOF | | F | FGF | LFGHEFUF Size | FSiz | . e | | Machi | Machine Code | Note | | | | | | | | | | - | | | _ | | | | | | | FMOV | FMOV (Rm),FSn | mem32(Rm)->FSn | 1 | ı | ı | <u>'</u> | 1 | ' | | 3 11 | 1111 1001 0010 000X Rm Sn | 10 000X R | m. Sn | FSn={X,Sn} | | | | FMOV (SP),FSn | mem32(SP)->FSn | | - | - | - | - | - | | 3 111 | 1111 1001 0010 010X | 10 010X | Sn | FSn={X,Sn} | | | | FMOV (Rm,Ri),FSn | mem32(Rm+Ri)->FSn | - | , | ı | ' | - | ' | | 4 111 | 1 1011 00 | 10 0111 R | 1111 1011 0010 0111 Ri Rm SnZ- | FSn={Z,Sn} | | | | FMOV (d8,Rm),FSn | mem32(Rm+(sign ext)d8)->FSn - | | ı | ı | • | 1 | ' | | 4 111 | 1 1011 00 | 10 000X R | 1111 1011 0010 000X Rm Sn d8 | FSn={X,Sn} | | | | FMOV (d24,Rm),FSn | mem32(Rm+(sign_ext)d24)->FSn | - | - | | _ | - | - | | 6 111 | 1 1101 00 | 10 000X R | 1111 1101 0010 000X Rm Sn d24 | FSn={X,Sn} | | | | FMOV (d32,Rm),FSn | | - | - | | <u> </u> | - | | | 7 111 | 1 1110 00 | 10 000X R | 1111 1110 0010 000X Rm Sn d32 | FSn={X,Sn} | | | | FMOV (d8,SP),FSn | mem32(SP+(zero_ext)d8)->FSn | 1 | ı | | <u>'</u> | 1 | ' | | 4 111 | 1111 1011 0010 010X | 10 010X | Sn d8 | FSn={X,Sn} | | | | FMOV (d24,SP),FSn | mem32(SP+(zero ext)d24)->FSn | - | ı | ı | | 1 | ' | | 6 111 | 1 1101 00 | 10 010X | 1111 1101 0010 010X Sn d24 | FSn={X,Sn} | | | | FMOV (d32,SP),FSn | mem32(SP+d32)->FSn | - | - | | - | - | - | | 7 111 | 1 1110 00 | 10 010X | 1111 1110 0010 010X Sn d32 | FSn={X,Sn} | | | | FMOV FSm,(Rn) | FSm->mem32(Rn) | - | ı | ı | | - | ' | | 3 111 | 1111 1001 0011 00Y0 Sm Rn | 11 00Y0 S | m Rn | FSm={Y,Sm} | | | | FMOV FSm,(SP) | | ' | , | , | | ' | ' | | 3 111 | 1111 1001 0011 01Y0 Sm | 11 01Y0 S | m | FSm={Y,Sm} | | | | FMOV FSm,(Rn,Ri) | FSm->mem32(Rn+Ri) | | , | , | | ' | ' | | 4 111 | 1 1011 00 | 11 0111 R | 1111 1011 0011 0111 Ri Rn SmZ- | FSm={Z,Sm} | | | | FMOV FSm,(d8,Rn) | FSm->mem32(Rn+(sign_ext)d8) | | - | - | <u>'</u> | - | - | | 4 111 | 1 1011 00 | 11 00Y0 S | 1111 1011 0011 00Y0 Sm Rn d8 | FSm={X,Sm} | | | | FMOV FSm,(d24,Rn) | FSm->mem32(Rn+(sign_ext)d24) | - | ٠ | , | - | - | - | | 6 111 | 1 1101 00 | 11 00Y0 S | 1111 1101 0011 00Y0 Sm Rn d24 | FSm={Y,Sm} | | | | FMOV FSm,(d32,Rn) | | 1 | | | | ' | ' | | 7 111 | 1 1110 00 | 11 00Y0 S | 1111 1110 0011 00Y0 Sm Rn d32 | FSm={Y,Sm} | | | | FMOV FSm,(d8,SP) | FSm->mem32(SP+(zero_ext)d8) | 1 | ı | , | <u>'</u> | - | ' | | 4 111 | 1111 1011 0011 01Y0 Sm | 11 01Y0 S | m d8 | FSm={X,Sm} | | | | FMOV FSm,(d24,SP) | ext)d24) | 1 | | , | 1 | 1 | ' | | 6 111 | 1111 1101 0011 01Y0 Sm | 11 01Y0 S | m d24 | FSm={Y,Sm} | | | | FMOV FSm,(d32,SP) | FSm->mem32(SP+d32) | 1 | ı | - | ' | ı | ' | | 7 111 | 1111 1110 0011 01Y0 Sm | 11 01Y0 S | m d32 | FSm={Y,Sm} | | | | FMOV (Rm+),FSn | mem32(Rm)->FSn,Rm+0x00000004->Rm | - | ı | | | 1 | ' | | 3 111 | 1111 1001 0010 001X Rm Sn | 10 001X R | .m Sn | FSn={X,Sn} | | | | FMOV (Rm+,imm8),FSn | mem32(Rm)->FSn,Rm+(sign_ext)imm8->Rm | 1 | ı | ı | 1 | ı | ' | | 4 111 | 1 1011 00 | 10 001X R | 1111 1011 0010 001X Rm Sn imm8 | FSn={X,Sn} | | | | FMOV (Rm+,imm24),FSn | mem32(Rm)->FSn,Rm+(sign_ext)imm24->Rm | | - | - | - | - | - | | 6 111 | 1 1101 00 | 10 001X R | 1111 1101 0010 001X Rm Sn imm24 | FSn={X,Sn} | | | | FMOV (Rm+,imm32),FSn | mem32(Rm)->FSn,Rm+imm32->Rm | 1 | ı | | | 1 | ' | | 7 111 | 1111000 | 10 001X R | 1111 1110 0010 001X Rm Sn imm32 | FSn={X,Sn} | | | | FMOV FSm,(Rn+) | FSm->mem32(Rn),Rn+0x00000004->Rn | 1 | ı | ı | | 1 | ' | | 3 111 | 1111 1001 0011 00Y1 Sm Rn. | 11 00Y1 S | m Rn | FSm={Y,Sm} | | | | FMOV FSm,(Rn+,imm8) | _ | - | • | | - | - | - | | 4 111 | 1 1011 00 | 11 00Y1 S | 1111 1011 0011 00Y1 Sm Rn imm8 | FSm={X,Sm} | | | | FMOV FSm,(Rn+,imm24) | FSm->mem32(Rn),Rn+(sign_ext)imm24->Rn | | - | - | - | - | - | | 6 111 | 1 1101 00 | 11 00Y1 S | 1111 1101 0011 00Y1 Sm Rn imm24 | FSm={Y,Sm} | | | | FMOV FSm,(Rn+,imm32) | FSm->mem32(Rn),Rn+imm32->Rn | - | ı | ı | ' | 1 | ' | | | 1 1110 00 | 11 00Y1 S | 1111 1110 0011 00Y1 Sm Rn imm32 | FSm={Y,Sm} | | | | FMOV FSm,FSn | FSm->FSn | - | ı | ı | | ı | ' | | 3 111 | 1111 1001 0100 00YX Sm Sn | S XX00 0C | m Sn | FSm={Y,Sm},FSn={X,Sn} | n={X,Sn} | | | FMOV FSm,Rn | FSm->Rn | | - | - | _ | - | | | | 1111 1001 0011 01Y1 Sm Rn | 11 01Y1 S | m Rn | FSm={Y,Sm} | | | | FMOV Rm,FSn | | - | - | - | | - | | | 3 111 | 1111 1001 0010 011X Rm Sn | 10 011X R | .m Sn | FSn={X,Sn} | | | | FMOV imm32,FSn | imm32->FSn | 1 | , | , | | 1 | ' | | 7 111 | 1111 1110 0010 011X | | Sn imm32 | FSn={X,Sn} | | | | FMOV FPCR,Rn | FPCR->Rn | 1 | 1 | , | 1 | 1 | ' | | 3 111 | 1111 1001 1011 0111 Rn. | 11 0111 | Rn | | | | | FMOV Rm, FPCR | | | - | - | - | - | | | | 1111 1001 1011 0101 Rm | 11 0101 R | m | | | | | FMOV imm32,FPCR | imm32->FPCR | 7 | $\Delta$ | <b>∇</b> | <b>∇</b> | Δ | 7 | ∇ | 6 111 | 1111 1101 1011 0101 imm32 | 11 0101 in | าm32 | | | | | FMOV (Rm), FDn | | | 1 | - | - | - | - | | 3 111 | 1111 1001 1010 000X Rm fn. | 10 000X R | m fn | FDn={X,fn}<<1 | | | | FMOV (Rm,Ri),FDn | | 1 | ı | | 1 | ı | 1 | | | 1 1011 01 | 00 0111 R | 1111 1011 0100 0111 Ri Rm fnZ- | FDn={Z,fn} | | | | FMOV (d8,Rm),FDn | mem64(d8+Rm)->FDn | 1 | 1 | | <u>'</u> | 1 | <u>'</u> | | <u>4</u><br><u>†</u> | 1 1011 10 | 10 000X R | 1111 1011 1010 000X Rm fn d8 | FDn={X,fn}<<1 | | | | | | | | | | | | | | | | | | | | | | : | EC Flag | FCC Flag | about | | | |-------|------------------------|---------------------------------------|------------|-------------------------------------|---------------------------------------------------------|---------------------------------------|--------------------------------------| | Group | Minemonic | Operation | VEZFORUFIE | | | Machine Code | Note | | | | | | | | | | | FMOV | FMOV FMOV (d24,Rm),FDn | mem64(d24+Rm)->FDn | 1 | 1 | - 6 1111 1101 1010 000X Rm fn d24 | X Rm fn d24 | FDn={X,fn}<<1 | | | FMOV (d32,Rm),FDn | mem64(d32+Rm)->FDn | | 1 | - 7 1111 1110 0100 000X Rm fn d32 | X Rm fn d32 | FDn={X,fn}<<1 | | | FMOV (SP), FDn | mem64(SP)->FDn | 1 | 1 | - 3 1111 1001 1010 010X fn | X fn | FDn={X,fn}<<1 | | | FMOV (d8,SP),FDn | mem64(d8+SP)->FDn | | | - 4 1111 1011 1010 010X fn d8 | X fn d8 | FDn={X,fn}<<1 | | | FMOV (d24,SP),FDn | mem64(d24+SP)->FDn | | | - 6 1111 1101 1010 010X fn d24 | X fn d24 | FDn={X,fn}<<1 | | | FMOV (d32,SP),FDn | mem64(d32+SP)->FDn | - | 1 | - 7 1111 1110 0101 01Y0 fm | '0 fm d32 | FDn={X,fn}<<1 | | | FMOV FDm,(Rn) | FDm->mem64(Rn) | | 1 | - 3 1111 1001 1011 00Y0 fm Rn. | ′0 fm Rn | FDm={Y,fm}<<1 | | | FMOV FDm,(Rn,Ri) | FDm->mem64(Rn+Ri) | | | - 4 1111 1011 0101 0111 Ri Rn fm | 1 Ri Rn fmZ- | FDm={Z,fm} | | | FMOV FDm,(d8,Rn) | FDm->mem64((sign_ext)d8+Rn) | 1 | 1 | - 4 1111 1011 1011 00Y0 fm Rn d8 | ′0 fm Rn d8 | FDm={Y,fm}<<1 | | | FMOV FDm, (d24,Rn) | FDm->mem64((sign_ext)d24+Rn) | 1 1 | 1 | - 6 1111 1101 1011 00Y0 fm Rn d24 | '0 fm Rn d24 | FDm={Y,fm}<<1 | | | FMOV FDm, (d32,Rn) | FDm->mem64(d32+Rn) | 1 | 1 | - 7 1111 1110 0101 00Y0 fm Rn d32 | '0 fm Rn d32 | FDm={Y,fm}<<1 | | | FMOV FDm,(SP) | FDm->mem64(SP) | 1 | 1 | - 3 1111 1001 1011 01Y0 fm | ′0 fm | FDm={Y,fm}<<1 | | | FMOV FDm,(d8,SP) | FDm->mem64((zero_ext)d8+SP) | 1 1 | 1 | - 4 1111 1011 1011 01Y0 fm d8 | ′0 fm d8 | FDm={Y,fm}<<1 | | | FMOV FDm,(d24,SP) | FDm->mem64((zero_ext)d24+SP) | 1 1 | 1 | - 6 1111 1101 1011 01Y0 fm d24 | '0 fm d24 | FDm={Y,fm}<<1 | | | FMOV FDm,(d32,SP) | FDm->mem64(d32+SP) | | | - 7 1111 1110 0101 01Y0 fm d32 | '0 fm d32 | FDm={Y,fm}<<1 | | | FMOV (Rm+),FDn | mem64(Rm)->FDn,Rm+0x0000008->Rm | 1 1 | 1 | - 3 1111 1001 1010 001X Rm fn | X Rm fn | FDn={X,fn}<<1 | | | FMOV (Rm+,imm8),FDn | mem64(Rm)->FDn, | 1 1 | 1 1 | - 4 1111 1011 1010 001X Rm fn imm8 | X Rm fn imm8 | FDn={X,fn}<<1 | | | | Km+(sign_ext)imms->Km | | | | | | | | FMOV (Rm+,imm24,FDn | mem64(Rm)->FDn, | 1 1 1 | 1 | - 6 1111 1101 1010 001X Rm fn imm24 | X Rm fn imm24 | FDn={X,fn}<<1 | | | | Km+(sign_ext)imm24->Km | | | | | | | | FMOV (Rm+,imm32),FDn | mem64(Rm)->FDn,Rm+imm32->Rm | 1 1 | 1 | | X Km tn ımm32 | FDn={X,fn}<<1 | | | FMOV FDm,(Rn+) | FDm->mem64(Rn),Rn+0x00000008->Rn | 1 1 | 1 | | ′1 fm Rn | FDm={Y,fm}<<1 | | | FMOV FDm,(Rn+,imm8) | FDm->mem64(Rn),Rn+(sign_ext)imm8->Rn | | | | ′1 fm Rn imm8 | FDm={Y,fm}<<1 | | | FMOV FDm, (Rn+, imm24) | FDm->mem64(Rn),Rn+(sign_ext)imm24->Rn | | | - 6 1111 1101 1011 00Y1 fm Rn imm24 | ′1 fm Rn imm24 | FDm={Y,fm}<<1 | | | FMOV FDm,(Ri+,imm32) | FDm->mem64(Rn),Rn+imm32->Rn | | | | ′1 fm Rn imm32 | FDm={Y,fm}<<1 | | FABS | FABS FSn | FSn ->FSn | 7 0 0 0 0 | $\Delta$ $\Delta$ $\Delta$ | $\Delta \mid 3 \mid 1111 \mid 1001 \mid 0100 \mid 010X$ | Sn | FSn ={X,Sn} | | | FABS FSm,FSn | FSm ->FSn | | | | 0 Sm Sn X-Z- | FSm={X,Sm},FSn={Z,Sn} | | FNEG | | FSn*(-1)->FSn | 1 1 | 1 1 | | | FSn ={X,Sn} | | | FNEG FSm,FSn | FSm*(-1)->FSn | | -<br>- | - 4 1111 1011 0100 0110 Sm | 0 Sm Sn X-Z- | FSm={X,Sm},FSn={Z,Sn} | | FRSOR | FRSQRT FSn | 1/Sqrt(FSn)->FSn | 7 0 0 0 0 | ∇ | - 3 1111 1001 0101 000X Sn | X Sn | FSn={X,Sn} | | | FRSQRT FSm,FSn | 1/Sqrt(FSm)->FSn | 4 A A A A | Δ | | 0 Sm Sn X-Z- | FSm={X,Sm},FSn={Z,Sn} | | FCMP | | FSm2-FSm1:FPCR(EC) | | $\Delta$ $\Delta$ $\Delta$ $\Delta$ | ∆ 3 1111 1001 0101 01YX Sm1. Sm2 | X Sm1. Sm2. | FSm1={Y,Sm1},FSm2={X,Sm2} | | | | FSm-imm32:FPCR(EC) | Δ Δ Δ Δ Δ | Δ Δ Δ Δ | | '1 Sm imm32 | FSm={Y,Sm} | | FADD | | FSm+FSn->FSn | Δ Δ Δ Δ Δ | V | | X Sm Sn | FSm={Y,Sm},FSn={X,Sn} | | | FADD FSm1,FSm2,FSn | FSm1+FSm2->FSn | Δ Δ Δ Δ | V | - 4 1111 1011 0110 000 | 1111 1011 0110 0000 Sm1. Sm2. Sn XYZ- | FSm1={X,Sm1},FSm2={Y,Sm2},Fsn={Z,Sn} | | | FADD imm32,FSm,FSn | FSm+imm32->FSn | 7 V V V V | | - 7 1111 1110 0110 00Y | 1111 1110 0110 00YX Sm Sn imm32 | FSm={Y,Sm},FSn={X,Sn} | | | | | | | | | | | Group | o Mnemonic | Operation | VFZ | EC Flag<br>VF ZF OF UF IF | FLF | FCC Flag<br>LFGFEFUF | ag C | Code | Machine Code | Note | |---------|-------------------------------|----------------------------------------------------|----------|----------------------------------------------------------|-----|----------------------|------|--------------|-----------------------------------------------|---------------------------------------------------| | | | | | | | | | | | | | FSUB | FSUB FSm,FSn | FSn-FSm->FSn | Δ | | 1 | | , | <sub>(</sub> | 1111 1001 0110 01YX Sm Sn | FSm={Y,Sm},FSn={X,Sn} | | | FSUB FSm1,FSm2,FSn | FSm2-FSm1->FSn | ∇<br>∇ | | 1 | ' | ı | 4 | 4 1111 1011 0110 0100 Sm1. Sm2. Sn XYZ- FSmi: | FSm1={X,Sm1},FSm2={Y,Sm2},Fsn={Z,Sn} | | | FSUB imm32,FSm,FSn | FSm-imm32->FSn | $\Delta$ | | - | | - | 7 | 7 1111 1110 0110 01YX Sm Sn imm32 | FSm={Y,Sm},FSn={X,Sn} | | FMUL | FMUL FSm,FSn | FSm*FSn->FSn | 7 | V | - \ | | - | 3 | 3 1111 1001 0111 00YX Sm Sn | FSm={Y,Sm},FSn={X,Sn} | | | FMUL FSm1,FSm2,FSn | FSm1*FSm2->FSn | 7 | 7 0 0 | - \ | , | , | 4 | 4 1111 1011 0111 0000 Sm1. Sm2. Sn XYZ- | FSm1=(X,Sm1),FSm2=(Y,Sm2),Fsn=(Z,Sn) | | | FMUL imm32,FSm,FSn | FSm*imm32->FSn | Δ Δ | 7 0 0 0 | Δ - | - | - | 7 | 1111 1110 0111 00YX Sm Sn imm32 | FSm={Y,Sm},FSn={X,Sn} | | FDIV | FDIV FSm,FSn | FSn/FSm->FSn | Δ | | - V | - | - | 3 | 3 1111 1001 0111 01YX Sm Sn | FSm={Y,Sm},FSn={X,Sn} | | | FDIV FSm1,FSm2,FSn | FSm2/FSm1->FSn | 7 | $\Delta \mid \Delta \mid \Delta \mid \Delta$ | - | | , | 4 | .Z- | FSm1=(X,Sm1),FSm2={Y,Sm2},Fsn={Z,Sn} | | | FDIV imm32,FSm,FSn | FSm/imm32->FSn | Δ Δ | $\Delta \mid \Delta \mid \Delta \mid \Delta$ | - | - | - | 7 | 1111 1110 0111 01YX Sm Sn imm32 | FSm={Y,Sm},FSn={X,Sn} | | FMADE | FMADD FMADDFSm1,FSm2,FSm3,FSn | ((FSm1*FSm2)+FSm3)->FSn | Δ 2 | $\Delta \mid \Delta \mid \Delta \mid \Delta$ | - | - | - | 4 | 1111 1011 1000 00Sn Sm1. Sm2. Sm3. XYZA | FSm1={X,Sm1},FSm2={Y,Sm2},FSm3={Z,Sm3},FSn={A,Sn} | | FMSUE | FMSUB FMSUBFSm1,FSm2,FSm3,FSn | ((FSm1*FSm2)-FSm3)->FSn | Δ | $\Delta \mid \Delta \mid \Delta \mid \Delta$ | - 1 | - | - | 4 | 1111 1011 1000 01Sn Sm1. Sm2. Sm3. XYZA | FSm1={X,Sm1},FSm2={Y,Sm2},FSm3={Z,Sm3},FSn={A,Sn} | | FINMADI | FNMADD FSm1,FSm2,FSm3,FSn | FNMADD FSm1,FSm2,FSm3,FSn (-(FSm1*FSm2)+FSm3)->FSn | Δ Δ | $\Delta \mid \Delta \mid \Delta \mid \Delta$ | - 1 | 1 | - | 4 | 1111 1011 1001 00Sn Sm1. Sm2. Sm3. XYZA | FSm1={X,Sm1},FSm2={Y,Sm2},FSm3={Z,Sm3},FSn={A,Sn} | | FNIMSU | F FNMSUB FSm1,FSm2,FSm3,FSn | FNMSUB FSm1,FSm2,FSm3,FSn (-(FSm1*FSm2)-FSm3)->FSn | 7 | $\nabla \mid \nabla \mid \nabla \mid \nabla \mid \nabla$ | 1 | | | 4 | 1111 1011 1001 01Sn Sm1. Sm2. Sm3. XYZA | FSm1={X,Sm1},FSm2={Y,Sm2},FSm3={Z,Sm3},FSn={A,Sn} | | FBCC | FBEQ label | IF(E=1),PC+((sign_ext)d8)->nPC, | | 1 | , | 1 | , | က | 1111 1000 1101 0000 d8 | | | | | else,PC+CodeSize->nPC | | | | | | | | | | | FBNE label | IF(U=1orL=1orG=1) | 1 | 1 | ı | , | ı | <u>დ</u> | 1111 1000 1101 0001 d8 | | | | | PC+((sign_ext)d8)->nPC, | | | | | | | | | | | | else,PC+CodeSize->nPC, | | | | | | | | | | | FBGT label | IF(G=1) | 1 | 1 | | , | ı | m | 1111 1000 1101 0010 d8 | | | | | PC+((sign_ext)d8)->nPC, | | | | | | | | | | | | else,PC+CodeSize->nPC, | | | | | | | | | | | FBGE label | IF(G=1orE=1) | 1 | 1 | 1 | 1 | 1 | n | 1111 1000 1101 0011 d8 | | | | | PC+((sign_ext)d8)->nPC, | | | | | | | | | | | | else,PC+CodeSize->nPC, | | | | | | | | | | | FBLT label | IF(L=1) | ' | | | - | ı | m | 1111 1000 1101 0100 d8 | | | | | PC+((sign_ext)d8)->nPC, | | | | | | | | | | | | else,PC+CodeSize->nPC | | | | | | | | | | | FBLE label | IF(L=1orE=1) | 1 | - | | - | ı | ღ | 1111 1000 1101 0101 d8 | | | | | PC+((sign_ext)d8)->nPC, | | | | | | | | | | | | else,PC+CodeSize->nPC | | | | | | | | | | | FBUO label | IF(U=1) | 1 | 1 | | • | , | m<br>m | 1111 1000 1101 0110 d8 | | | | | PC+((sign_ext)d8)->nPC, | | | | | | | | | | | | else,PC+CodeSize->nPC | | | | | | | | | | | | | _ | | | | | | | | | _ | | | _ | | | _ | | | _ | | _ | _ | |--------------------------------------------------|--------------------------|-------------------------|--------------------------|-------------------------|-----------------------|--------------------------|-------------------------|-----------------------|--------------------------|-------------------------|------------------------|--------------------------|-------------------------|-----------------------|--------------------------|-------------------------|-----------------------|--------------------------|-------------------------|-----------------------|-----------------------|----------------|-------------------------------|----| | Machine Code | 1 0111 d8 | | 1 1000 d8 | | | 1 1001 d8 | | | 1 1010 d8 | | | 1 1011 d8 | | | 1 1100 d8 | | | 1 1101 d8 | | | 1 0000 | | 1 0001 | | | | 3 1111 1000 1101 0111 d8 | | 3 1111 1000 1101 1000 d8 | | | 3 1111 1000 1101 1001 d8 | | | 3 1111 1000 1101 1010 d8 | | | 3 1111 1000 1101 1011 d8 | | | 3 1111 1000 1101 1100 d8 | | | 3 1111 1000 1101 1101 d8 | | | 2 1111 0000 1101 0000 | | 2 1111 0000 1101 0001 | | | EC Flag FCC Flag Code<br>VFZFOFUFIF LFGFEFUF Sze | 3 | | 3 | | | 3 | | | 3 | | | 3 | | | 3 | | | 3 | | | 2 | | 2 | | | ag<br>-UF | - | | | | | ı | | | 1 | | | - | | | - | | | ı | | | ı | | , | _ | | 明点 | - | | ' | | | • | | | ' | | | • | | | - | | | 1 | | | 1 | | ' | | | 일은 | - | | - | | | 1 | | | - | | | - | | | 1 | | | 1 | | | 1 | | 1 | _ | | ᆜᆣ | • | | 1 | | | | | | <u> </u> | | | _ | | | | | | | | | | _ | <u> </u> | _ | | ag<br>UF | - | | | | | , | | | , | | | - | | | , | | | , | | | , | | , | - | | EC Flag<br>ZFOHUF | | | 1 | | | ı | | | , | | | ı | | | ı | | | , | | | ı | | , | _ | | | ı | | ' | | | 1 | | | , | | | - | | | 1 | | | , | | | 1 | | , | | | | 1 | | | | | • | | | ' | | | • | | | 1 | | | ı | | | 1 | | () | | | Operation | IF(L=1orG=1) | PC+((sign_ext)d8)->nPC, | IF(L=10rE=10rG=1) | PC+((sign_ext)d8)->nPC, | else,PC+CodeSize->nPC | IF(U=1orG=1) | PC+((sign_ext)d8)->nPC, | else,PC+CodeSize->nPC | IF(U=1orG=1orE=1) | PC+((sign_ext)d8)->nPC, | else,PC+CodeSize->nPC( | IF(U=1orL=1) | PC+((sign_ext)d8)->nPC, | else,PC+CodeSize->nPC | IF(U=1orL=1orE=1) | PC+((sign_ext)d8)->nPC, | else,PC+CodeSize->nPC | IF(U=10rE=1) | PC+((sign_ext)d8)->nPC, | else,PC+CodeSize->nPC | IF(E=1),LAR-4->nPC, | else,PC+1->nPC | IF(U=1orL=1orG=1),LAR-4->nPC, | (1 | | Mnemonic | FBCC FBLG label | | FBLEG label | | | FBUG label | | | FBUGE label | | | FBUL label | | | FBULE label | | | FBUE label | | | FLEQ | | FLNE | | | Group | FBCC | | • | | | | | | | | | | | | | | | • | | | FLCC FLEQ | | | _ | | Group | Mnemonic | Operation | EC Flag FCC Flag Code VFZFOHUF IF LFGHEFUF Size Machine Code | | |-------|-----------|--------------------------------------------------|--------------------------------------------------------------------------------|--| | | | | | | | CCC | FLCC FLUO | IF(U=1),LAR-4->nPC,<br>else.PC+1->nPC | 2 1111 0000 1101 0110 | | | | FLLG | IF(L=1orG=1),LAR-4->nPC,<br>else,PC+1->nPC | 2 1111 0000 1101 0111 | | | | FLLEG | IF(L=1orE=1orG=1),LAR-4->nPC,<br>else,PC+1-> nPC | 2 1111 0000 1101 1000 | | | | FLUG | IF(U=1orG=1),LAR-4->nPC,<br>else,PC+1-> nPC | 2 1111 0000 1101 1001 | | | | FLUGE | IF(U=1orG=1orE=1),LAR-4->nPC<br>else,PC+1-> nPC | 2 1111 0000 1101 1010 | | | | FLUL | IF(U=1orL=1),LAR-4->nPC,<br>else,PC+1-> nPC | 2 1111 0000 1101 1011 | | | | FLULE | IF(U=1orL=1orE=1),LAR-4->nPC, else,PC+1-> nPC | 2 1111 0000 1101 1100 | | | | FLUE | IF(U=1orE=1),LAR-4->nPC,<br>else,PC+1-> nPC | 2 1111 0000 1101 1101 | | | 1st Byte | | | | | | | | | | | | | | | | | |----------------|----------------|-------------------|---------------------|---------------------|----------------|-------------------|---------------------|---------------------|----------------|-------------------|--------------------|----------------------|-----------------|------------------|---------------------|---------------------| | Lowe<br>Upper, | - | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | 0 | CLR<br>D0 | MOV<br>D0,(abs16) | MOVBU<br>D0,(abs16) | MOVHU<br>D0,(abs16) | CLR<br>D1 | MOV<br>D1,(abs16) | MOVBU<br>D1,(abs16) | MOVHU<br>D1,(abs16) | CLR<br>D2 | MOV<br>D2,(abs16) | MOVBU<br>D2,(abs16 | MOVHU<br>)D2,(abs16) | CLR<br>D3 | MOV<br>D3,(abs16 | MOVBU<br>D3,(abs16) | MOVHU<br>D3,(abs16) | | 1 | | EXT | B Dn | | | EXTE | BU Dn | | | EXT | H Dn | | | EXT | HU Dn | | | 2 | | ADD ir | nm8,Ar | 1 | | MOV im | nm16,A | ın | | ADD in | nm8,Dı | n | ı | MOV in | nm16,D | n | | 3 | | <del>, `</del> | abs16),l | | | OVBU | | | | OVHU | ` | | | | SP,An | | | 4 | INC<br>D0 | INC<br>A0 | MOV<br>D0,(d8,SP) | MOV<br>A0,(d8,SP) | INC<br>D1 | INC<br>A1 | MOV<br>D1,(d8,SP) | MOV<br>A1,(d8,SP) | INC<br>D2 | INC<br>A2 | MOV<br>D2,(d8,SP) | MOV<br>)A2,(d8,SP) | INC<br>D3 | INC<br>A3 | MOV<br>D3,(d8,SP) | MOV<br>A3,(d8,SP) | | 5 | | INC | C4 An | | | ASL | 2 Dn | | N | MOV (d | 8,SP),I | Dn | N | MOV (c | 18,SP),A | ۸n | | 6 | | | | | | | | MOV D | m,(An) | ) | | | | | | | | 7 | | | | | | | | MOV ( | ۹m),Dr | 1 | | | | | | | | 8 | | | | | | МО | V Dm, | Dn (m= | n:MOV | / imm8, | Dn) | | | | | | | 9 | | | | | | MO | V Am, | An (m= | n:MOV | ' imm8, | An) | | | | | | | Α | | | | | | CM | P Dm, | Dn (m= | n:CMP | imm8, | Dn) | | | | | | | В | DI T | 207 | | | | | | An (m= | | 1 | | | | 0411 | 140/44 | 140)/04 | | С | BLT<br>(d8,PC) | BGT<br>(d8,PC) | BGE<br>(d8,PC) | BLE<br>(d8,PC) | BCS<br>(d8,PC) | BHI<br>(d8,PC) | BCC<br>(d8,PC) | BLS<br>(d8,PC) | BEQ<br>(d8,PC) | BNE<br>(d8,PC) | BRA<br>(d8,PC) | NOP | JMP<br>(d16,PC) | CALL<br>(d16,PC) | MOVM<br>(SP),regs | MOVM<br>regs,(SP) | | D | LLT | LGT | LGE | LLE | LCS | LHI | LCC | LLS | LEQ | LNE | LRA | SETLB | (d32,PC) | (d32,PC) | RETF | RET | | E | | | | | | | | ADD [ | Dm,Dn | | | | | | 7 byte | | | F | | | | 2 byte code | ) | | | code | 3 byte | e code | 4 byt | e code | 6 byte | code | code | PI | | F0 | (2 byte | e Code ) | 1 | | | | | | | | | | | | | | | 2nd Byte | | , , | | | | | | | | | | | | | | | | Lowe<br>Upper | r 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | 0 | | | | | | | | MOV ( | ۹m),An | 1 | | | | | | | | 1 | | | | | | | | MOV A | m,(An) | ) | | | | | | | | 2 | | 1 | JSP,Ar | 1 | | MOV S | · · | 1 | | MOV N | i - | <u>1</u> | | l e | PC,An | | | 3 | MOV<br>A0,USP | MOV<br>A0,SSP | MOV<br>A0,MSP | | MOV<br>A1,USP | MOV<br>A1,SSP | MOV<br>A1,MSP | | MOV<br>A2,USP | MOV<br>A2,SSP | MOV<br>A2,MSP | | MOV<br>A3,USP | MOV<br>A3,SSP | MOV<br>A3,MSP | | | 4 | | | | | | | N | IOVBU | (Am),E | On | | | | | | | | 5 | | | | | | | M | IOVBU | Dm,(A | n) | | | | | | | | 6 | | | | | | | N | IOVHU | (Am),E | On | | | | | | | | 7 | | | | | | | N | IOVHU | Dm,(A | n) | | | | | | | | 8 | | | | | | | | BSET [ | Om,(An | ) | | | | | | | | 9 | | | | | | | | BCLR [ | Om,(An | ı) | | | | | | | | Α | | | | | | | | | | | | | | | | | | В | | | | | | | | | | | | | | | | | | С | | | 1 | | | | | | | | | | | | 7 | | | D | FLEQ | FLNE | FLGT | FLGE | FLLT | FLLE | FLUO | FLLG | FLLEG | FLUG | FLUGE | FLUL | FLULE | FLUE | | | | Е | | | | | | | | YSCAL | L imm | ո4 | | | | | | | | F | | CALL | S (An) | | | JMP | (An) | | | | | | RETS | RTI | TRAP | | F1 ( 2 byte Code ) | l Byte<br>Lower | ٥ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | |---------------------------------------------------|--------|---------------|-----------|----------|---|----------|------|-----------------------------------|-------------------------------------------------------|---|---|---|---|-------------|---|---| | Upper 0 | | <u>'</u> | | <u> </u> | | <u> </u> | - 0 | SUB [ | | 9 | | | | | | | | 1 | | | | | | | | SUB A | | | | | | | | | | 2 | | | | | | | | SUB [ | | | | | | | | | | 3 | | | | | | | | SUB A | | | | | | | | | | 4 | | | | | | | | | Dm,Dn | | | | | | | | | 5 | | | | | | | | ADD A | Am,Dn | | | | | | | | | 6 | | | | | | | | ADD [ | Dm,An | | | | | | | | | 7 | | | | | | | | ADD A | Am,An | | | | | | | | | 8 | | | | | | | | SUBC | Dm,Dn | | | | | | | | | 9 | | | | | | | | CMP A | Am,Dn | | | | | | | | | Α | | | | | | | | CMP [ | Dm,An | | | | | | | | | В | | | | | | | | | | | | | | | | | | С | | | | | | | | | | | | | | | | | | D | | | | | | | | MOV | Am,Dn | | | | | | | | | E | | | | | | | | MOV I | Dm,An | | | | | | | | | | | | | | | | | | | | | | | | | | | F F2 ( | 2 byte | e Code ) | | | | | | | | | | | | | | | | F2 (<br>d Byte<br>Lower<br>Upper | | e Code )<br>1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | А | В | С | D | E | F | | F2 ( d Byte Lower Upper 0 | | | | 3 | 4 | 5 | 6 | AND I | Dm,Dn | 9 | A | В | С | D | E | F | | F2 ( Byte Lower Upper 0 | | | | 3 | 4 | 5 | 6 | AND I | Om,Dn<br>Om,Dn | 9 | A | В | С | D | E | F | | F2 ( d Byte Lower Upper 0 1 2 | | 1 | 2 | 3 | 4 | 5 | 6 | AND I | Dm,Dn | 9 | A | В | С | D | E | F | | F2 ( I Byte Lower Upper 0 1 2 | | | 2 | 3 | 4 | 5 | 6 | AND I | Om,Dn<br>Om,Dn<br>Om,Dn | 9 | A | В | С | D | E | F | | F2 ( d Byte Lower Upper 0 1 2 3 4 | | 1 | 2 | 3 | 4 | 5 | | AND I | Om,Dn Om,Dn Om,Dn Om,Dn | | A | В | С | D | E | F | | F2 ( d Byte Lower Upper 0 1 2 3 4 5 | | 1 | 2 | 3 | 4 | 5 | | AND I OR D XOR I MUL I | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | | A | В | С | D | E | F | | F2 ( I Byte Lower Upper 0 1 2 3 4 5 6 | | 1 | 2 | 3 | 4 | 5 | | AND I OR D XOR I MUL I MULU DIV D | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | C | D | E | F | | F2 ( d Byte Lower Upper 0 1 2 3 4 5 6 7 | | 1<br>NOT | 2<br>T Dn | 3 | 4 | | | AND I OR D XOR I MUL I MULU DIV D | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | C | D | E | F | | F2 ( d Byte Lower Upper 0 1 2 3 4 5 6 7 8 | | 1 | 2<br>T Dn | 3 | 4 | 5<br>ROF | | AND I OR D XOR I MUL I MULU DIV D | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | C | D | E | F | | F2 ( I Byte Lower Upper 0 1 2 3 4 5 6 7 8 9 | | 1<br>NOT | 2<br>T Dn | 3 | 4 | | | MUL I DIVU | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | C | D | E | F | | F2 (I Byte Lower Upper 0 1 2 3 4 5 6 7 8 9 A A | | 1<br>NOT | 2<br>T Dn | 3 | 4 | | | MUL I DIVU ASL I | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | C | D | E | F | | F2 ( I Byte Lower Upper 0 1 2 3 4 5 6 7 8 9 | | 1<br>NOT | 2<br>T Dn | 3 | 4 | | | MUL I DIVU ASL I | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | C | D | E | F | | F2 ( I Byte Lower Upper 0 1 2 3 4 5 6 7 8 9 A B | | 1<br>NOT | 2 T Dn | 3 | 4 | | | MUL I DIVU ASL I | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | C | D | E | F | | F2 ( I Byte Lower Upper 0 1 2 3 4 5 6 7 8 9 A B C | 0 | NOT | 2 Dn Dn | | | | R Dn | MULU DIVU ASL [ LSR [ | Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn Om,Dn | 1 | A | В | | D<br>MOV EF | | F | F3 (2 byte Code) 2nd Byte Lower 0 1 2 3 4 5 6 7 8 9 Α В С D Ε F Upper 0 1 MOV (Di,Am),Dn 2 3 4 5 MOV Dm,(Di,An) 6 7 8 9 MOV (Di,Am),An Α В С D MOV Am,(Di,An) Е F4 (2 byte Code) 2nd Byte 5 7 С D Ε F Lower 0 1 2 3 4 6 8 9 Α В Upper 0 1 MOVBU (Di,Am),Dn 2 3 4 5 MOVBU Dm,(Di,An) 6 7 8 9 MOVHU (Di,Am),Dn Α В С D MOVHU Dm,(Di,An) Е F F5 (2 byte Code) 2nd Byte Lower 0 2 3 4 5 6 7 8 9 A B C D Ε F 1 Upper 0 MOV Am,Rn 1 2 3 4 5 MOV Dm,Rn 6 7 8 9 MOV Rm,An Α В С D MOV Rm,Dn Ε F6 ( 2 byte Code ) 2nd | nd Byte | | | | | | | | | | | | | | | | | |----------------|---|---|---|---|--------|-------|---------|--------|--------|--------|--------|-------|-----|---|---|---| | Lower<br>Upper | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | 0 | | | | | | U | DF00 D | m,Dn | (MULQ | Dm,D | n) | | | | | | | 1 | | | | | | UE | F01 D | m,Dn ( | MULQL | J Dm,l | On) | | | | | | | 2 | | | | U | DF02 [ | Dm,Dn | (MCST | 32 Dn | / MCST | 16 Dr | n / MC | ST8 D | )n) | | | | | 3 | | | | | | ı | JDF03 | Dm,Dı | n (MCS | T9 Dn | ) | | | | | | | 4 | | | | | | UI | DF04 D | m,Dn | (SAT16 | Dm,E | n) | | | | | | | 5 | | | | | | UI | DF05 D | m,Dn | (SAT24 | Dm,E | n) | | | | | | | 6 | | | | | | ι | JDF06 | Dm,Dn | (MCS | 748 Dr | ר) | | | | | | | 7 | | | | | | U | DF07 [ | m,Dn | (BSCH | Dm,D | n) | | | | | | | 8 | | | | | | UI | DF08 D | m,Dn | (SWAP | Dm,D | )n) | | | | | | | 9 | | | | | | UD | F09 D | m,Dn ( | SWAPH | H Dm,I | Dn) | | | | | | | Α | | | | | | | ı | JDF10 | Dm,Dr | ) | | | | | | | | В | | | | | | | ı | JDF11 | Dm,Dr | 1 | | | | | | | | С | | | | | | U | IDF12 I | Dm,Dn | (GETC | HX D | n) | | | | | | | D | | | | | | L | JDF13 | Dm,Dn | (GETC | LX Dr | า) | | | | | | | E | | | | | | | Į | JDF14 | Dm,Dr | 1 | | | | | | | | F | | | | | | | UDF1 | 5 Dm,E | n (GE1 | X Dn) | | | | | | | | | Щ | | | | | | | | | | | | | | | | | |-----------------|----------------------------|-----------------------|-----------------------|-----------------------|-----------------------|----------------------------|----------------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---------------------|---| | | Ш | | | | | | | | | | | | | | | | | | | D | SAT16_ADD<br>operand1 | SAT16_ADD<br>operand3 | SAT16_SUB<br>operand1 | SAT16_SUB<br>operand3 | SAT16_CMP<br>operand1 | SAT16_CMP<br>operand3 | SAT16_MOV<br>operand1 | SAT16_MOV<br>operand3 | SAT16_ASR<br>operand1 | SAT16_ASR<br>operand3 | SAT16_LSR<br>operand1 | SAT16_LSR<br>operand3 | SAT16_ASL<br>operand1 | SAT16_ASL<br>operand3 | | | | | O | OR_ADD<br>operand1 | OR_ADD<br>operand3 | OR_SUB operand1 | OR_SUB<br>operand3 | OR_CMP operand1 | OR_CMP<br>operand3 | OR_MOV operand1 | OR_MOV operand3 | OR_ASR<br>operand1 | OR_ASR<br>operand3 | OR_LSR<br>operand1 | OR_LSR<br>operand3 | OR_ASL operand1 | OR_ASL<br>operand3 | | | | | В | SWHW_ADD<br>operand1 | SWHW_ADD<br>operand3 | SWHW_SUB operand1 | SWHW_SUB<br>operand3 | SWHW_CMP<br>operand1 | SWHW_CMP<br>operand3 | SWHW_MOV<br>operand1 | SWHW_MOV operand3 | SWHW_ASR<br>operand1 | SWHW_ASR<br>operand3 | SWHW_LSR<br>operand1 | SWHW_LSR<br>operand3 | SWHW_ASL<br>operand1 | SWHW_ASL<br>operand3 | | | | | Α | XOR_ADD operand1 | XOR_ADD operand3 | XOR_SUB operand1 | XOR_SUB<br>operand3 | | | XOR_MOV operand1 | XOR_MOV operand3 | XOR_ASR<br>operand1 | XOR_ASR<br>operand3 | XOR_LSR<br>operand1 | XOR_LSR<br>operand3 | XOR_ASL operand1 | XOR_ASL operand3 | | | | | 6 | DMACH_ADD<br>operand1 | DMACH_ADD<br>operand3 | DMACH_SUB<br>operand1 | DMACH_SUB<br>operand3 | DMACH_CMP XOR_CMP operand1 | DMACH_CMP XOR_CMP operand3 | DMACH_MOV<br>operand1 | DMACH_MOV<br>operand3 | DMACH_ASR<br>operand1 | DMACH_ASR ) | DMACH_LSR<br>operand1 | DMACH_LSR<br>operand3 | DMACH_ASL<br>operand1 | DMACH_ASL<br>operand3 | | | | | 8 | AND_ADD operand1 | AND_ADD operand3 | AND_SUB operand1 | AND_SUB operand3 | AND_CMP I | AND_CMP operand3 | AND_MOV<br>operand1 | AND_MOV<br>operand3 | AND_ASR I | AND_ASR I | AND_LSR operand1 | AND_LSR<br>operand3 | AND_ASL<br>operand1 | AND_ASL<br>operand3 | | | | | 7 | MOV_ADD<br>operand2 | MOV_ADD operand4 | MOV_SUB operand2 | MOV_SUB operand4 | MOV_CMP operand2 | MOV_CMP operand4 | MOV_MOV<br>operand2 | MOV_MOV<br>operand4 | MOV_ASR<br>operand2 | MOV_ASR<br>operand4 | MOV_LSR<br>operand2 | MOV_LSR<br>operand4 | MOV_ASL operand2 | MOV_ASL operand4 | | | | | 9 | SUB_ADD<br>operand2 | SUB_ADD<br>operand4 | SUB_SUB<br>operand2 | SUB_SUB<br>operand4 | SUB_CMP<br>operand2 | SUB_CMP<br>operand4 | SUB_MOV<br>operand2 | SUB_MOV<br>operand4 | SUB_ASR<br>operand2 | SUB_ASR<br>operand4 | SUB_LSR<br>operand2 | SUB_LSR<br>operand4 | SUB_ASL<br>operand2 | SUB_ASL<br>operand4 | | | | | 2 | CMP_ADD<br>operand2 | CMP_ADD<br>operand4 | CMP_SUB operand2 | CMP_SUB<br>operand4 | ' | | CMP_MOV operand2 | CMP_MOV operand4 | CMP_ASR<br>operand2 | CMP_ASR<br>operand4 | CMP_LSR<br>operand2 | CMP_LSR<br>operand4 | CMP_ASL operand2 | CMP_ASL operand4 | | | | | 4 | ADD_ADD<br>operand2 | ADD_ADD<br>operand4 | ADD_SUB operand2 | ADD_SUB<br>operand4 | ADD_CMP<br>operand2 | ADD_CMP<br>operand4 | ADD_MOV<br>operand2 | ADD_MOV<br>operand4 | ADD_ASR<br>operand2 | ADD_ASR<br>operand4 | ADD_LSR<br>operand2 | ADD_LSR<br>operand4 | ADD_ASL<br>operand2 | ADD_ASL<br>operand4 | | | | | 3 | MOV_ADD operand1 | MOV_ADD operand3 | MOV_SUB operand1 | MOV_SUB operand3 | MOV_CMP<br>operand1 | MOV_CMP<br>operand3 | MOV_MOV<br>operand1 | MOV_MOV<br>operand3 | MOV_ASR<br>operand1 | MOV_ASR<br>operand3 | MOV_LSR<br>operand1 | MOV_LSR<br>operand3 | MOV_ASL operand1 | MOV_ASL operand3 | | | | | 2 | SUB_ADD<br>operand1 | SUB_ADD<br>operand3 | SUB_SUB<br>operand1 | SUB_SUB<br>operand3 | SUB_CMP<br>operand1 | SUB_CMP<br>operand3 | SUB_MOV operand1 | SUB_MOV operand3 | SUB_ASR<br>operand1 | SUB_ASR<br>operand3 | SUB_LSR<br>operand1 | SUB_LSR<br>operand3 | SUB_ASL<br>operand1 | SUB_ASL<br>operand3 | | | | ( e | _ | CMP_ADD<br>operand1 | CMP_ADD operand3 | CMP_SUB operand1 | CMP_SUB operand3 | | | CMP_MOV operand1 | CMP_MOV operand3 | CMP_ASR<br>operand1 | CMP_ASR<br>operand3 | CMP_LSR<br>operand1 | CMP_LSR<br>operand3 | CMP_ASL operand1 | CMP_ASL operand3 | | | | F7 (4 byte Code | 0 | ADD_ADD<br>operand1 | ADD_ADD<br>operand3 | ADD_SUB operand1 | ADD_SUB operand3 | ADD_CMP<br>operand1 | ADD_CMP<br>operand3 | ADD_MOV operand1 | ADD_MOV operand3 | ADD_ASR<br>operand1 | ADD_ASR<br>operand3 | ADD_LSR<br>operand1 | ADD_LSR<br>operand3 | ADD_ASL<br>operand1 | ADD_ASL operand3 | MOV_Lcc<br>operand5 | | | F7 ( | 2nd Byte<br>Lower<br>Upper | 0 | <del>-</del> | 7 | က | 4 | 2 | 9 | 7 | 80 | 6 | ∢ | В | O | ۵ | Ш | Ш | operand1: Rm1,Rn1,Rm2,Rn2 operand2: imm4,Rn1,Rm2.Rn2 operand3: Rm1,Rn1,imm4,Rn2 operand4: imm4,Rn1 operand5: (Rm+,imm4),Rn F8 (3 byte Code) | 2nd Byte | | | | | | | | | | | | | | | | | |------------|-----------------|-----------------|---------------------|---------------------|-----------------|-----------------|---------------------|---------------------|------------------|-----------------|---------------------|---------------------|------------------|-----------------|---------------------|---------------------| | Lower | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | Upper<br>0 | | | | | | | МС | OV (d8, | Am),Dı | า | | | | | | | | 1 | | | | | | | М | OV Dn | n,(d8,A | n) | | | | | | | | 2 | | | | | | | M | 3b) VO | 3,Am), <i>A</i> | ۸n | | | | | | | | 3 | | | | | | | М | OV An | n,(d8,A | n) | | | | | | | | 4 | | | | | | | MC | VBU ( | d8,Am) | ,Dn | | | | | | | | 5 | | | | | | | MC | VBU D | m,(d8, | An) | | | | | | | | 6 | | | | | | | МО | VHU ( | d8,Am) | ,Dn | | | | | | | | 7 | | | | | | | МО | VHU [ | )m,(d8, | An) | | | | | | | | 8 | | | | | | | | | 1 | | | | - | | | | | 9 | | | MOVBU<br>D0,(d8,SP) | MOVHU<br>D0,(d8,SP) | | | MOVBU<br>D1,(d8,SP) | MOVHU<br>D1,(d8,SP) | | | MOVBU<br>D2,(d8,SP) | MOVHU<br>D2,(d8,SP) | | | MOVBU<br>D3,(d8,SP) | MOVHU<br>D3,(d8,SP) | | Α | | | | | | | | | | | | | | | | | | В | | | | | | | | | М | OVBU | (d8,SP) | ),Dn | МС | DHVC | (d8,SP) | ),Dn | | С | ı | ASL in | m8,Dn | ] | | LSR in | nm8,Dr | ) | | ASR in | nm8,Dr | ) | | | MOVM<br>(USP),regs | MOVM<br>regs,(USP) | | D | FBEQ<br>(d8,PC) | FBNE<br>(d8,PC) | FBGT<br>(d8,PC) | FBGE<br>(d8,PC) | FBLT<br>(d8,PC) | FBLE<br>(d8,PC) | FBUO<br>(d8,PC) | FBLG<br>(d8,PC) | FBLEG<br>(d8,PC) | FBUG<br>(d8,PC) | FBUGE<br>(d8,PC) | FBUL<br>(d8,PC) | FBULE<br>(d8,PC) | FBUE<br>(d8,PC) | | | | Е | , | AND in | nm8,Dr | 1 | | OR im | m8,Dn | | BVC<br>(d8,PC) | BVS<br>(d8,PC) | BNC<br>(d8,PC) | BNS<br>(d8,PC) | E | BTST ii | mm8,Dı | า | | F | M | IOV (da | 8,An),S | Р | l N | 10V SF | P,(d8,A | n) | | | | | | | ADD<br>imm8,SP | | F9 (3 byte Code) | 2nd Byte | | | | | | | | | | | | | | | | | |----------------|----------|-----------|-----------|-----------|----------|-----------|-----------|---------|-------------|--------------|------------------|--------|---|---|---|---| | Lower<br>Upper | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | | | | | | | | | | MOV | AND | MOV | MAC | | | | | | 0 | UDF00 | imm8,Dn | (MULQ in | nm,Dn) | | | | | Rm,Rn | Rm,Rn | (Rm),Rn | Rm,Rn | | | | | | 1 | | | | | | | | ъ, | EXT | OR | MOV | MACU | | | | | | ' | | 1 | | | | | (MULQU i | | Rn | | Rm,(Rn) | Rm,Rn | | | | | | 2 | | IOV | FM | | ı | OV | FM | | EXTB | XOR | MOVBU | MACB | | | | | | _ | | ,FSn | (Rm+ | ,, | | ,FSn | Rm, | | Rn | Rm,Rn | (Rm),Rn | | | | | | | 3 | FMOV EXTBU | NOT | MOVBU | MACBU | | | | | | • | FSM,(KN) | FSm,(Rn+) | | F5m,(Kn+) | | | | | Rn | Rn | Rm,(Rn) | Rm,Rn | | | | | | 4 | | FM<br>FSm | | | | .BS<br>Sn | FNI<br>FS | | EXTH | ASR | MOVHU<br>(Rm),Rn | MACH | | | | | | 7 | FDO | | | NDT. | F | | | οΠ | Rn | Rm,Rn | ` '' | Rm,Rn | | | | | | 5 | | QRT<br>Sn | FSC<br>FS | | | FC | ,FSm2 | | EXTHU<br>Rn | LSR<br>Rm,Rn | MOVHU<br>Rm,(Rn) | | | | | | | • | F | FA | | 011 | | FS | | | CLR | ASL | MOV | DMACH | | | | | | 6 | | FSm | | | | FSm | | | Rn | _ | (Rm+),Rn | - | | | | | | | | FM | | | | | )IV | | ADD | ASL2 | | DMACHU | | | | | | 7 | | FSm | | | | FSm | | | Rm,Rn | | Rm,(Rn+) | | | | | | | - | | 1 0111 | ,1 011 | | | 1 0111 | 1,1 011 | | ADDC | ROR | MOV | DMULH | | | | | | 8 | | | | | | | | | Rm,Rn | Rn | (SP),Rn | Rm,Rn | | | | | | | | | | | | | | | SUB | ROL | | DMULHU | | | | | | 9 | | | | | | | | | Rm.Rn | Rn | Rm,(SP) | Rm,Rn | | | | | | İ | FM | IOV | FM | OV | FM | OV | DCPF | DCPF | SUBC | MUL | MOVBU | SAT16 | | | | | | Α | | ,FDn | (Rm+ | | l | ,FDn | (Rm) | (SP) | Rm,Rn | Rm,Rn | (SP),Rn | Rm,Rn | | | | | | _ | FMOV INC | MULU | MOVBU | MCSTE | | | | | | В | FDm,(Rn) | FDm,(Rn+) | FDm,(Rn) | FDm,(Rn+) | FDm,(SP) | Rm,FPCR | FDm,(SP) | FPCR,Rn | Rn | Rm,Rn | Rm,(SP) | Rm,Rn | | | | | | | | FM | OV | | FA | BS | FN | EG | INC4 | DIV | MOVHU | SWAP | | | | | | С | | FDm | ,FDn | | FI | On | FD | On | Rn | Rm,Rn | (SP),Rn | Rm,Rn | | | | | | | FRS | QRT | FSC | QRT | | FC | MP | | CMP | DIVU | MOV | SWAPH | | | | | | D | FI | On | F | On | | FDm1 | ,FDm2 | | Rm,Rn | Rn | Rm,(SP) | Rm,Rn | | | | | | | | FA | DD | | | FS | UB | | MOV | | MOVHU | SWHW | | | | | | E | | FDm | , | | | | ,FDn | | XRm,Rn | | (Rm+),Rn | | | | | | | F | | FM | | | | FD | | | MOV | | MOVHU | BSCH | | | | | | F | | FDm | ,FDn | | | FDm | ,FDn | | Rm,XRn | | Rm,(Rn+) | Rm,Rn | | | | | FA ( 4 byte Code ) | 2nd I | Byte | |-------|------| |-------|------| | Lower<br>Upper | . 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | |----------------|-------------------|--------------------|----------------------|----------------------|--------------------|-------------------|----------------------|----------------------|--------------------|--------------------|----------------------|----------------------|--------------------|--------------------|----------------------|----------------------| | 0 | | | | | | | M | OV (d1 | 6,Am),I | Dn | | | | | | | | 1 | | | | | | | M | OV Dm | ,(d16,A | n) | | | | | | | | 2 | | | | | | | M | OV (d1 | 6,Am), | An | | | | | | | | 3 | | | | | | | M | OV Am | ,(d16,A | n) | | | | | | | | 4 | | | | | | | MO | VBU (d | [16,Am] | ),Dn | | | | | | | | 5 | | | | | | | MO | VBU D | m,(d16 | ,An) | | | | | | | | 6 | | | | | | | MO' | VHU (d | [16,Am] | ),Dn | | | | | | | | 7 | | _ | | | | | MO' | VHU D | m,(d16 | ,An) | | | | | | | | 8 | MOV<br>A0,(abs1 | 6) | | | MOV<br>A1,(abs16) | | | | MOV<br>A2,(abs16) | | | | MOV<br>A3,(abs16) | | | | | 9 | MOV<br>A0,(d16,SF | MOV<br>D0,(d16,SP) | MOVBU<br>D0,(d16,SP) | MOVHU<br>D0,(d16,SP) | MOV<br>A1,(d16,SP) | MOV<br>D1,(d16,SP | MOVBU<br>D1,(d16,SP) | MOVHU<br>D1,(d16,SP) | MOV<br>A2,(d16,SP) | MOV<br>D2,(d16,SP) | MOVBU<br>D2,(d16,SP) | MOVHU<br>D2,(d16,SP) | MOV<br>A3,(d16,SP) | MOV<br>D3,(d16,SP) | MOVBU<br>D3,(d16,SP) | MOVHU<br>D3,(d16,SP) | | Α | ı | MOV (at | os16), <i>P</i> | ۸n | | | | | | | | | | | | | | В | N | 10V (d1 | 6,SP), | An | М | OV (d1 | 16,SP),I | Dn | MO | VBU (d | 116,SP | ),Dn | МО | VHU ( | d16,SP | ),Dn | | С | | ADD im | m16,D | n | | | | | С | MP im | m16,D | n | | | | | | D | | ADD im | m16,A | n | | | | | C | MP im | m16,A | .n | | | | | | Е | | AND im | m16,D | n | ( | OR im | m16,Dr | า | X | OR im | m16,D | n | BTST | imm16 | ,Dn | | | F | В | SET imn | n8,(d8, | An) | ВС | LR imi | m8,(d8, | An) | вт | ST imr | n8,(d8, | An) | AND<br>imm16,PSW | OR<br>imm16,PSW | ADD<br>imm16,SP | CALLS<br>(d16,PC) | | Lower 0 1 2 Upper UDF00 imm16,Dn (MULQ imm,Dn) | 1 2 UDF00 imm16,Dn (MULQ imm,Dn) | 2<br>nm16,Dn<br>imm,Dn) | | 8 | 4 | 2 | 9 | 7 | 8<br>MOV<br>imm8,Rn | 9<br>AND<br>imm8,Rn | A<br>MOV<br>(d8,Rm),Rn | B<br>MAC<br>imm8,Rn | O | D<br>AND<br>Rm,Rn,Rd | MOV<br>(abs8),Rn | F<br>MAC<br>Rm,Rn,Rd1,Rd2 | |-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------|-----------------------|-----------------------|--------------|----------------------|----------------------------------|---------------------|---------------------|---------------------|------------------------|---------------------|------------------|-----------------------|---------------------|---------------------------| | )<br>HONO<br>WORL | ) WUL | ) MUL | UDF( | UDF( | UDF(<br>(MUL | 12<br> - <u>-</u> ∪ö | UDF01 imm16,Dn<br>(MULQU imm,Dn) | | MOVU<br>imm8,Rn | OR<br>imm8,Rn | MOV<br>Rm,(d8,Rn) | MACU<br>imm8,Rn | | OR<br>Rm,Rn,Rd | MOV<br>Rm,(abs8) | MACU<br>Rm,Rn,Rd1,Rd2 | | FMOV FMOV FMOV (d8,Rm),FSn (d8,SP),FSn | FMOV FMOV (Rm+,imm8),FSn (d8,SP),F | FMOV<br>(d8,SP),F | FMOV<br>(d8,SP),F | FMOV<br>(d8,SP),FSn | JV<br>),FSn | | | FMOV<br>(Ri,Rm),FSn | | XOR<br>imm8,Rn | MOVBU<br>(d8,Rm),Rn | MACB<br>imm8,Rn | | XOR<br>Rm,Rn,Rd | MOVBU<br>(abs8),Rn | MACB<br>Rm, Rn, Rd | | FMOV FMOV FMOV FMOV FMOV FMOV FSm.(d8,Rn) FSm.(d8,Rn) FSm.(d8,SP) | FMOV FMOV<br>FSm,(d8,Rn) FSm,(Rn+,imm8) | FMOV FMOV<br>FSm,(d8,Rn) FSm,(Rn+,imm8) | | | | | FMOV<br>FSm,(d8,SP) | FMOV<br>FSm,(Ri,Rn) | | | MOVBU<br>Rm,(d8,Rn) | MACBU<br>imm8,Rn | | | MOVBU<br>Rm,(abs8) | MACBU<br>Rm,Rn,Rd | | FTOI ITOF FABS FSm,FSn FSm,FSn | | | FABS<br>FSm,FSn | FABS<br>FSm,FSn | | | FNEG<br>FSm,FSn | FMOV<br>(Ri,Rm),FDn | | ASR<br>imm8,Rn | MOVHU<br>(d8,Rm),Rn | MACH<br>imm8,Rn | | ASR<br>Rm,Rn,Rd | MOVHU<br>(abs8),Rn | MACH<br>Rm,Rn,Rd1,Rd2 | | FRSQRT FTOD FSQRT FSm,FSn FSm,FSn | | | FSQRT<br>FSm,FSn | FSQRT<br>FSm,FSn | | | DTOF<br>FSm,FSn | FMOV<br>FDm,(Ri,Rn) | | LSR<br>imm8,Rn | MOVHU<br>Rm,(d8,Rn) | MACHU<br>imm8,Rn | | LSR<br>Rm,Rn,Rd | MOVHU<br>Rm,(abs8) | MACHU<br>Rm,Rn,Rd1,Rd2 | | FSDD FSm1,FSm2,FSn | FSUB<br>FSm1,FSm2,FSn | FSUB<br>FSm1,FSm2,FSn | FSUB<br>FSm1,FSm2,FSn | FSUB<br>FSm1,FSm2,FSn | | | | | | ASL<br>imm8,Rn | MOV<br>(Rm+,imm8),Rn | | | ASL<br>Rm,Rn,Rd | | DMACH<br>Rm,Rn,Rd | | FMUL<br>FSm1,Fsm2,FSn | FDIV<br>FSm1,FSm2,FSn | FSm1,FSn | FDIV<br>FSm2,FSn | FDIV<br>FSm1,FSm2,FSn | | | | | ADD<br>imm8,Rn | | MOV<br>Rm,(Rn+,imm8) | | ADD<br>Rm,Rn,Rd | | | DMACHU<br>Rm,Rn,Rd | | FMADD FSm1,FSm2,FSm3,FSn FMSUB FSi | FMSUB | FMSUB | FMSUB | | | m1,F | FSm1,FSm2,FSm3,FSn | FSn | ADDC<br>imm8,Rn | | MOV<br>(d8,SP),Rn | | ADDC<br>Rm,Rn,Rd | | MOV<br>(Ri,Rm),Rn | DMULH<br>Rm,Rn,Rd1,Rd2 | | FNMSUB FSr FNMSUB FSr | FNMSUB | FNMSUB | FNMSUB | ω | ω | ٦, | FSm1,FSm2,FSm3,FSn | ,FSn | SUB<br>imm8,Rn | | MOV<br>Rm,(d8,SP) | | SUB<br>Rm,Rn,Rd | | MOV<br>Rm,(Ri,Rn) | DMULHU<br>Rm,Rn,Rd1,Rd2 | | FMOV FMOV FMOV (d8,Rm),FDn (d8,SP),FDn | FMOV FMOV (Rm+,imm8),FDn (d8,SP),F | FMOV<br>(d8,SP),F | FMOV<br>(d8,SP),F | FMOV<br>(d8,SP),FDn | ov<br>),FDn | | DCPF<br>(Ri,Rm) | DCPF<br>(d8,Rm) | SUBC<br>imm8,Rn | MUL<br>imm8,Rn | MOVBU<br>(d8,SP),Rn | | SUBC<br>Rm,Rn,Rd | MUL<br>Rm,Rn,Rd1,Rd2 | MOVBU<br>(Ri,Rm),Rn | SAT24<br>Rm,Rn | | FMOV FMOV FMOV FMOV FDm.(d8,Rn) FDm.(d8,Rn) FDm.(d8,SP) FDm.(d8,SP) | | | | FMOV<br>FDm,(d8,SP) | | | FMOV<br>FDm,(d8,SP) | | | MULU<br>imm8,Rn | MOVBU<br>Rm,(d8,SP) | MCSTE<br>imm8,Rn | | MULU<br>Rm,Rn,Rd1,Rd2 | MOVBU<br>Rm,(Ri,Rn) | | | FABS<br>FDm,FDn | FABS<br>FDm,FDn | FABS<br>FDm,FDn | FABS<br>FDm,FDn | FABS<br>FDm,FDn | | | FNEG<br>FDm,FDn | | | | MOVHU<br>(d8,SP),Rn | | | | MOVHU<br>(Ri,Rm),Rn | | | FRSQRT FDm,FDn | FSQRT<br>FDm,FDn | FSQRT<br>FDm,FDn | FSQRT<br>FDm,FDn | FSQRT<br>FDm,FDn | | | | | CMP<br>imm8,Rn | | MOVHU<br>Rm,(d8,SP) | | | | MOVHU<br>Rm,(Ri,Rn) | | | FADD FDm1,FDm2,FDn | FSUB<br>FDm1,FDm2,FDn | FSUB<br>FDm1,FDm2,FDn | FSUB<br>FDm1,FDm2,FDn | FSUB<br>FDm1,FDm2,FDn | | | | | | BTST<br>imm8,Rn | MOVHU<br>(Rm+,imm8),Rn | | | | | | | FMUL FDm2,FDn FDm1,FDm2,FDn | FDIV<br>FDm1,FDm2,FDn | FDIV<br>FDm1,FDm2,FDn | FDIV<br>FDm1,FDm2,FDn | FDIV<br>FDm1,FDm2,FDn | | | | | MOV<br>imm8,XRn | | MOVHU<br>Rm,(Rn+,imm8) | | | | | BSCH<br>Rm,Rn,Rd | | | _ | _ | _ | - | | | | | | | | | | | | 4 | FB (4 byte Code) FC (6 byte Code) | 2nd Byte | | | | | | | | | | | | | | | | | |------------|--------------------|--------------------|----------------------|----------------------|--------------------|--------------------|----------------------|----------------------|--------------------|--------------------|----------------------|----------------------|--------------------|--------------------|----------------------|----------------------| | Lower | - | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | Upper<br>0 | | | | | | | М | OV (d3 | 2,Am),l | Dn | | | | | | | | 1 | | | | | | | М | OV Dm | ,(d32, <i>P</i> | ۸n) | | | | | | | | 2 | | | | | | | М | OV (d3 | 2,Am), | An | | | | | | | | 3 | | | | | | | М | OV Am | ,(d32,A | ۸n) | | | | | | | | 4 | | | | | | | MO | VBU (d | 132,Am | ),Dn | | | | | | | | 5 | | | | | | | MO | VBU D | m,(d32 | ,An) | | | | | | | | 6 | | | | | | | MO' | VHU (c | 132,Am | ),Dn | | | | | | | | 7 | | | | | | | MO | VHU D | m,(d32 | ,An) | | | | | | | | 8 | MOV<br>A0,(abs32) | MOV<br>D0,(abs32) | MOVBU<br>D0,(abs32) | MOVHU<br>D0,(abs32) | MOV<br>A1,(abs32) | MOV<br>D1,(abs32) | MOVBU<br>D1,(abs32) | MOVHU<br>D1,(abs32) | MOV<br>A2,(abs32) | MOV<br>D2,(abs32) | MOVBU<br>D2,(abs32) | MOVHU<br>D2,(abs32) | MOV<br>A3(abs32) | MOV<br>D3,(abs32) | MOVBU<br>D3,(abs32) | MOVHU<br>D3,(abs32) | | 9 | MOV<br>A0,(d32,SP) | MOV<br>D0,(d32,SP) | MOVBU<br>D0,(d32,SP) | MOVHU<br>D0,(d32,SP) | MOV<br>A1,(d32,SP) | MOV<br>D1,(d32,SP) | MOVBU<br>D1,(d32,SP) | MOVHU<br>D1,(d32,SP) | MOV<br>A2,(d32,SP) | MOV<br>D2,(d32,SP) | MOVBU<br>D2,(d32,SP) | MOVHU<br>D2,(d32,SP) | MOV<br>A3,(d32,SP) | MOV<br>D3,(d32,SP) | MOVBU<br>D3,(d32,SP) | MOVHU<br>D3,(d32,SP) | | Α | М | OV (a | bs32), <i>F</i> | ٩n | N | 10V (a | abs32), | Dn | MO' | VBU (a | bs32), | Dn | МС | VHU ( | abs32) | ,Dn | | В | M | OV (d3 | 32,SP), | ٩n | М | Sb) VC | 32,SP), | Dn | MO | VBU (c | 132,SP | ),Dn | MC | VHU ( | d32,SP | ),Dn | | С | А | DD in | nm32,D | n | S | SUB in | nm32,D | )n | C | MP im | m32,D | n | N | /IOV im | m32,D | n | | D | А | DD in | nm32,A | ın | 5 | SUB in | nm32, <i>P</i> | ۸n | C | MP im | m32,A | n | N | /IOV im | m32,A | ın | | Е | А | ND in | nm32,D | n | ( | OR im | m32,Dı | n | × | OR im | m32,D | n | В | TST in | nm32,E | )n | | F | | | | | | | | | | | | | AND<br>imm32,EPSW | OR<br>limm32,EPSW | ADD<br>imm32,SP | CALLS<br>(d32,PC) | | Щ | | | | | | | | | | | | | | | | | |----------------------------|---------------------------------|-----------------------------------|-------------------------|------------------------------------------|----------------------|----------------------|---------------------------|---------------------------|--------------------|--------------------|-------------------------|----------------------------------------------------------------------------------------------------------|----------------------|----------------------|-----------------------------|-----------------------------| | Ш | MOV<br>(abs24),Rn | MOV<br>Rm,(abs24) | MOVBU<br>(abs24),Rn | MOVBU<br>Rm,(abs24) | MOVHU<br>(abs24),Rn | MOVHU<br>Rm,(abs24) | | | | | | | | | | | | Ω | | | | | | | | | | | | | | | | | | O | | | | | | | | | | | | | | | | | | В | MAC<br>imm24,Rn | MACU<br>imm24,Rn | MACB<br>imm24,Rn | MACBU<br>imm24,Rn | MACH<br>imm24,Rn | MACHU<br>imm24,Rn | | | | | | | | | | | | ⋖ | MOV<br>(d24,Rm),Rn | MOV<br>Rm,(d24,Rn) | MOVBU<br>(d24,Rm),Rn | MOVBU<br>Rm,(d24,Rn) | MOVHU<br>(d24,Rm),Rn | MOVHU<br>Rm,(d24,Rn) | MOV<br>(Rm+,imm24)<br>,Rn | MOV<br>Rm,<br>(Rn+,imm24) | MOV<br>(d24,SP),Rn | MOV<br>Rm,(d24,SP) | MOVBU<br>(d24,SP),Rn | MOVBU<br>Rm,(d24,SP) | MOVHU<br>(d24,SP),Rn | MOVHU<br>Rm,(d24,SP) | MOVHU<br>(Rm+,imm24)<br>,Rn | MOVHU<br>Rm,<br>(Rn+,imm24) | | თ | AND<br>imm24,Rn | OR<br>imm24,Rn | XOR<br>imm24,Rn | | ASR<br>imm24,Rn | LSR<br>imm24,Rn | ASL<br>imm24,Rn | | | | MUL<br>imm24,Rn | MULU<br>imm24,Rn | | | BTST<br>imm24,Rn | | | ∞ | MOV<br>imm24,Rn | MOVU<br>imm24,Rn | | J I | | | | ADD<br>imm24,Rn | ADDC<br>imm24,Rn | SUB<br>imm24,Rn | SUBC<br>imm24,Rn | | | CMP<br>imm24,Rn | | MOV<br>imm24,XRn | | 7 | | | | | | | | | | | DCPF<br>(d24,Rm) | | | | , | | | 9 | | nm32,Dn<br>mm,Dn) | | FMOV<br>FSm,(d24,SP) | | | | | | | | FMOV<br>Dm,(d24,SP) | | | | | | 2 | | UDFU01 imm32,Dn<br>(MULQU imm,Dn) | V<br>),FSn | ш | | | | | | | V<br>,FDn | FMOV<br>nm32,FPCR F | | | | | | 4 | | | FMOV<br>(d24,SP),F | FMOV<br>FSm,(d24,SP) | | | | | | | FMOV<br>(d24,SP),FDn | FMOV<br>Dm,(d24,SP) | | | | | | က | | | V<br>24),FSn | FMOV<br>FSm,<br>Rn+,imm24) | | | | | | | ۰۷<br>24),FDn | FMOV<br>FDm,<br>Rn+,imm24) | | | | | | 7 | m32,Dn<br>nm,Dn) | | FMOV<br>(Rm+,imm24),FSn | FMOV FMOV FMOV FSm, (424,Rn) (Rn+,imm24) | | | | | | | FMOV<br>(Rm+,imm24),FDn | FMOV<br>Dm,(d24,Rn) | | | | | | <del>-</del> | UDF00 imm32,Dn<br>(MULQ imm,Dn) | | ),FSn | FMOV<br>FSm,<br>Rn+,imm24) | | | | | | | ),FDn | FMOV<br>FDm,<br>Rn+,imm24) | | | | | | 0 | | | FMOV<br>(d24,Rm),FSn | FMOV<br>FSm,(d24,Rn) | | | | | | | FMOV<br>(d24,Rm),FDn | FMOV FDm, (d24,Rn) (Rn+,imm24) FDm, (d24,Rn) (Rn+,imm24) (Rn+,imm24) (Rn+,imm24) (Rn+,imm24) (Rn+,imm24) | | | | | | Znd Byte<br>Lower<br>Unner | i o | ~ | 7 | က | 4 | 2 | 9 | 7 | 80 | თ | A | a a | O | ٥ | ш | ш | FD (6 byte Code) | 0 | BSET<br>imm8,(abs | | р)<br> | FMOV<br>FSm,(d32,F | p) | FMOV<br>FDm,(d32,F | | | BSET<br>imm8,(abs | | | | | | | | |---|------------------------------------------|--------------------|-------------------------|---------------------------------------------------------------------|-------------------------|--------------------------------------------------------|---------------------------|---------------------------|------------------------------------------|--------------------|----------------------|----------------------|----------------------|----------------------|-----------------------------|--------------| | ~ | BSET BCLR BTST imm8.(abs32) jmm8.(abs32) | | FMOV<br>(d32,Rm),FSn | FMOV FSm, (d32,Rn) (Rn+,imm32) | FMOV<br>(d32,Rm),FDn | FMOV FDm, (d32,Rn) (Rn+,imm32) | FADD imm32,FSm,FSn | FMUL imm32,FSm,FSn | BSET BCLR BTST imm8,(abs16) imm8,(abs16) | | | | | | | | | 2 | BTST<br>imm8,(abs32) | | FMOV<br>(Rm+,imm32),FSn | FMOV FSm, FSm, (Rn+,imm32) | FMOV<br>(Rm+,imm32),FDn | FMOV FDM, FMOV FDM, (d32,RN) (Rn+,imm32) FDm, (d32,SP) | 32,FSm,FS | 32,FSm,FS | BTST<br>imm8,(abs16) | | | | | | | | | က | | | OV<br>132),FSn | | OV<br>132),FDn | FMOV<br>FDm,<br>(Rn+,imm32) | Ë | ų | | | | | | | | | | 4 | | | FMOV<br>(d32,SP),FSn | FMOV FCMPi<br>FSm,(d32,SP) | FMOV<br>(d32,SP),FDn | FMOV<br>FDm,(d32,SP) | FSUE | FDIV | | | | | | | | | | 2 | | | uS: | imm32,FS<br>F | uQ. | <u> </u> | B imm32 | / imm32 | | | | | | | | | | 9 | | | FMOV<br>imm32,FSn | FMOV F¢MPimm32,FSn FMOV F¢MPimm32,FSn<br>n,(d32,SP)<br>FSm,(d32,SP) | DCPF<br>(d32,Rm) | FMOV<br>FDm,(d32,SP) | FSUB imm32,FSm,FSn | FDIV imm32,FSm,FSn | | | | | | | | | | 7 | | | -Sn | Pimm32,FS | | | | | | | 1 | | | | ı | | | ∞ | MOV<br>imm32,Rn | MOVU<br>imm32,Rn | | C. | | | 1 | ADD<br>imm32,Rn | ADDC<br>imm32,Rn | SUB<br>imm32,Rn | SUBC<br>imm32,Rn | | , | CMP<br>imm32,Rn | | MOV | | 6 | AND<br>imm32,Rn | OR<br>imm32,Rn | XOR<br>imm32,Rn | | ASR<br>imm32,Rn ( | LSR<br>imm32,Rn | ASL<br>imm32,Rn | | | | MUL<br>imm32,Rn | MULU<br>imm32,Rn | | | BTST<br>imm32,Rn | | | ⋖ | MOV<br>(d32,Rm),Rn | MOV<br>Rm,(d32,Rn) | MOVBU<br>(d32,Rm),Rn | MOVBU<br>Rm,(d32,Rn) | MOVHU<br>(d32,Rm),Rn | MOVHU<br>Rm,(d32,Rn) | MOV<br>(Rm+,imm32)<br>,Rn | MOV<br>Rm,<br>(Rn+,imm32) | MOV<br>(d32,SP),Rn | MOV<br>Rm,(d32,SP) | MOVBU<br>(d32,SP),Rn | MOVBU<br>Rm,(d32,SP) | MOVHU<br>(d32,SP),Rn | MOVHU<br>Rm,(d32,SP) | MOVHU<br>(Rm+,imm32)<br>,Rn | MOVHU<br>Rm, | | В | MAC<br>imm32,Rn | MACU<br>imm32,Rn | MACB<br>imm32,Rn | MACBU<br>imm32,Rn | MACH<br>imm32,Rn | MACHU<br>imm32,Rn | DMACH<br>imm32,Rn | DMACHU<br>imm32,Rn | DMULH<br>imm32,Rn | DMULHU<br>imm32,Rn | | | | | | | | O | | | | | | | | | | | | | | | | | | ۵ | | | | | | | | | | | | | | | | | | ш | MOV<br>(abs32),Rn | MOV<br>Rm,(abs32) | MOVBU<br>(abs32),Rn | MOVBU<br>Rm,(abs32) | MOVHU<br>(abs32),Rn | MOVHU<br>Rm,(abs32) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # **INDEX** ## Α | dd Am, An 7 | '6 | |-------------------------------------------------|------------| | dd Am, Dn7 | 76 | | dd Dm, An7 | 76 | | dd Dm, Dn7 | 76 | | dd imm16, An7 | 77 | | dd imm16, Dn7 | 7 | | dd imm16, SP7 | 77 | | dd imm24, Rn7 | 7 | | dd imm32, An7 | 77 | | dd imm32, Dn7 | 7 | | dd imm32, Rn7 | 7 | | dd imm32, SP7 | 77 | | dd imm8, An7 | 7 | | dd imm8, Dn7 | 77 | | dd imm8, Rn7 | 77 | | dd imm8, SP7 | 77 | | dd Rm, Rn7 | 76 | | dd Rm, Rn, Rd7 | 76 | | dd_add imm4, Rn1, imm4, Rn2 171, 19 | 97 | | dd_add imm4, Rn1, Rm2, Rn2 170, 19 | <b>)</b> 5 | | dd_add Rm1, Rn1, imm4, Rn2 169, 19 | 96 | | dd_add Rm1, Rn1, Rm2, Rn2 168, 19 | )4 | | dd_asI_imm4, Rn1, imm4, Rn2 171, 21 | 9 | | dd_asI_imm4, Rn1, Rm2, Rn2170, 21 | 7 | | dd_asl Rm1, Rn1, imm4, Rn2 169, 21 | 8 | | dd_asl Rm1, Rn1, Rm2, Rn2168, 21 | 6 | | dd_asr_imm4, Rn1, imm4, Rn2 171, 2 <sup>-</sup> | 11 | | dd_asr_imm4, Rn1, Rm2, Rn2 170, 20 | )9 | | dd_asr Rm1, Rn1, imm4, Rn2 169, 21 | 0 | | dd_asr Rm1, Rn1, Rm2, Rn2 168, 20 | 8( | | dd_cmp imm4, Rn1, imm4, Rn2 171, 20 | )3 | | dd_cmp imm4, Rn1, Rm2, Rn2 170, 20 | )2 | | dd_cmp Rm1, Rn1, imm4, Rn2 169, 20 | )3 | | dd_cmp Rm1, Rn1, Rm2, Rn2 168, 20 | )2 | | dd_lsr imm4, Rn1, imm4, Rn2171, 21 | 15 | | dd_lsr imm4, Rn1, Rm2, Rn2170, 21 | 13 | | dd_lsr Rm1, Rn1, imm4, Rn2169, 21 | 4 | | dd_lsr Rm1, Rn1, Rm2, Rn2 168, 21 | 2 | | dd_mov imm4, Rn1, imm4, Rn2 171, 20 | )7 | | dd_mov imm4, Rn1, Rm2, Rn2 170, 20 | )5 | | | | | add_mov Rm1, Rn1, imm4, Rn2 | - 169, | 206 | |------------------------------|--------|------| | add_mov Rm1, Rn1, Rm2, Rn2 | - 168, | 204 | | add_sub imm4, Rn1, imm4, Rn2 | - 171, | 201 | | add_sub imm4, Rn1, Rm2, Rn2 | - 170, | 199 | | add_sub Rm1, Rn1, imm4, Rn2 | -169, | 200 | | add_sub Rm1, Rn1, Rm2, Rn2 | - 168, | 198 | | addc Dm, Dn | | 78 | | addc imm24, Rn | | 79 | | addc imm32, Rn | | 79 | | addc imm8, Rn | | 79 | | addc Rm, Rn | | 78 | | addc Rm, Rn, Rd | | 78 | | and Dm, Dn | | 94 | | and imm16, Dn | | 95 | | and imm16, PSW | | 96 | | and imm24, Rn | | 95 | | and imm32, Dn | | 95 | | and imm32, EPSW | | 96 | | and imm32, Rn | | 95 | | and imm8, Dn | | 95 | | and imm8, Rn | | 95 | | and Rm, Rn | | 94 | | and Rm, Rn, Rd | 94 | , 97 | | and_add Rm1, Rn1, imm4, Rn2 | - 183, | 196 | | and_add Rm1, Rn1, Rm2, Rn2 | | | | and_asl_Rm1, Rn1, imm4, Rn2 | - 183, | 218 | | and_asl Rm1, Rn1, Rm2, Rn2 | | | | and_asr Rm1, Rn1, imm4, Rn2 | | | | and asr Rm1, Rn1, Rm2, Rn2 | | | | and_cmp Rm1, Rn1, imm4, Rn2 | -183, | 203 | | and cmp Rm1, Rn1, Rm2, Rn2 | | | | and_lsr Rm1, Rn1, imm4, Rn2 | | | | and_lsr Rm1, Rn1, Rm2, Rn2 | | | | and_mov Rm1, Rn1, imm4, Rn2 | | | | and_mov Rm1, Rn1, Rm2, Rn2 | | | | and_sub_Rm1, Rn1, imm4 Rn2 | | | | and_sub_Rm1, Rn1, imm4, Rn2 | | | | and_sub_Rm1, Rn1, Rm2, Rn2 | | | | asl imm8, Dn | | | | asl Dm, Dn | | | | asl imm24, Rn | | | | asl imm32, Rn | | | | asl imm8, Rn | | | | asl Rm, Rn | | | | asl Rm, Rn, Rd | | | | asl2 Dn | | | | WOIE DII | | | | asl2 Rn | 117 | С | | |---------------------------------------------------------------|-----|-----------------------------------|-----| | asr imm8, Dn | 110 | CALL (440 DO) 10 10 insure | 405 | | asr Dm, Dn | 108 | CALL (d16, PC), regs, imm8 | | | asr imm24, Rn | 110 | CALL (d32, PC), regs, imm8 | | | asr imm32, Rn | 110 | call label, regs, imm8 125, | | | asr imm8, Rn | 110 | calls (An) | | | asr Rm, Rn | 108 | calls label | | | asr Rm, Rn, Rd | 109 | CALLS (d16, PC) | | | _ | | CALLS (d32, PC) | | | В | | clr Dn | | | bcc label | 120 | clr Rn | | | bclr imm8, (abs16) | 107 | cmp imm16, An | | | bclr imm8, (abs32) | 107 | cmp imm16, Dn | | | bclr imm8, (d8, An) | 107 | cmp imm24, Rn | | | bclr Dm, (An) | 106 | cmp imm32, An | | | bcs label | 120 | cmp imm32, Dn | | | beg label | 120 | cmp imm32, Rn | | | bge label | | cmp imm8, An | | | bgt label | | cmp imm8, Dn | 93 | | bhi label | | cmp imm8, Rn | 93 | | ble label | | cmp Am, An | 92 | | bls label | | cmp Am, Dn | 92 | | bit label | | cmp Dm, An | 92 | | bnc label | | cmp Dm, Dn | 92 | | bne label | | cmp Rm, Rn | 92 | | bns label | | cmp_add imm4, Rn1, imm4, Rn2 173, | 197 | | bra label | | cmp_add imm4, Rn1, Rm2, Rn2 | | | | | cmp_add Rm1, Rn1, imm4, Rn2 172, | | | bsch Rm, Rn | | cmp_add Rm1, Rn1, Rm2, Rn2 172, | | | bsch Rm, Rn, Rd | | cmp_asl imm4, Rn1, imm4, Rn2 173, | | | bset imm8, (abs32) | | cmp_asl imm4, Rn1, Rm2, Rn2 | | | bset imm8, (d8, An) | | cmp_asl Rm1, Rn1, imm4, Rn2 172, | | | bset Dm, (An) | | cmp asl Rm1, Rn1, Rm2, Rn2172, | | | bset imm8, (abs16) | | cmp asr imm4, Rn1, imm4, Rn2 173, | | | btst imm16, Dn | | · <del>-</del> | | | btst imm24, Rn | 103 | cmp_asr_imm4, Rn1, Rm2, Rn2 | | | btst $imm32$ , $Dn$ | 103 | cmp_asr Rm1, Rn1, imm4, Rn2172, | | | $btst \hspace{0.2cm} imm32, \hspace{0.2cm} Rn \hspace{0.2cm}$ | 103 | cmp_asr Rm1, Rn1, Rm2, Rn2172, | | | btst imm8, (abs16) | 103 | cmp_lsr imm4, Rn1, imm4, Rn2 173, | | | btst imm8, (abs32) | 103 | cmp_lsr imm4, Rn1, Rm2, Rn2 | | | btst imm8, (d8, An) | 103 | cmp_lsr Rm1, Rn1, imm4, Rn2172, | | | btst imm8, Dn | 103 | cmp_lsr Rm1, Rn1, Rm2, Rn2 | | | btst imm8, Rn | 103 | cmp_mov imm4, Rn1, imm4, Rn2 173, | | | bvc label | | cmp_mov imm4, Rn1, Rm2, Rn2 | | | bvs label | | cmp_mov Rm1, Rn1, imm4, Rn2 172, | 206 | | | - | cmp_mov Rm1, Rn1, Rm2, Rn2172, | 204 | | | | cmp_sub imm4, Rn1, imm4, Rn2 173, | 201 | | | | cmn suh imm/ Rn1 Rm2 Rn2 | 100 | | cmp_sub Rm1, Rn1, imm4, Rn2172, 200 | E | | |-------------------------------------------------------------------------------|----------------------|-----| | cmp_sub Rm1, Rn1, Rm2, Rn2172, 198 | aut De | 60 | | D | ext Dn | | | | extb Rm, Rn | | | dcpf (d24, Rm)75 | extb Dn | | | dcpf (d32, Rm)75 | extb Rn | | | dcpf (d8, Rm)75 | extbu Rm, Rn | | | dcpf (Ri, Rm)75 | extbu Dn | | | dcpf (Rm)75 | extbu Rn | | | dcpf (SP)75 | exth Rm, Rn | | | div Rm, Rn88 | exth Dn | | | div Dm, Dn88 | exth Rn | | | divu Rm, Rn89 | exthu Dn | | | divu Dm, Dn89 | exthu Rm, Rn | | | dmach imm32, Rn142 | exthu Rn | | | dmach Rm, Rn141 | | | | dmach Rm, Rn, Rd141 | F | | | dmach_add Rm1, Rn1, imm4, Rn2 189 | fabs FSm, FSn | 253 | | dmach_add Rm1, Rn1, Rm2, Rn2 188, 194 | fabs FSn | | | dmach_add Rm1,Rn1,imm4,Rn2196 | fadd FSm, FSn | 260 | | dmach_asl Rm1, Rn1, imm4, Rn2 189, 218 | fadd FSm1, FSm2, FSn | 260 | | dmach_asl Rm1, Rn1, Rm2, Rn2 188, 216 | fadd imm32, FSm, FSn | 261 | | dmach_asr Rm1, Rn1, imm4, Rn2 189, 210 | fbeq label | 296 | | dmach_asr Rm1, Rn1, Rm2, Rn2 188, 208 | fbge label | 296 | | dmach_cmp Rm1, Rn1, imm4, Rn2 189 | fbgt label | 296 | | dmach_cmp Rm1, Rn1, imm4,Rn2 203 | fble label | 296 | | dmach_cmp Rm1, Rn1, Rm2, Rn2 188, 202 | fbleg label | 296 | | dmach_lsr Rm1, Rn1, imm4, Rn2189, 214<br>dmach_lsr Rm1, Rn1, Rm2, Rn2188, 212 | fblg label | 296 | | dmach_mov Rm1, Rn1, imm4, Rn2 189 | fblt label | 296 | | dmach_mov Rm1, Rn1, Rm2, Rn2 188, 204 | fbne label | 296 | | dmach mov Rm1, Rn1, imm4,Rn2 206 | fbue label | 296 | | dmach_sub_Rm1, Rn1, imm4, Rn2 189 | fbug label | 296 | | dmach_sub_Rm1, Rn1, Rm2, Rn2 188, 198 | fbuge label | 296 | | dmach sub Rm1,Rn1, imm4, Rn2 200 | fbul label | 296 | | dmachu imm32, Rn 144 | fbule label | 296 | | dmachu Rm, Rn 143 | fbuo label | 296 | | dmachu Rm, Rn, Rd 143 | fcmp FSm1, FSm2 | 257 | | dmulh imm32, Rn 138 | fcmp imm32, FSm, FSn | 257 | | dmulh Rm, Rn 137 | fdiv FSm, FSn | 269 | | dmulh Rm, Rn, Rd1, Rd2 137 | fdiv FSm1, FSm2, FSn | | | dmulhu imm32, Rn 140 | fdiv imm32, FSm, FSn | | | dmulhu Rm, Rn 139 | fleq | | | dmulhu Rm, Rn, Rd1, Rd2 139 | flge | | | ,,, | flgt | 297 | | | flle | | | | flleg | 297 | | fllg | 297 | fmov FDm,(Rn+,imm32) | 252 | |-----------------------------|-----|------------------------------|-----------| | fllt | 297 | fmov FDm,(Rn+,imm8) | 252 | | flne | 297 | fmov FDm,(Rn+) | 251 | | flue | 297 | fmov FDm,(SP) | 248 | | flug | 297 | fmov FPCR,Rn | 244 | | fluge | 297 | fmov FSm, (d24, Rn) | 237 | | flul | 297 | fmov FSm, (d24, SP) | 237 | | flule | 297 | fmov FSm, (d32, Rn) | 237 | | fluo | 297 | fmov FSm, (d32, SP) | 237 | | fmadd FSm1, FSm2, FSm3, FSn | 272 | fmov FSm, (d8, Rn) | 237 | | fmov (d24, Rm), FSn | 236 | fmov FSm, (d8, SP) | 237 | | fmov (d24, SP), FSn | 236 | fmov FSm, (Rn, Ri) | 237 | | fmov (d32, Rm), FSn | 236 | fmov FSm, (Rn) | 237 | | fmov (d32, SP), FSn | 236 | fmov FSm, (Rn+, imm24) | 241 | | fmov (d8, Rm), FSn | 236 | fmov FSm, (Rn+, imm32) | 241 | | fmov (d8, SP), FSn | 236 | fmov FSm, (Rn+, imm8) | 241 | | fmov (Rm, Ri), FSn | 236 | fmov FSm, (SP) | 237 | | fmov (Rm), FSn | 236 | fmov FSm, FSn | 242 | | fmov (Rm+), FSn | 238 | fmov FSn, (Rn+) | 240 | | fmov (SP), FSn | 236 | fmov imm32,FPCR | 246 | | fmov FSm, Rn | 242 | fmov imm32,FSn | 243 | | fmov (d24,Rm),FDn | 247 | fmov Rm,FPCR | 245 | | fmov (d24,SP),FDn | 247 | fmov Rm,FSn | 243 | | fmov (d32,Rm),FDn | 247 | fmsub FSm1, FSm2, FSm3, FSn | 278 | | fmov (d32,SP),FDn | 247 | fmul FSm, FSn | 266 | | fmov (d8,Rm),FDn | 247 | fmul FSm1, FSm2, FSn | 266 | | fmov (d8,SP),FDn | 247 | fmul imm32, FSm, FSn | 267 | | fmov (Rm,Ri),FDn | 247 | fneg FSm, FSn | 254 | | fmov (Rm),FDn | 247 | fneg FSn | 254 | | fmov (Rm+,imm24),FDn | 250 | fnmadd FSm1, FSm2, FSm3, FSn | 284 | | fmov (Rm+,imm32),FDn | 250 | fnmsub FSm1, FSm2, FSm3, FSn | 290 | | fmov (Rm+,imm8),FDn | 250 | frsqrt FSm | 255 | | fmov (Rm+),FDn | 249 | frsqrt FSm, FSn | 255 | | fmov (Rn+, imm24), FSn | 239 | fsub FSm1, FSm2, FSn | 263 | | fmov (Rn+, imm32), FSn | 239 | fsub imm32, FSm, FSn | 264 | | fmov (Rn+, imm8), FSn | 239 | fsud FSm, FSn | 263 | | fmov (SP),FDn | 247 | | | | fmov FDm,(d24,Rn) | 248 | <b>I</b> | | | fmov FDm,(d24,SP) | | inc An | 90 | | fmov FDm,(d32,Rn) | | inc Dn | 90 | | fmov FDm,(d32,SP) | | inc Rn | 90 | | fmov FDm,(d8,Rn) | | inc4 An | 91 | | fmov FDm,(d8,SP) | | inc4 Rn | 91 | | fmov FDm,(Rn,Ri) | | | | | fmov FDm,(Rn) | | J | | | fmov FDm,(Rn+,imm24) | | jmp label | -123, 124 | | jmp (An) 123 | machu imm24, Rn | 152 | |--------------------------|------------------------|-----| | JMP (d16, PC) 123 | machu imm32, Rn | 152 | | JMP (d32, PC) 124 | machu Rm, Rn | 151 | | | machu Rm, Rn, Rd1, Rd2 | 151 | | L | macu imm24, Rn | 148 | | lcc label 121 | macu imm32, Rn | 148 | | lcs label121 | macu imm8, Rn | 148 | | leq label 121 | macu Rm, Rn | | | lge label 121 | macu Rm, Rn, Rd1, Rd2 | 147 | | lgt label 121 | mcste imm8, Rn | | | lhi label121 | mcste Rm, Rn | | | lle label121 | mov (Rm+), Rn | | | lls label 121 | mov Am, An | | | Ilt label 121 | mov Am, Dn | | | Ine label121 | mov Am, MSP | | | Ira label 121 | mov Am, Rn | | | Isr imm8, Dn 113 | mov Am, SP | | | lsr Dm, Dn 111 | mov Am, SSP | | | Isr imm24, Rn 113 | mov Am, USP | | | lsr imm32, Rn 113 | mov Dm, An | | | Isr imm8, Rn 113 | mov Dm, Dn | | | Isr Rm, Rn 111 | mov Dm, EPSW | | | Isr Rm, Rn, Rd 112 | mov Dm, MDR | | | | mov Dm, PSW | | | M | mov Dm, Rn | | | mac imm24, Rn 146 | mov EPSW, Dn | | | mac imm32, Rn 146 | mov imm16, An | | | mac imm8, Rn 146 | mov imm16, Dn | | | mac Rm, Rn 145 | mov imm24, Rn | 33 | | mac Rm, Rn, Rd1, Rd2 145 | mov imm32, An | 33 | | macb imm8, Rn 154 | mov imm32, Dn | 33 | | macb imm24, Rn 154 | mov imm32, Rn | 33 | | macb imm32, Rn 154 | mov imm8, An | 33 | | macb Rm, Rn 153 | mov imm8, Dn | 33 | | macb Rm, Rn, Rd 153 | mov imm8, Rn | 33 | | macbu imm8, Rn 156 | mov MCRH, Rn | 42 | | macbu imm24, Rn 156 | mov MCRL, Rn | 43 | | macbu imm32, Rn 156 | mov MCVF, Rn | 44 | | macbu Rm, Rn 155 | mov MDR, Dn | 39 | | macbu Rm, Rn, Rd 155 | mov MDRQ, Rn | 41 | | mach imm8, Rn 150 | mov MSP, An | 34 | | mach imm24, Rn 150 | mov PC, An | 45 | | mach imm32, Rn 150 | mov PSW, Dn | 38 | | mach Rm, Rn 149 | mov Rm, (Rn+) | 51 | | mach Rm, Rn, Rd1, Rd2149 | mov Rm, An | 33 | | machu imm8, Rn 152 | mov Rm, Dn | 33 | | I | | | | mov | Rm, MCRH | 42 | mov | Am,(abs16) | 48 | |-----|------------------|----|-----|------------------|----| | mov | Rm, MCRL | 43 | mov | Am,(abs32) | 48 | | mov | Rm, MCVF | 44 | mov | Am,(An) | 48 | | mov | Rm, MDRQ | 41 | mov | Am,(d16,An) | 48 | | mov | Rm, Rn | 33 | mov | Am,(d16,SP) | 48 | | mov | Rm, SP | 40 | mov | Am,(d32,An) | 48 | | mov | SP, An | 40 | mov | Am,(d32,SP) | 49 | | mov | SP, Rn | 40 | mov | Am,(d8,An) | 48 | | mov | SSP, An | 35 | mov | Am,(d8,SP) | 48 | | mov | USP, An | 36 | mov | Am,(Di,An) | 48 | | mov | (abs16),An | 46 | mov | Dm,(abs16) | 48 | | mov | (abs16),Dn | 46 | mov | Dm,(abs32) | 48 | | mov | (abs24),Rn | 46 | mov | Dm,(An) | 48 | | mov | (abs32),An | 46 | mov | Dm,(d16,An) | 48 | | mov | (abs32),Dn | 46 | mov | Dm,(d16,SP) | 48 | | mov | (abs32),Rn | 46 | mov | Dm,(d32,An) | 48 | | mov | (abs8),Rn | 46 | mov | Dm,(d32,SP) | 48 | | mov | (Am),An | 46 | mov | Dm,(d8,An) | 48 | | mov | (Am),Dn | 46 | mov | Dm,(d8,SP) | 48 | | mov | (d16,Am),An | 46 | mov | Dm,(Di,An) | 48 | | mov | (d16,Am),Dn | 46 | mov | imm24, MCRH | 42 | | mov | (d16,SP),An | 46 | mov | imm24, MCRL | 43 | | mov | (d16,SP),Dn | 46 | mov | imm24, MCVF | 44 | | mov | (d24,Rm),Rn | 46 | mov | imm24, MDRQ | 41 | | mov | (d24,SP),Rn | 47 | mov | imm24, SP | 40 | | mov | (d32,Am),An | 46 | mov | imm32, MCRH | 42 | | mov | (d32,Am),Dn | 46 | mov | imm32, MCRL | 43 | | mov | (d32,Rm),Rn | 46 | mov | imm32, MCVF | 44 | | mov | (d32,SP),An | 47 | mov | imm32, MDRQ | 41 | | mov | (d32,SP),Dn | 46 | mov | imm32, SP | 40 | | | (d32,SP),Rn | | mov | imm8, MCRH | 42 | | mov | (d8,Am),An | 46 | mov | imm8, MCRL | 43 | | mov | (d8,Am),Dn | 46 | mov | imm8, MCVF | 44 | | mov | (d8,Am),SP | 47 | mov | imm8, MDRQ | 41 | | mov | (d8,Rm),Rn | 46 | mov | imm8, SP | 40 | | mov | (d8,SP),An | 46 | mov | Rm, (Rn+, imm24) | 51 | | mov | (d8,SP),Dn | 46 | mov | Rm, (Rn+, imm32) | 51 | | mov | (d8,SP),Rn | 47 | mov | Rm, (Rn+, imm8) | 51 | | mov | (Di,Am),An | 46 | mov | Rm,(abs24) | 48 | | mov | (Di,Am),Dn | 46 | mov | Rm,(abs32) | 48 | | mov | (Ri,Rm),Rn | 46 | mov | Rm,(abs8) | 48 | | mov | (Rm),Rn | 46 | mov | Rm,(d24,Rn) | 48 | | mov | (Rm+, imm24), Rn | 50 | mov | Rm,(d24,SP) | 49 | | mov | (Rm+, imm32), Rn | 50 | mov | Rm,(d32,Rn) | 48 | | mov | (Rm+, imm8), Rn | 50 | mov | Rm,(d32,SP) | 49 | | mov | (SP),Rn | 47 | mov | Rm,(d8,Rn) | 48 | | | | | mov | Rm,(d8,SP) | 49 | | mov Rm,(Ri,Rn)48 | movbu (abs32),Rn | 59 | |---------------------------------------|-------------------|----| | mov Rm,(Rn)48 | movbu (abs8),Rn | 59 | | mov Rm,(SP)49 | movbu (Am),Dn | 59 | | mov SP,(d8,An)49 | movbu (d16,Am),Dn | 59 | | mov_add imm4, Rn1, imm4, Rn2 181, 197 | movbu (d16,SP),Dn | 59 | | mov_add imm4, Rn1, Rm2, Rn2 180, 195 | movbu (d24,Rm),Rn | 59 | | mov_add Rm1, Rn1, imm4, Rn2 179, 196 | movbu (d24,SP),Rn | 59 | | mov_add Rm1, Rn1, Rm2, Rn2178, 194 | movbu (d32,Am),Dn | 59 | | mov_asl imm4, Rn1, imm4, Rn2 181, 219 | movbu (d32,Rm),Rn | 59 | | mov_asl imm4, Rn1, Rm2, Rn2 180, 217 | movbu (d32,SP),Dn | 59 | | mov_asl Rm1, Rn1, imm4, Rn2 179, 218 | movbu (d32,SP),Rn | | | mov_asl Rm1, Rn1, Rm2, Rn2178, 216 | movbu (d8,Am),Dn | 59 | | mov_asr imm4, Rn1, imm4, Rn2 181, 211 | movbu (d8,Rm),Rn | 59 | | mov_asr imm4, Rn1, Rm2, Rn2 180, 209 | movbu (d8,SP),Dn | | | mov_asr Rm1, Rn1, imm4, Rn2 179, 210 | movbu (d8,SP),Rn | 59 | | mov_asr Rm1, Rn1, Rm2, Rn2 178, 208 | movbu (Di,Am),Dn | 59 | | mov_cmp imm4, Rn1, imm4, Rn2 181, 203 | movbu (Ri,Rm),Rn | 59 | | mov_cmp imm4, Rn1, Rm2, Rn2 180, 202 | movbu (Rm),Rn | 59 | | mov_cmp Rm1, Rn1, imm4, Rn2 179, 203 | movbu (SP),Rn | 59 | | mov_cmp Rm1, Rn1, Rm2, Rn2 178, 202 | movbu Dm,(abs16) | 60 | | mov_lcc (Rm+, imm4), Rn 221 | movbu Dm,(abs32) | 60 | | mov_lcs (Rm+, imm4), Rn 221 | movbu Dm,(An) | 60 | | mov_leq (Rm+, imm4), Rn 221 | movbu Dm,(d16,An) | 60 | | mov_lge (Rm+, imm4), Rn 221 | movbu Dm,(d16,SP) | 60 | | mov_lgt (Rm+, imm4), Rn 221 | movbu Dm,(d32,An) | | | mov_lhi (Rm+, imm4), Rn 221 | movbu Dm,(d32,SP) | | | mov_lle (Rm+, imm4), Rn 221 | movbu Dm,(d8,An) | | | mov_lls (Rm+, imm4), Rn 221 | movbu Dm,(d8,SP) | 60 | | mov_llt (Rm+, imm4), Rn 221 | movbu Dm,(Di,An) | 60 | | mov_lne (Rm+, imm4), Rn 221 | movbu Rm,(abs24) | | | mov_lra (Rm+, imm4), Rn221 | movbu Rm,(abs32) | | | mov_lsr imm4, Rn1, imm4, Rn2181, 215 | movbu Rm,(abs8) | | | mov_lsr imm4, Rn1, Rm2, Rn2 180, 213 | movbu Rm,(d24,Rn) | | | mov_lsr Rm1, Rn1, imm4, Rn2 179, 214 | movbu Rm,(d24,SP) | 60 | | mov_lsr Rm1, Rn1, Rm2, Rn2 178, 212 | movbu Rm,(d32,Rn) | 60 | | mov_mov imm4, Rn1, imm4, Rn2 181, 207 | movbu Rm,(d32,SP) | 60 | | mov_mov imm4, Rn1, Rm2, Rn2 180, 205 | movbu Rm,(d8,Rn) | | | mov_mov Rm1, Rn1, imm4, Rn2 179, 206 | movbu Rm,(d8,SP) | 60 | | mov_mov Rm1, Rn1, Rm2, Rn2 178, 204 | movbu Rm,(Ri,Rn) | 60 | | mov_sub_imm4, Rn1, imm4, Rn2181, 201 | movbu Rm,(Rn) | 60 | | mov_sub imm4, Rn1, Rm2, Rn2180, 199 | movbu Rm,(SP) | | | mov_sub Rm1, Rn1, imm4, Rn2179, 200 | movhu (Rm+), Rn | | | mov_sub Rm1, Rn1, Rm2, Rn2178, 198 | movhu Rm, (Rn+) | | | movbu (abs16),Dn59 | movhu (abs16),Dn | 53 | | movbu (abs24),Rn59 | movhu (abs24),Rn | 53 | | movbu (abs32),Dn59 | movhu (abs32),Dn | 53 | | | | | | movhu | (abs32),Rn | -53 | movhu Rm(Rn+, imm8) | | 58 | |-------|------------------|-----|---------------------------------|--------|-----| | movhu | (abs8),Rn | -53 | movm (SP), [reg1, reg2,,,regn] | | 61 | | movhu | (Am),Dn | -53 | movm (USP),[reg1, reg2,,,regn] | | 65 | | movhu | (d16,Am),Dn | -53 | movm [reg1, reg2,,,regn], (SP) | | | | movhu | (d16,SP),Dn | -53 | movm [reg1, reg2,,,regn], (USP) | | | | | (d24,Rm),Rn | | movu imm24, Rn | | | | | (d24,SP),Rn | | movu imm32, Rn | | | | | (d32,Am),Dn | | movu imm8, Rn | | | | | (d32,Rm),Rn | | mul Dm, Dn | | | | | (d32,SP),Dn | | mul imm24, Rn | | | | | (d32,SP),Rn | | mul imm32, Rn | | | | | (d8,Am),Dn | | mul imm8, Rn | | | | | (d8,Rm),Rn | | mul Rm, Rn | | | | | (d8,SP),Dn | | mul Rm, Rn, Rd1, Rd2 | | | | | (d8,SP),Rn | | mulu Dm, Dn | | | | | (Di,Am),Dn | | mulu imm24, Rn | | | | | (Ri,Rm),Rn | | mulu imm32, Rn | | | | | (Rm),Rn | | mulu imm8, Rn | | | | | (Rm+, imm24), Rn | | mulu Rm, Rn | | | | | (Rm+, imm32), Rn | | mulu Rm, Rn, Rd1, Rd2 | | | | | (Rm+, imm8), Rn | | | | | | | (SP),Rn | | N | | | | | Dm,(abs16) | | nop | | 134 | | | Dm,(abs32) | | not Dn | | | | | Dm,(An) | | not Rn | | | | | Dm,(d16,An) | | | | | | | Dm,(d16,SP) | | 0 | | | | | Dm,(d32,An) | | or imm8, Rn | | 98 | | | Dm,(d32,SP) | | or Dm, Dn | | 97 | | | Dm,(d8,An) | | or imm16, Dn | | 98 | | | Dm,(d8,SP) | | or imm16, PSW | | 99 | | | Dm,(Di,An) | | or imm24, Rn | | 98 | | | Rm,(abs24) | | or imm32, Dn | | 98 | | | Rm,(abs32) | | or imm32, EPSW | | 99 | | | Rm,(abs8) | | or imm32, Rn | | 98 | | | Rm,(d24,Rn) | | or imm8, Dn | | 98 | | | Rm,(d24,SP) | | or Rm, Rn | | 97 | | | Rm,(d32,Rn) | | or_add Rm1, Rn1, imm4, Rn2 | - 185, | 196 | | | Rm,(d32,SP) | | or_add Rm1, Rn1, Rm2, Rn2 | 184, | 194 | | | Rm,(d8,Rn) | | or_asl Rm1, Rn1, imm4, Rn2 | - 185, | 218 | | | Rm,(d8,SP) | | or_asl Rm1, Rn1, Rm2, Rn2 | -184, | 216 | | | Rm,(Ri,Rn) | | or_asr Rm1, Rn1, imm4, Rn2 | -185, | 210 | | | Rm,(Rn) | | or_asr Rm1, Rn1, Rm2, Rn2 | - 184, | 208 | | | Rm,(SP) | | or_cmp Rm1, Rn1, imm4, Rn2 | - 185, | 203 | | | Rm(Rn+, imm24) | | or_cmp Rm1, Rn1, Rm2, Rn2 | - 184, | 202 | | | Rm(Rn+, imm32) | | or_lsr Rm1, Rn1, imm4, Rn2 | ·185, | 214 | | | | | I . | | | | or_lsr Rm1, Rn1, Rm2, Rn2184, | 212 | sub Rm, Rn | 80 | |------------------------------------|-----|----------------------------------|--------| | or_mov Rm1, Rn1, imm4, Rn2 185, | 206 | sub Rm, Rn, Rd | 80 | | or_mov Rm1, Rn1, Rm2, Rn2184, | 204 | sub_add imm4, Rn1, imm4, Rn2 17 | 7, 197 | | or_sub Rm1, Rn1, imm4, Rn2185, | 200 | sub_add imm4, Rn1, Rm2, Rn2 176 | 3, 195 | | or_sub Rm1, Rn1, Rm2, Rn2184, | 198 | sub_add Rm1, Rn1, imm4, Rn2 175 | 5, 196 | | P | | sub_add Rm1, Rn1, Rm2, Rn2 174 | 1, 194 | | • | | sub_asl imm4, Rn1, imm4, Rn2 177 | 7, 219 | | pi | 136 | sub_asl imm4, Rn1, Rm2, Rn2 170 | 3, 217 | | R | | sub_asl Rm1, Rn1, imm4, Rn2175 | 5, 218 | | | | sub_asl Rm1, Rn1, Rm2, Rn2174 | 1, 216 | | ret | | sub_asr imm4, Rn1, imm4, Rn2 17 | 7, 211 | | retf | | sub_asr imm4, Rn1, Rm2, Rn2 176 | 3, 209 | | rets | | sub_asr Rm1, Rn1, imm4, Rn2 175 | 5, 210 | | rol Dn | | sub_asr Rm1, Rn1, Rm2, Rn2 174 | 1, 208 | | rol Rn | | sub_cmp imm4, Rn1, imm4, Rn2 17 | 7, 203 | | ror Dn | | sub_cmp imm4, Rn1, Rm2, Rn2 170 | 3, 202 | | ror Rn | 118 | sub_cmp Rm1, Rn1, imm4, Rn2 175 | 5, 203 | | rti | 132 | sub_cmp Rm1, Rn1, Rm2, Rn2174 | 1, 202 | | S | | sub_lsr imm4, Rn1, imm4, Rn2 17 | 7, 215 | | | | sub_lsr imm4, Rn1, Rm2, Rn2 176 | 3, 213 | | sat16 Rm, Rn | 160 | sub_lsr Rm1, Rn1, imm4, Rn2 175 | 5, 214 | | sat16_add Rm1, Rn1, imm4, Rn2193, | 196 | sub_lsr Rm1, Rn1, Rm2, Rn2 174 | 1, 212 | | sat16_add Rm1, Rn1, Rm2, Rn2 192, | 194 | sub_mov imm4, Rn1, imm4, Rn2 177 | 7, 207 | | sat16_asl Rm1, Rn1, imm4, Rn2 193, | 218 | sub_mov imm4, Rn1, Rm2, Rn2 176 | 3, 205 | | sat16_asl Rm1, Rn1, Rm2, Rn2192, | 216 | sub_mov Rm1, Rn1, imm4, Rn2 175 | 5, 206 | | sat16_asr Rm1, Rn1, imm4, Rn2193, | 210 | sub_mov Rm1, Rn1, Rm2, Rn2 174 | 1, 204 | | sat16_asr Rm1, Rn1, Rm2, Rn2 192, | 208 | sub_sub_imm4, Rn1, imm4, Rn2 177 | 7, 201 | | sat16_cmp Rm1, Rn1, imm4, Rn2 193, | 203 | sub_sub_imm4, Rn1, Rm2, Rn2176 | 3, 199 | | sat16_cmp Rm1, Rn1, Rm2, Rn2 192, | 202 | sub_sub_Rm1, Rn1, imm4, Rn2 179 | 5, 200 | | sat16_lsr Rm1, Rn1, imm4, Rn2 193, | 214 | sub_sub_Rm1, Rn1, Rm2, Rn2174 | 1, 198 | | sat16_lsr Rm1, Rn1, Rm2, Rn2192, | 212 | subc Dm, Dn | 82 | | sat16_mov Rm1, Rn1, imm4, Rn2 193, | 206 | subc imm24, Rn | 83 | | sat16_mov Rm1, Rn1, Rm2, Rn2 192, | 204 | subc imm32, Rn | 83 | | sat16_sub Rm1, Rn1, imm4, Rn2 193, | 200 | subc imm8, Rn | 83 | | sat16_sub Rm1, Rn1, Rm2, Rn2 192, | 198 | subc Rm, Rn | 82 | | sat24 Rm, Rn | 161 | subc Rm, Rn, Rd | 82 | | setlb | 122 | swap Rm, Rn | 158 | | sub imm24, An | 81 | swaph Rm, Rn | 159 | | sub imm32, Rn | 81 | swhw Rm, Rn | 157 | | sub imm8, Dn | 81 | swhw_add Rm1, Rn1, imm4, Rn2 19 | 1, 196 | | sub Am, An | 80 | swhw_add Rm1, Rn1, Rm2, Rn2 190 | ), 194 | | sub Am, Dn | 80 | swhw_asl Rm1, Rn1, imm4, Rn2 19 | 1, 218 | | sub Dm, An | 80 | swhw_asl Rm1, Rn1, Rm2, Rn2 190 | ), 216 | | sub Dm, Dn | 80 | swhw_asr Rm1, Rn1, imm4, Rn219 | | | sub imm32, An | 81 | swhw_asr Rm1, Rn1, Rm2, Rn2190 | | | sub imm32, Dn | 81 | swhw cmp Rm1, Rn1, imm4, Rn2 19 | | | swhw_cmp Rm1, Rn1, Rm2, Rn2 190, | 202 | |-----------------------------------|-----| | swhw_lsr Rm1, Rn1, imm4, Rn2 191, | 214 | | swhw_lsr Rm1, Rn1, Rm2, Rn2190, | 212 | | swhw_mov Rm1, Rn1, imm4, Rn2 191, | 206 | | swhw_mov Rm1, Rn1, Rm2, Rn2 190, | 204 | | swhw_sub Rm1, Rn1, imm4, Rn2 191, | 200 | | swhw_sub Rm1, Rn1, Rm2, Rn2 190, | 198 | | syscall imm4 | 135 | | т | | | trap | 133 | | · | 100 | | U | | | udf00 Dm, Dn | 222 | | udf00 imm16, Dn | 222 | | udf00 imm32, Dn | 222 | | udf00 imm8, Dn | 222 | | udf01 Dm, Dn | 223 | | udf02 Dm, Dn | 225 | | udf03 Dm, Dn | 226 | | udf04 Dm, Dn | 227 | | udf05 Dm, Dn | 228 | | udf06 Dm, Dn | 229 | | udf07 Dm, Dn | 230 | | udf08 Dm, Dn | 231 | | udf09 Dm, Dn | 232 | | udf12 Dm, Dn | 233 | | udf13 Dm, Dn | 234 | | udf15 Dm, Dn | 235 | | udfu01 imm16, Dn | 223 | | $udfu01\ imm32,Dn$ | | | udfu01 imm8, Dn | 223 | | x | | | xor imm24,Rn | 101 | | xor Dm, Dn | | | xor imm16, Dn | | | xor imm32, Dn | | | xor imm32, Rn | | | xor imm8, Rn | | | xor Rm, Rn | 100 | | xor Rm, Rn, Rd | 100 | | xor_add Rm1, Rn1, imm4, Rn2 187, | 196 | | xor_add Rm1, Rn1, Rm2, Rn2 186, | | | xor_asl Rm1, Rn1, imm4, Rn2 187, | 218 | | xor_asl Rm1, Rn1, Rm2, Rn2186, | 216 | | xor_asr Rm1, Rn1, imm4, Rn2187, | 210 | |---------------------------------------------|-----| | xor_asr Rm1, Rn1, Rm2, Rn2 186, | 208 | | $xor\_cmp\ Rm1,Rn1,imm4,Rn2187,$ | 203 | | $xor\_cmp\ Rm1,Rn1,Rm2,Rn2186,$ | 202 | | $xor\_lsr \ Rm1, Rn1, imm4, Rn2 187,$ | 214 | | $xor\_lsr\ Rm1,Rn1,Rm2,Rn2186,$ | 212 | | $xor\_mov \;\; Rm1, Rn1, imm4, Rn2 187,$ | 206 | | $xor\_mov \;\; Rm1, Rn1, Rm2, Rn2 186,$ | 204 | | $xor\_sub \ Rm1, Rn1, imm4, Rn2 187,$ | 200 | | $xor\_sub \ Rm1, Rn1, Rm2, Rn2 186,$ | 198 | | | | ## MN103E Series Instruction Manual March, 2003 2nd Edition Issued by Matsushita Electric Industrial Co., Ltd. © Matsushita Electric Industrial Co., Ltd. ## Semiconductor Company, Matsushita Electric Industrial Co., Ltd. Nagaokakyo, Kyoto 617-8520, Japan Tel: (075) 951-8151 http://panasonic.co.jp/semicon SALES OFFICES #### **■ NORTH AMERICA** #### ●U.S.A. Sales Office: **Panasonic Industrial Company** [PIC] • New Jersey Office: Two Panasonic Way Secaucus, New Jersey 07094 U.S.A. Tel: 1-201-348-5257 Fax:1-201-392-4652 • Chicago Office: 1707 N. Randall Road Elgin, Illinois 60123-7847 U.S.A. Tel: 1-847-468-5720 Fax:1-847-468-5725 • Milpitas Office: 1600 McCandless Drive Milpitas, California 95035 U.S.A. Tel: 1-408-942-2912 Fax:1-408-946-9063 Atlanta Office: 1225 Northbrook Parkway Suite 1-151 Suwanee, GA 30024 U.S.A. Tel: 1-770-338-6953 Fax:1-770-338-6849 • San Diego Office: 9444 Balboa Avenue, Suite 185, San Diego, California 92123 U.S.A. Tel: 1-619-503-2903 Fax:1-858-715-5545 Canada Sales Office: Panasonic Canada Inc. [PCI] 5770 Ambler Drive 27 Mississauga, Ontario, L4W 2T3 **CANADA** Tel: 1-905-238-2315 Fax:1-905-238-2414 ### **■ LATIN AMERICA** ### ●Mexico Sales Office: Panasonic de Mexico, S.A. de C.V. [PANAMEX] Amores 1120 Col. Del Valle Delegacion Benito Juarez C.P. 03100 Mexico, D.F. MEXICO Tel: 52-5-488-1000 Fax:52-5-488-1073 • Guadalajara Office: SUCURSAL GUADALAJARA Av. Lazaro Cardenas 2305 Local G-102 Plaza Comercial Abastos; Col. Las Torres Guadalajara, Jal. 44920 **MEXICO** Tel: 52-3-671-1205 Fax:52-3-671-1256 ●Brazil Sales Office: Panasonic do Brasil Ltda. [PANABRAS] Caixa Postal 1641, Sao Jose dos Campos, Estado de Sao Paulo Tel: 55-12-335-9000 Fax:55-12-331-3789 ## **■** EUROPE ## ●Europe Sales Office: Panasonic Industrial Europe GmbH • U.K. Sales Office: [PIE] Willoughby Road, Bracknell, Berks., RG12 8FP, THE UNITED KINGDOM Tel: 44-1344-85-3671 Fax:44-1344-85-3853 • Germany Sales Office: Hans-Pinsel-Strasse 2 85540 Haar, GERMANY Tel: 49-89-46159-119 Fax:49-89-46159-195 ■ ASIA ## ●Singapore Sales Office: Panasonic Semiconductor of South Asia [PSSA] 300 Beach Road, #16-01, The Concourse, Singapore 199555 THE REPUBLIC OF SINGAPORE Tel: 65-6390-3688 Fax:65-6390-3689 ## ●Malaysia Sales Office: Panasonic Industrial Company (M) Sdn. Bhd. [PICM] Tingkat 16B, Menara PKNS Petaling Jaya, No.17, Jalan Yong Shook Lin 46050 Petaling Jaya, Selangor Darul Ehsan, MALAYSIA Tel: 60-3-7951-6601 Fax:60-3-7954-5968 • Penang Office: Suite 20-07.20th Floor, MWE Plaza, No.8, Lebuh Farquhar, 10200 Penang, MALAYSIA Tel: 60-4-201-5113 Fax:60-4-261-9989 Johore Sales Office: Menara Pelangi, Suite8.3A, Level8, No.2, Jalan Kuning Taman Pelangi, 80400 Johor Bahru, Johor, MALAYSIA Tel: 60-7-331-3822 Fax:60-7-355-3996 ●Thailand Sales Office: Panasonic Industrial (THAILAND) Ltd. 252-133 Muang Thai-Phatra Complex Building, 31st Fl. Rachadaphisek Rd., Huaykwang, Bangkok 10320, **THAILAND** Tel: 66-2-693-3428 Fax:66-2-693-3422 Philippines Sales Office: [PISP] Panasonic Indsutrial Sales Philippines Division of Matsushita Electric Philippines Corporation 102 Laguna Boulevard, Bo. Don Jose Laguna Technopark, Santa. Rosa, Laguna 4026 PHILIPPINES Tel: 63-2-520-8615 Fax:63-2-520-8629 ●India Sales Office: National Panasonic India Ltd. [NPI] E Block, 510, International Trade Tower Nehru Place, New Delhi\_110019 INDIA Tel: 91-11-629-2870 Fax:91-11-629-2877 ●Indonesia Sales Office: P.T.MET & Gobel [M&G] JL. Dewi Sartika (Cawang 2) Jakarta 13630, INDONESIA Tel: 62-21-801-5666 Fax:62-21-801-5675 China Sales Office: Panasonic Industrial (Shanghai) Co., Ltd. Floor 12, Zhong Bao Mansion, 166 East Road Lujian Zui, PU Dong New District, Shanghai, 200120 CHINA Tel: 86-21-5866-6114 Fax:86-21-5866-8000 Panasonic Industrial (Tianjin) Co., Ltd. Room No.1001, Tianjin International Building 75, Nanjin Road, Tianjin 300050, CHINA Tel: 86-22-2313-9771 Fax:86-22-2313-9770 Panasonic SH Industrial Sales (Shenzhen) Co., Ltd. • Head Office: 7A-107, International Bussiness & Exhibition Centre, Futian Free Trade Zone, Shenzhen 518048, CHINA Tel: 86-755-8359-8500 Fax:86-755-8359-8516 • Shum Yip Centre Office: 25F, Shum Yip Centre, #5045, East Shennan Road, Shenzhen, CHINA Tel: 86-755-8211-0888 Fax:86-755-8211-0884 Panasonic Shun Hing Industrial Sales (Hong Kong) Co., Ltd. [PSI(HK)] 11th Floor, Great Eagle Center 23 Harbour Road, Wanchai, HONG KONG Tel: 852-2529-7322 Fax:852-2865-3697 ●Taiwan Sales Office: Panasonic Industrial Sales (Taiwan) Co.,Ltd. [PIST] Head Office: 6F, 550, Sec. 4, Chung Hsiao E. RD. Taipei, 110, TAIWAN Tel: 886-2-2757-1900 Fax:886-2-2757-1906 Kaohsiung Office: 6th Floor, Hsin Kong Bldg. No.251, Chi Hsien 1st Road Kaohsiung 800, TAIWAN Tel: 886-7-346-3815 Fax:886-7-236-8362 •Korea Sales Office: Panasonic Industrial Korea Co., Ltd. [PIKL] Kukje Center Bldg. 11th Fl., 191 Hangangro 2ga, Youngsan-ku, Seoul 140-702, KOREA Tel: 82-2-795-9600 Fax:82-2-795-1542 110303