forked from OSchip/llvm-project
267 lines
11 KiB
ArmAsm
267 lines
11 KiB
ArmAsm
// RUN: not llvm-mc -triple aarch64-none-linux-gnu -show-encoding -mattr=+v8.4a < %s 2> %t | FileCheck %s --check-prefix=CHECK
|
|
// RUN: FileCheck --check-prefix=CHECK-ERROR < %t %s
|
|
// RUN: not llvm-mc -triple aarch64-none-linux-gnu -show-encoding -mattr=+tlb-rmi < %s 2> %t | FileCheck %s --check-prefix=CHECK
|
|
// RUN: FileCheck --check-prefix=CHECK-ERROR < %t %s
|
|
// RUN: not llvm-mc -triple aarch64-none-linux-gnu -show-encoding -mattr=-v8.4a < %s 2>&1 | FileCheck %s --check-prefix=CHECK-NO-V84
|
|
// RUN: not llvm-mc -triple aarch64-none-linux-gnu -show-encoding -mattr=+v8.4a,-tlb-rmi < %s 2>&1 | FileCheck %s --check-prefix=CHECK-NO-V84
|
|
|
|
// Outer shareable TLB maintenance instructions:
|
|
tlbi vmalle1os
|
|
tlbi vae1os, xzr
|
|
tlbi vae1os, x0
|
|
tlbi aside1os, x1
|
|
tlbi vaae1os, x2
|
|
tlbi vale1os, x3
|
|
tlbi vaale1os, x4
|
|
tlbi ipas2e1os, x5
|
|
tlbi ipas2le1os, x6
|
|
tlbi vae2os, x7
|
|
tlbi vale2os, x8
|
|
tlbi vmalls12e1os
|
|
tlbi vae3os, x9
|
|
tlbi vale3os, x10
|
|
tlbi alle2os
|
|
tlbi alle1os
|
|
tlbi alle3os
|
|
|
|
//CHECK: tlbi vmalle1os // encoding: [0x1f,0x81,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi vae1os, xzr // encoding: [0x3f,0x81,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi vae1os, x0 // encoding: [0x20,0x81,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi aside1os, x1 // encoding: [0x41,0x81,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi vaae1os, x2 // encoding: [0x62,0x81,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi vale1os, x3 // encoding: [0xa3,0x81,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi vaale1os, x4 // encoding: [0xe4,0x81,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi ipas2e1os, x5 // encoding: [0x05,0x84,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi ipas2le1os, x6 // encoding: [0x86,0x84,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi vae2os, x7 // encoding: [0x27,0x81,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi vale2os, x8 // encoding: [0xa8,0x81,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi vmalls12e1os // encoding: [0xdf,0x81,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi vae3os, x9 // encoding: [0x29,0x81,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi vale3os, x10 // encoding: [0xaa,0x81,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi alle2os // encoding: [0x1f,0x81,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi alle1os // encoding: [0x9f,0x81,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi alle3os // encoding: [0x1f,0x81,0x0e,0xd5]
|
|
|
|
tlbi vae1os, sp
|
|
|
|
//CHECK-ERROR: error: invalid operand for instruction
|
|
//CHECK-ERROR-NEXT: tlbi vae1os, sp
|
|
//CHECK-ERROR-NEXT: ^
|
|
|
|
//CHECK-NO-V84: error: TLBI VMALLE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vmalle1os
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VAE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vae1os, xzr
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VAE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vae1os, x0
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI ASIDE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi aside1os, x1
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VAAE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vaae1os, x2
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VALE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vale1os, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VAALE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vaale1os, x4
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI IPAS2E1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ipas2e1os, x5
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI IPAS2LE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ipas2le1os, x6
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VAE2OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vae2os, x7
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VALE2OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vale2os, x8
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VMALLS12E1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vmalls12e1os
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VAE3OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vae3os, x9
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI VALE3OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi vale3os, x10
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI ALLE2OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi alle2os
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI ALLE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi alle1os
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI ALLE3OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi alle3os
|
|
//CHECK-NO-V84-NEXT: ^
|
|
|
|
// TLB Range maintenance instructions:
|
|
tlbi rvae1, x3
|
|
tlbi rvaae1, x3
|
|
tlbi rvale1, x3
|
|
tlbi rvaale1, x3
|
|
tlbi rvae1is, x3
|
|
tlbi rvaae1is, x3
|
|
tlbi rvale1is, x3
|
|
tlbi rvaale1is, x3
|
|
tlbi rvae1os, x3
|
|
tlbi rvaae1os, x3
|
|
tlbi rvale1os, x3
|
|
tlbi rvaale1os, x3
|
|
tlbi ripas2e1is, x3
|
|
tlbi ripas2le1is, x3
|
|
tlbi ripas2e1, X3
|
|
tlbi ripas2le1, X3
|
|
tlbi ripas2e1os, X3
|
|
tlbi ripas2le1os, X3
|
|
tlbi rvae2, X3
|
|
tlbi rvale2, X3
|
|
tlbi rvae2is, X3
|
|
tlbi rvale2is, X3
|
|
tlbi rvae2os, X3
|
|
tlbi rvale2os, X3
|
|
tlbi rvae3, X3
|
|
tlbi rvale3, X3
|
|
tlbi rvae3is, X3
|
|
tlbi rvale3is, X3
|
|
tlbi rvae3os, X3
|
|
tlbi rvale3os, X3
|
|
tlbi rvale3os, XZR
|
|
|
|
//CHECK: tlbi rvae1, x3 // encoding: [0x23,0x86,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvaae1, x3 // encoding: [0x63,0x86,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvale1, x3 // encoding: [0xa3,0x86,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvaale1, x3 // encoding: [0xe3,0x86,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvae1is, x3 // encoding: [0x23,0x82,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvaae1is, x3 // encoding: [0x63,0x82,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvale1is, x3 // encoding: [0xa3,0x82,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvaale1is, x3 // encoding: [0xe3,0x82,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvae1os, x3 // encoding: [0x23,0x85,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvaae1os, x3 // encoding: [0x63,0x85,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvale1os, x3 // encoding: [0xa3,0x85,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi rvaale1os, x3 // encoding: [0xe3,0x85,0x08,0xd5]
|
|
//CHECK-NEXT: tlbi ripas2e1is, x3 // encoding: [0x43,0x80,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi ripas2le1is, x3 // encoding: [0xc3,0x80,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi ripas2e1, x3 // encoding: [0x43,0x84,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi ripas2le1, x3 // encoding: [0xc3,0x84,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi ripas2e1os, x3 // encoding: [0x63,0x84,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi ripas2le1os, x3 // encoding: [0xe3,0x84,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi rvae2, x3 // encoding: [0x23,0x86,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi rvale2, x3 // encoding: [0xa3,0x86,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi rvae2is, x3 // encoding: [0x23,0x82,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi rvale2is, x3 // encoding: [0xa3,0x82,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi rvae2os, x3 // encoding: [0x23,0x85,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi rvale2os, x3 // encoding: [0xa3,0x85,0x0c,0xd5]
|
|
//CHECK-NEXT: tlbi rvae3, x3 // encoding: [0x23,0x86,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi rvale3, x3 // encoding: [0xa3,0x86,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi rvae3is, x3 // encoding: [0x23,0x82,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi rvale3is, x3 // encoding: [0xa3,0x82,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi rvae3os, x3 // encoding: [0x23,0x85,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi rvale3os, x3 // encoding: [0xa3,0x85,0x0e,0xd5]
|
|
//CHECK-NEXT: tlbi rvale3os, xzr // encoding: [0xbf,0x85,0x0e,0xd5]
|
|
|
|
tlbi rvae1, sp
|
|
|
|
//CHECK-ERROR: error: invalid operand for instruction
|
|
//CHECK-ERROR-NEXT: tlbi rvae1, sp
|
|
//CHECK-ERROR-NEXT: ^
|
|
|
|
//CHECK-NO-V84: error: TLBI RVAE1 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae1, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAAE1 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvaae1, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE1 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale1, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAALE1 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvaale1, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE1IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae1is, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAAE1IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvaae1is, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE1IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale1is, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAALE1IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvaale1is, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae1os, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAAE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvaae1os, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale1os, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAALE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvaale1os, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RIPAS2E1IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ripas2e1is, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RIPAS2LE1IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ripas2le1is, x3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RIPAS2E1 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ripas2e1, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RIPAS2LE1 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ripas2le1, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RIPAS2E1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ripas2e1os, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RIPAS2LE1OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi ripas2le1os, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE2 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae2, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE2 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale2, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE2IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae2is, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE2IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale2is, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE2OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae2os, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE2OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale2os, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE3 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae3, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE3 requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale3, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE3IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae3is, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE3IS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale3is, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVAE3OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvae3os, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE3OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale3os, X3
|
|
//CHECK-NO-V84-NEXT: ^
|
|
//CHECK-NO-V84-NEXT: error: TLBI RVALE3OS requires tlb-rmi
|
|
//CHECK-NO-V84-NEXT: tlbi rvale3os, XZR
|
|
//CHECK-NO-V84-NEXT: ^
|