From cf20e45cc4cb77bcb16363531e600883cd27ff80 Mon Sep 17 00:00:00 2001 From: Richard Sandiford Date: Thu, 25 Jul 2013 09:04:52 +0000 Subject: [SystemZ] Add LOC and LOCG As with the stores, these instructions can trap when the condition is false, so they are only used for things like (cond ? x : *ptr). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@187112 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/MC/Disassembler/SystemZ/insns.txt | 96 ++++++++++++++++++++++++++++++++++ test/MC/SystemZ/insn-bad-z196.s | 34 ++++++++++++ test/MC/SystemZ/insn-good-z196.s | 96 ++++++++++++++++++++++++++++++++++ 3 files changed, 226 insertions(+) (limited to 'test/MC') diff --git a/test/MC/Disassembler/SystemZ/insns.txt b/test/MC/Disassembler/SystemZ/insns.txt index 7728a516e7..23f45a6067 100644 --- a/test/MC/Disassembler/SystemZ/insns.txt +++ b/test/MC/Disassembler/SystemZ/insns.txt @@ -3262,6 +3262,102 @@ # CHECK: lnxbr %f13, %f9 0xb3 0x41 0x00 0xd9 +# CHECK: loc %r7, 6399(%r8), 0 +0xeb 0x70 0x88 0xff 0x01 0xf2 + +# CHECK: loco %r7, 6399(%r8) +0xeb 0x71 0x88 0xff 0x01 0xf2 + +# CHECK: loch %r7, 6399(%r8) +0xeb 0x72 0x88 0xff 0x01 0xf2 + +# CHECK: locnle %r7, 6399(%r8) +0xeb 0x73 0x88 0xff 0x01 0xf2 + +# CHECK: locl %r7, 6399(%r8) +0xeb 0x74 0x88 0xff 0x01 0xf2 + +# CHECK: locnhe %r7, 6399(%r8) +0xeb 0x75 0x88 0xff 0x01 0xf2 + +# CHECK: loclh %r7, 6399(%r8) +0xeb 0x76 0x88 0xff 0x01 0xf2 + +# CHECK: locne %r7, 6399(%r8) +0xeb 0x77 0x88 0xff 0x01 0xf2 + +# CHECK: loce %r7, 6399(%r8) +0xeb 0x78 0x88 0xff 0x01 0xf2 + +# CHECK: locnlh %r7, 6399(%r8) +0xeb 0x79 0x88 0xff 0x01 0xf2 + +# CHECK: loche %r7, 6399(%r8) +0xeb 0x7a 0x88 0xff 0x01 0xf2 + +# CHECK: locnl %r7, 6399(%r8) +0xeb 0x7b 0x88 0xff 0x01 0xf2 + +# CHECK: locle %r7, 6399(%r8) +0xeb 0x7c 0x88 0xff 0x01 0xf2 + +# CHECK: locnh %r7, 6399(%r8) +0xeb 0x7d 0x88 0xff 0x01 0xf2 + +# CHECK: locno %r7, 6399(%r8) +0xeb 0x7e 0x88 0xff 0x01 0xf2 + +# CHECK: loc %r7, 6399(%r8), 15 +0xeb 0x7f 0x88 0xff 0x01 0xf2 + +# CHECK: locg %r7, 6399(%r8), 0 +0xeb 0x70 0x88 0xff 0x01 0xe2 + +# CHECK: locgo %r7, 6399(%r8) +0xeb 0x71 0x88 0xff 0x01 0xe2 + +# CHECK: locgh %r7, 6399(%r8) +0xeb 0x72 0x88 0xff 0x01 0xe2 + +# CHECK: locgnle %r7, 6399(%r8) +0xeb 0x73 0x88 0xff 0x01 0xe2 + +# CHECK: locgl %r7, 6399(%r8) +0xeb 0x74 0x88 0xff 0x01 0xe2 + +# CHECK: locgnhe %r7, 6399(%r8) +0xeb 0x75 0x88 0xff 0x01 0xe2 + +# CHECK: locglh %r7, 6399(%r8) +0xeb 0x76 0x88 0xff 0x01 0xe2 + +# CHECK: locgne %r7, 6399(%r8) +0xeb 0x77 0x88 0xff 0x01 0xe2 + +# CHECK: locge %r7, 6399(%r8) +0xeb 0x78 0x88 0xff 0x01 0xe2 + +# CHECK: locgnlh %r7, 6399(%r8) +0xeb 0x79 0x88 0xff 0x01 0xe2 + +# CHECK: locghe %r7, 6399(%r8) +0xeb 0x7a 0x88 0xff 0x01 0xe2 + +# CHECK: locgnl %r7, 6399(%r8) +0xeb 0x7b 0x88 0xff 0x01 0xe2 + +# CHECK: locgle %r7, 6399(%r8) +0xeb 0x7c 0x88 0xff 0x01 0xe2 + +# CHECK: locgnh %r7, 6399(%r8) +0xeb 0x7d 0x88 0xff 0x01 0xe2 + +# CHECK: locgno %r7, 6399(%r8) +0xeb 0x7e 0x88 0xff 0x01 0xe2 + +# CHECK: locg %r7, 6399(%r8), 15 +0xeb 0x7f 0x88 0xff 0x01 0xe2 + # CHECK: lpdbr %f0, %f9 0xb3 0x10 0x00 0x09 diff --git a/test/MC/SystemZ/insn-bad-z196.s b/test/MC/SystemZ/insn-bad-z196.s index f62ea74fa0..5243eb57cd 100644 --- a/test/MC/SystemZ/insn-bad-z196.s +++ b/test/MC/SystemZ/insn-bad-z196.s @@ -24,6 +24,40 @@ ahik %r0, %r1, 32768 ahik %r0, %r1, foo +#CHECK: error: invalid operand +#CHECK: loc %r0,0,-1 +#CHECK: error: invalid operand +#CHECK: loc %r0,0,16 +#CHECK: error: invalid operand +#CHECK: loc %r0,-524289,1 +#CHECK: error: invalid operand +#CHECK: loc %r0,524288,1 +#CHECK: error: invalid use of indexed addressing +#CHECK: loc %r0,0(%r1,%r2),1 + + loc %r0,0,-1 + loc %r0,0,16 + loc %r0,-524289,1 + loc %r0,524288,1 + loc %r0,0(%r1,%r2),1 + +#CHECK: error: invalid operand +#CHECK: locg %r0,0,-1 +#CHECK: error: invalid operand +#CHECK: locg %r0,0,16 +#CHECK: error: invalid operand +#CHECK: locg %r0,-524289,1 +#CHECK: error: invalid operand +#CHECK: locg %r0,524288,1 +#CHECK: error: invalid use of indexed addressing +#CHECK: locg %r0,0(%r1,%r2),1 + + locg %r0,0,-1 + locg %r0,0,16 + locg %r0,-524289,1 + locg %r0,524288,1 + locg %r0,0(%r1,%r2),1 + #CHECK: error: invalid operand #CHECK: sllk %r0,%r0,-524289 #CHECK: error: invalid operand diff --git a/test/MC/SystemZ/insn-good-z196.s b/test/MC/SystemZ/insn-good-z196.s index 5b0ed59cb1..5b452b5081 100644 --- a/test/MC/SystemZ/insn-good-z196.s +++ b/test/MC/SystemZ/insn-good-z196.s @@ -121,6 +121,102 @@ ark %r15,%r0,%r0 ark %r7,%r8,%r9 +#CHECK: loc %r0, 0, 0 # encoding: [0xeb,0x00,0x00,0x00,0x00,0xf2] +#CHECK: loc %r0, 0, 15 # encoding: [0xeb,0x0f,0x00,0x00,0x00,0xf2] +#CHECK: loc %r0, -524288, 0 # encoding: [0xeb,0x00,0x00,0x00,0x80,0xf2] +#CHECK: loc %r0, 524287, 0 # encoding: [0xeb,0x00,0x0f,0xff,0x7f,0xf2] +#CHECK: loc %r0, 0(%r1), 0 # encoding: [0xeb,0x00,0x10,0x00,0x00,0xf2] +#CHECK: loc %r0, 0(%r15), 0 # encoding: [0xeb,0x00,0xf0,0x00,0x00,0xf2] +#CHECK: loc %r15, 0, 0 # encoding: [0xeb,0xf0,0x00,0x00,0x00,0xf2] +#CHECK: loc %r1, 4095(%r2), 3 # encoding: [0xeb,0x13,0x2f,0xff,0x00,0xf2] + + loc %r0,0,0 + loc %r0,0,15 + loc %r0,-524288,0 + loc %r0,524287,0 + loc %r0,0(%r1),0 + loc %r0,0(%r15),0 + loc %r15,0,0 + loc %r1,4095(%r2),3 + +#CHECK: loco %r1, 2(%r3) # encoding: [0xeb,0x11,0x30,0x02,0x00,0xf2] +#CHECK: loch %r1, 2(%r3) # encoding: [0xeb,0x12,0x30,0x02,0x00,0xf2] +#CHECK: locnle %r1, 2(%r3) # encoding: [0xeb,0x13,0x30,0x02,0x00,0xf2] +#CHECK: locl %r1, 2(%r3) # encoding: [0xeb,0x14,0x30,0x02,0x00,0xf2] +#CHECK: locnhe %r1, 2(%r3) # encoding: [0xeb,0x15,0x30,0x02,0x00,0xf2] +#CHECK: loclh %r1, 2(%r3) # encoding: [0xeb,0x16,0x30,0x02,0x00,0xf2] +#CHECK: locne %r1, 2(%r3) # encoding: [0xeb,0x17,0x30,0x02,0x00,0xf2] +#CHECK: loce %r1, 2(%r3) # encoding: [0xeb,0x18,0x30,0x02,0x00,0xf2] +#CHECK: locnlh %r1, 2(%r3) # encoding: [0xeb,0x19,0x30,0x02,0x00,0xf2] +#CHECK: loche %r1, 2(%r3) # encoding: [0xeb,0x1a,0x30,0x02,0x00,0xf2] +#CHECK: locnl %r1, 2(%r3) # encoding: [0xeb,0x1b,0x30,0x02,0x00,0xf2] +#CHECK: locle %r1, 2(%r3) # encoding: [0xeb,0x1c,0x30,0x02,0x00,0xf2] +#CHECK: locnh %r1, 2(%r3) # encoding: [0xeb,0x1d,0x30,0x02,0x00,0xf2] +#CHECK: locno %r1, 2(%r3) # encoding: [0xeb,0x1e,0x30,0x02,0x00,0xf2] + + loco %r1,2(%r3) + loch %r1,2(%r3) + locnle %r1,2(%r3) + locl %r1,2(%r3) + locnhe %r1,2(%r3) + loclh %r1,2(%r3) + locne %r1,2(%r3) + loce %r1,2(%r3) + locnlh %r1,2(%r3) + loche %r1,2(%r3) + locnl %r1,2(%r3) + locle %r1,2(%r3) + locnh %r1,2(%r3) + locno %r1,2(%r3) + +#CHECK: locg %r0, 0, 0 # encoding: [0xeb,0x00,0x00,0x00,0x00,0xe2] +#CHECK: locg %r0, 0, 15 # encoding: [0xeb,0x0f,0x00,0x00,0x00,0xe2] +#CHECK: locg %r0, -524288, 0 # encoding: [0xeb,0x00,0x00,0x00,0x80,0xe2] +#CHECK: locg %r0, 524287, 0 # encoding: [0xeb,0x00,0x0f,0xff,0x7f,0xe2] +#CHECK: locg %r0, 0(%r1), 0 # encoding: [0xeb,0x00,0x10,0x00,0x00,0xe2] +#CHECK: locg %r0, 0(%r15), 0 # encoding: [0xeb,0x00,0xf0,0x00,0x00,0xe2] +#CHECK: locg %r15, 0, 0 # encoding: [0xeb,0xf0,0x00,0x00,0x00,0xe2] +#CHECK: locg %r1, 4095(%r2), 3 # encoding: [0xeb,0x13,0x2f,0xff,0x00,0xe2] + + locg %r0,0,0 + locg %r0,0,15 + locg %r0,-524288,0 + locg %r0,524287,0 + locg %r0,0(%r1),0 + locg %r0,0(%r15),0 + locg %r15,0,0 + locg %r1,4095(%r2),3 + +#CHECK: locgo %r1, 2(%r3) # encoding: [0xeb,0x11,0x30,0x02,0x00,0xe2] +#CHECK: locgh %r1, 2(%r3) # encoding: [0xeb,0x12,0x30,0x02,0x00,0xe2] +#CHECK: locgnle %r1, 2(%r3) # encoding: [0xeb,0x13,0x30,0x02,0x00,0xe2] +#CHECK: locgl %r1, 2(%r3) # encoding: [0xeb,0x14,0x30,0x02,0x00,0xe2] +#CHECK: locgnhe %r1, 2(%r3) # encoding: [0xeb,0x15,0x30,0x02,0x00,0xe2] +#CHECK: locglh %r1, 2(%r3) # encoding: [0xeb,0x16,0x30,0x02,0x00,0xe2] +#CHECK: locgne %r1, 2(%r3) # encoding: [0xeb,0x17,0x30,0x02,0x00,0xe2] +#CHECK: locge %r1, 2(%r3) # encoding: [0xeb,0x18,0x30,0x02,0x00,0xe2] +#CHECK: locgnlh %r1, 2(%r3) # encoding: [0xeb,0x19,0x30,0x02,0x00,0xe2] +#CHECK: locghe %r1, 2(%r3) # encoding: [0xeb,0x1a,0x30,0x02,0x00,0xe2] +#CHECK: locgnl %r1, 2(%r3) # encoding: [0xeb,0x1b,0x30,0x02,0x00,0xe2] +#CHECK: locgle %r1, 2(%r3) # encoding: [0xeb,0x1c,0x30,0x02,0x00,0xe2] +#CHECK: locgnh %r1, 2(%r3) # encoding: [0xeb,0x1d,0x30,0x02,0x00,0xe2] +#CHECK: locgno %r1, 2(%r3) # encoding: [0xeb,0x1e,0x30,0x02,0x00,0xe2] + + locgo %r1,2(%r3) + locgh %r1,2(%r3) + locgnle %r1,2(%r3) + locgl %r1,2(%r3) + locgnhe %r1,2(%r3) + locglh %r1,2(%r3) + locgne %r1,2(%r3) + locge %r1,2(%r3) + locgnlh %r1,2(%r3) + locghe %r1,2(%r3) + locgnl %r1,2(%r3) + locgle %r1,2(%r3) + locgnh %r1,2(%r3) + locgno %r1,2(%r3) + #CHECK: ngrk %r0, %r0, %r0 # encoding: [0xb9,0xe4,0x00,0x00] #CHECK: ngrk %r0, %r0, %r15 # encoding: [0xb9,0xe4,0xf0,0x00] #CHECK: ngrk %r0, %r15, %r0 # encoding: [0xb9,0xe4,0x00,0x0f] -- cgit v1.2.3