Mercurial > hg > CbC > CbC_llvm
diff test/MC/Mips/micromips-control-instructions.s @ 77:54457678186b LLVM3.6
LLVM 3.6
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 08 Sep 2014 22:06:00 +0900 |
parents | |
children | 60c9769439b8 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/MC/Mips/micromips-control-instructions.s Mon Sep 08 22:06:00 2014 +0900 @@ -0,0 +1,60 @@ +# RUN: llvm-mc %s -triple=mipsel -show-encoding -mcpu=mips32r2 -mattr=micromips \ +# RUN: | FileCheck -check-prefix=CHECK-EL %s +# RUN: llvm-mc %s -triple=mips -show-encoding -mcpu=mips32r2 -mattr=micromips \ +# RUN: | FileCheck -check-prefix=CHECK-EB %s +# Check that the assembler can handle the documented syntax +# for control instructions. +#------------------------------------------------------------------------------ +# microMIPS Control Instructions +#------------------------------------------------------------------------------ +# Little endian +#------------------------------------------------------------------------------ +# CHECK-EL: break # encoding: [0x00,0x00,0x07,0x00] +# CHECK-EL: break 7 # encoding: [0x07,0x00,0x07,0x00] +# CHECK-EL: break 7, 5 # encoding: [0x07,0x00,0x47,0x01] +# CHECK-EL: syscall # encoding: [0x00,0x00,0x7c,0x8b] +# CHECK-EL: syscall 396 # encoding: [0x8c,0x01,0x7c,0x8b] +# CHECK-EL: eret # encoding: [0x00,0x00,0x7c,0xf3] +# CHECK-EL: deret # encoding: [0x00,0x00,0x7c,0xe3] +# CHECK-EL: di # encoding: [0x00,0x00,0x7c,0x47] +# CHECK-EL: di # encoding: [0x00,0x00,0x7c,0x47] +# CHECK-EL: di $10 # encoding: [0x0a,0x00,0x7c,0x47] +# CHECK-EL: ei # encoding: [0x00,0x00,0x7c,0x57] +# CHECK-EL: ei # encoding: [0x00,0x00,0x7c,0x57] +# CHECK-EL: ei $10 # encoding: [0x0a,0x00,0x7c,0x57] +# CHECK-EL: wait # encoding: [0x00,0x00,0x7c,0x93] +# CHECK-EL: wait 17 # encoding: [0x11,0x00,0x7c,0x93] +#------------------------------------------------------------------------------ +# Big endian +#------------------------------------------------------------------------------ +# CHECK-EB: break # encoding: [0x00,0x00,0x00,0x07] +# CHECK-EB: break 7 # encoding: [0x00,0x07,0x00,0x07] +# CHECK-EB: break 7, 5 # encoding: [0x00,0x07,0x01,0x47] +# CHECK-EB: syscall # encoding: [0x00,0x00,0x8b,0x7c] +# CHECK-EB: syscall 396 # encoding: [0x01,0x8c,0x8b,0x7c] +# CHECK-EB: eret # encoding: [0x00,0x00,0xf3,0x7c] +# CHECK-EB: deret # encoding: [0x00,0x00,0xe3,0x7c] +# CHECK-EB: di # encoding: [0x00,0x00,0x47,0x7c] +# CHECK-EB: di # encoding: [0x00,0x00,0x47,0x7c] +# CHECK-EB: di $10 # encoding: [0x00,0x0a,0x47,0x7c] +# CHECK-EB: ei # encoding: [0x00,0x00,0x57,0x7c] +# CHECK-EB: ei # encoding: [0x00,0x00,0x57,0x7c] +# CHECK-EB: ei $10 # encoding: [0x00,0x0a,0x57,0x7c] +# CHECK-EB: wait # encoding: [0x00,0x00,0x93,0x7c] +# CHECK-EB: wait 17 # encoding: [0x00,0x11,0x93,0x7c] + + break + break 7 + break 7,5 + syscall + syscall 0x18c + eret + deret + di + di $0 + di $10 + ei + ei $0 + ei $10 + wait + wait 17