ref: 1ac9de9d3edc5efb355c01293f1bc880bc8de451
parent: 4212f8a3ecf712dbf89c9449336bc5b3d9f2aaed
author: Roberto E. Vargas Caballero <[email protected]>
date: Sun Dec 17 17:26:07 EST 2017
[as-z80] Add 8 bit ALU group instructions
--- a/as/target/x80/ins.c
+++ b/as/target/x80/ins.c
@@ -289,3 +289,17 @@
args[1] = args[1]->left;
r16_imm16(op, args);
}
+
+void
+r8(Op *op, Node **args)
+{
+ /* TODO */
+ abort();
+}
+
+void
+idx(Op *op)
+{
+ /* TODO */
+ abort();
+}
--- a/as/target/x80/x80.dat
+++ b/as/target/x80/x80.dat
@@ -137,9 +137,81 @@
POP IX 2 0xdd,0xe1 noargs Z80,R800
POP IY 2 0xfd,0xe1 noargs Z80,R800
+# 8 bit ALU group
ADD A,r 1 0x80 xx_r8 Z80,R800,GB80
ADD A,p 2 0xdd,0x80 xx_r8 Z80,R800
ADD A,q 2 0xfd,0x80 xx_r8 Z80,R800
ADD A,imm8 2 0xc6 imm8 Z80,R800,GB80
-
ADD A,(HL) 1 0x86 noargs Z80,R800,GB80
+ADD A,(IX+n) 3 0xdd,0x86 idx Z80,R800
+ADD A,(IY+n) 3 0xfd,0x86 idx Z80,R800
+
+ADC A,r 1 0x88 xx_r8 Z80,R800,GB80
+ADC A,p 2 0xdd,0x88 xx_r8 Z80,R800
+ADC A,q 2 0xfd,0x88 xx_r8 Z80,R800
+ADC A,imm8 2 0xce imm8 Z80,R800,GB80
+ADC A,(HL) 1 0x8e noargs Z80,R800,GB80
+ADC A,(IX+n) 3 0xdd,0x8e idx Z80,R800
+ADC A,(IY+n) 3 0xfd,0x8e idx Z80,R800
+
+SUB A,r 1 0x90 xx_r8 Z80,R800,GB80
+SUB A,p 2 0xdd,0x90 xx_r8 Z80,R800
+SUB A,q 2 0xfd,0x90 xx_r8 Z80,R800
+SUB A,imm8 2 0xd6 imm8 Z80,R800,GB80
+SUB A,(HL) 1 0x96 noargs Z80,R800,GB80
+SUB A,(IX+n) 3 0xdd,0x96 idx Z80,R800
+SUB A,(IY+n) 3 0xfd,0x96 idx Z80,R800
+
+SBC A,r 1 0x98 xx_r8 Z80,R800,GB80
+SBC A,p 2 0xdd,0x98 xx_r8 Z80,R800
+SBC A,q 2 0xfd,0x98 xx_r8 Z80,R800
+SBC A,imm8 2 0xde imm8 Z80,R800,GB80
+SBC A,(HL) 1 0x9e noargs Z80,R800,GB80
+SBC A,(IX+n) 3 0xdd,0x9e idx Z80,R800
+SBC A,(IY+n) 3 0xfd,0x9e idx Z80,R800
+
+AND A,r 1 0xa0 xx_r8 Z80,R800,GB80
+AND A,p 2 0xdd,0xa0 xx_r8 Z80,R800
+AND A,q 2 0xfd,0xa0 xx_r8 Z80,R800
+AND A,imm8 2 0xe5 imm8 Z80,R800,GB80
+AND A,(HL) 1 0xa6 noargs Z80,R800,GB80
+AND A,(IX+n) 3 0xdd,0xa6 idx Z80,R800
+AND A,(IY+n) 3 0xfd,0xa6 idx Z80,R800
+
+OR A,r 1 0xb0 xx_r8 Z80,R800,GB80
+OR A,p 2 0xdd,0xb0 xx_r8 Z80,R800
+OR A,q 2 0xfd,0xb0 xx_r8 Z80,R800
+OR A,imm8 2 0xf6 imm8 Z80,R800,GB80
+OR A,(HL) 1 0xb6 noargs Z80,R800,GB80
+OR A,(IX+n) 3 0xdd,0xb6 idx Z80,R800
+OR A,(IY+n) 3 0xfd,0xb6 idx Z80,R800
+
+XOR A,r 1 0xa8 xx_r8 Z80,R800,GB80
+XOR A,p 2 0xdd,0xa8 xx_r8 Z80,R800
+XOR A,q 2 0xfd,0xa8 xx_r8 Z80,R800
+XOR A,imm8 2 0xe6 imm8 Z80,R800,GB80
+XOR A,(HL) 1 0xa6 noargs Z80,R800,GB80
+XOR A,(IX+n) 3 0xdd,0xa6 idx Z80,R800
+XOR A,(IY+n) 3 0xfd,0xa6 idx Z80,R800
+
+CP A,r 1 0xb8 xx_r8 Z80,R800,GB80
+CP A,p 2 0xdd,0xb8 xx_r8 Z80,R800
+CP A,q 2 0xfd,0xb8 xx_r8 Z80,R800
+CP A,imm8 2 0xfe imm8 Z80,R800,GB80
+CP A,(HL) 1 0xbe noargs Z80,R800,GB80
+CP A,(IX+n) 3 0xdd,0xbe idx Z80,R800
+CP A,(IY+n) 3 0xfd,0xbe idx Z80,R800
+
+INC r 1 0x40 r8 Z80,R800,GB80
+INC p 2 0xdd,0x40 r8 Z80,R800
+INC q 2 0xfd,0x40 r8 Z80,R800
+INC (HL) 1 0x34 noargs Z80,R800,GB80
+INC (IX+n) 3 0xdd,0x34 idx Z80,R800
+INC (IY+n) 3 0xfd,0x34 idx Z80,R800
+
+DEC r 1 0x05 r8 Z80,R800,GB80
+DEC p 2 0xdd,0x05 r8 Z80,R800
+DEC q 2 0xfd,0x05 r8 Z80,R800
+DEC (HL) 1 0x35 noargs Z80,R800,GB80
+DEC (IX+n) 3 0xdd,0x35 idx Z80,R800
+DEC (IY+n) 3 0xfd,0x35 idx Z80,R800