== CMP = Compare (16-Bits) ==
Hex | Mnemonic | Cycles |
---|---|---|
D4 nn nn | CMP BA, #nnnn | 12 |
D5 nn nn | CMP HL, #nnnn | 12 |
D6 nn nn | CMP X, #nnnn | 12 |
D7 nn nn | CMP Y, #nnnn | 12 |
CF 6C nn nn | CMP SP, #nnnn | 16 |
CF 18 | CMP BA, BA | 16 |
CF 19 | CMP BA, HL | 16 |
CF 1A | CMP BA, X | 16 |
CF 1B | CMP BA, Y | 16 |
CF 38 | CMP HL, BA | 16 |
CF 39 | CMP HL, HL | 16 |
CF 3A | CMP HL, X | 16 |
CF 3B | CMP HL, Y | 16 |
CF 5C | CMP SP, BA | 16 |
CF 5D | CMP SP, HL | 16 |
#nnnn = Immediate unsigned 16-Bits
BA = Register BA: (B shl 8) or A
HL = Register HL: (H shl 8) or L
X = Register X
Y = Register Y
SP = Register SP (Stack Pointer)
; CMP Sc2, Sc
;
; Sc2 = Source 2
; Sc = Source
(discarded) = Sc2 - Sc
"16-Bits Source 2" subtracts with "16-Bits Source", result is discarded.
This instruction is used to compare values.
Zero: Set when result is 0
Carry: Set when result is < 0
Overflow: Set when result overflow 16-bits signed range (< -32768 OR > 32767)
Sign: Set when bit 15 of the result is 1
; BA = 0x2EF0
CMP`` ``BA,`` ``$1337
; BA = 0x2EF0
; 0x1BB9 (0x2EF0 - 0x1337 = 0x(0)1BB9)
; F = (Zero=0):(Carry=0):(Overflow=0):(Sign=0)
; HL = 0xBB7E
; BA = 0xCF12
CMP`` ``BA,`` ``HL
; HL = 0xBB7E
; BA = 0xCF12
; 0xEC6C (0xCF12 - 0xBB7E = 0x(1)EC6C)
; F = (Zero=0):(Carry=1):(Overflow=0):(Sign=1)