219 lines
6.7 KiB
ArmAsm
219 lines
6.7 KiB
ArmAsm
// RUN: not llvm-mc -triple aarch64 \
|
|
// RUN: -mattr=+crc,+sm4,+sha3,+sha2,+aes,+fp,+neon,+ras,+lse,+predres,+ccdp,+mte,+tlb-rmi,+pan-rwv,+ccpp,+rcpc,+ls64,+flagm,+hbc,+mops \
|
|
// RUN: -mattr=+rcpc3,+lse128,+d128,+the,+rasv2,+ite,+cssc,+specres2,+gcs \
|
|
// RUN: -filetype asm -o - %s 2>&1 | FileCheck %s
|
|
|
|
.arch_extension axp64
|
|
// CHECK: error: unknown architectural extension: axp64
|
|
// CHECK-NEXT: .arch_extension axp64
|
|
|
|
crc32cx w0, w1, x3
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: crc
|
|
.arch_extension nocrc
|
|
crc32cx w0, w1, x3
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: crc
|
|
// CHECK-NEXT: crc32cx w0, w1, x3
|
|
|
|
sm4e v2.4s, v15.4s
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: sm4
|
|
.arch_extension nosm4
|
|
sm4e v2.4s, v15.4s
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: sm4
|
|
// CHECK-NEXT: sm4e v2.4s, v15.4s
|
|
|
|
sha512h q0, q1, v2.2d
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: sha3
|
|
.arch_extension nosha3
|
|
sha512h q0, q1, v2.2d
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: sha3
|
|
// CHECK-NEXT: sha512h q0, q1, v2.2d
|
|
|
|
sha1h s0, s1
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: sha2
|
|
.arch_extension nosha2
|
|
sha1h s0, s1
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: sha2
|
|
// CHECK-NEXT: sha1h s0, s1
|
|
|
|
aese v0.16b, v1.16b
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: aes
|
|
.arch_extension noaes
|
|
aese v0.16b, v1.16b
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: aes
|
|
// CHECK-NEXT: aese v0.16b, v1.16b
|
|
|
|
fminnm d0, d0, d1
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: fp
|
|
.arch_extension nofp
|
|
fminnm d0, d0, d1
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: fp
|
|
// CHECK-NEXT: fminnm d0, d0, d1
|
|
|
|
addp v0.4s, v0.4s, v0.4s
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: neon
|
|
.arch_extension nosimd
|
|
addp v0.4s, v0.4s, v0.4s
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: neon
|
|
// CHECK-NEXT: addp v0.4s, v0.4s, v0.4s
|
|
|
|
esb
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: ras
|
|
.arch_extension noras
|
|
esb
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: ras
|
|
// CHECK-NEXT: esb
|
|
|
|
casa w5, w7, [x20]
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: lse
|
|
.arch_extension nolse
|
|
casa w5, w7, [x20]
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: lse
|
|
// CHECK-NEXT: casa w5, w7, [x20]
|
|
|
|
swpp x0, x2, [x3]
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: lse128
|
|
.arch_extension nolse128
|
|
swpp x0, x2, [x3]
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: lse128
|
|
// CHECK-NEXT: swpp x0, x2, [x3]
|
|
|
|
cfp rctx, x0
|
|
// CHECK-NOT: [[@LINE-1]]:5: error: CFPRCTX requires: predres
|
|
.arch_extension nopredres
|
|
cfp rctx, x0
|
|
// CHECK: [[@LINE-1]]:5: error: CFPRCTX requires: predres
|
|
// CHECK-NEXT: cfp rctx, x0
|
|
|
|
cosp rctx, x0
|
|
// CHECK-NOT: [[@LINE-1]]:6: error: COSP requires: predres2
|
|
.arch_extension nopredres2
|
|
cosp rctx, x0
|
|
// CHECK: [[@LINE-1]]:6: error: COSP requires: predres2
|
|
// CHECK-NEXT: cosp rctx, x0
|
|
|
|
dc cvadp, x7
|
|
// CHECK-NOT: [[@LINE-1]]:4: error: DC CVADP requires: ccdp
|
|
.arch_extension noccdp
|
|
dc cvadp, x7
|
|
// CHECK: [[@LINE-1]]:4: error: DC CVADP requires: ccdp
|
|
// CHECK-NEXT: dc cvadp, x7
|
|
|
|
irg x0, x1
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: mte
|
|
.arch_extension nomte
|
|
irg x0, x1
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: mte
|
|
// CHECK-NEXT: irg x0, x1
|
|
|
|
tlbi vmalle1os
|
|
// CHECK-NOT: [[@LINE-1]]:6: error: TLBI VMALLE1OS requires: tlb-rmi
|
|
.arch_extension notlb-rmi
|
|
tlbi vmalle1os
|
|
// CHECK: [[@LINE-1]]:6: error: TLBI VMALLE1OS requires: tlb-rmi
|
|
// CHECK-NEXT: tlbi vmalle1os
|
|
|
|
at s1e1wp, x2
|
|
// CHECK-NOT: [[@LINE-1]]:4: error: AT S1E1WP requires: pan-rwv
|
|
.arch_extension nopan-rwv
|
|
at s1e1wp, x2
|
|
// CHECK: [[@LINE-1]]:4: error: AT S1E1WP requires: pan-rwv
|
|
// CHECK-NEXT: at s1e1wp, x2
|
|
|
|
dc cvap, x7
|
|
// CHECK-NOT: [[@LINE-1]]:4: error: DC CVAP requires: ccpp
|
|
.arch_extension noccpp
|
|
dc cvap, x7
|
|
// CHECK: [[@LINE-1]]:4: error: DC CVAP requires: ccpp
|
|
// CHECK-NEXT: dc cvap, x7
|
|
|
|
ldapr x0, [x1]
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: rcpc
|
|
.arch_extension norcpc
|
|
ldapr x0, [x1]
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: rcpc
|
|
// CHECK-NEXT: ldapr x0, [x1]
|
|
|
|
stilp w24, w0, [x16, #-8]!
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: rcpc3
|
|
.arch_extension norcpc3
|
|
stilp w24, w0, [x16, #-8]!
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: rcpc3
|
|
// CHECK-NEXT: stilp w24, w0, [x16, #-8]!
|
|
|
|
ld64b x0, [x13]
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: ls64
|
|
.arch_extension nols64
|
|
ld64b x0, [x13]
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: ls64
|
|
// CHECK-NEXT: ld64b x0, [x13]
|
|
|
|
cfinv
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: flagm
|
|
.arch_extension noflagm
|
|
cfinv
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: flagm
|
|
// CHECK-NEXT: cfinv
|
|
|
|
lbl:
|
|
bc.eq lbl
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: hbc
|
|
.arch_extension nohbc
|
|
bc.eq lbl
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: hbc
|
|
// CHECK-NEXT: bc.eq lbl
|
|
|
|
cpyfp [x0]!, [x1]!, x2!
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: mops
|
|
.arch_extension nomops
|
|
cpyfp [x0]!, [x1]!, x2!
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: mops
|
|
// CHECK-NEXT: cpyfp [x0]!, [x1]!, x2!
|
|
|
|
// This needs to come before `.arch_extension nothe` as it uses an instruction
|
|
// that requires both the and d128
|
|
sysp #0, c2, c0, #0, x0, x1
|
|
rcwcasp x0, x1, x6, x7, [x4]
|
|
// CHECK-NOT: [[@LINE-2]]:1: error: instruction requires: d128
|
|
// CHECK-NOT: [[@LINE-2]]:1: error: instruction requires: d128
|
|
.arch_extension nod128
|
|
sysp #0, c2, c0, #0, x0, x1
|
|
rcwcasp x0, x1, x6, x7, [x4]
|
|
// CHECK: [[@LINE-2]]:1: error: instruction requires: d128
|
|
// CHECK-NEXT: sysp #0, c2, c0, #0, x0, x1
|
|
// CHECK: [[@LINE-3]]:1: error: instruction requires: d128
|
|
// CHECK-NEXT: rcwcasp x0, x1, x6, x7, [x4]
|
|
|
|
rcwswp x0, x1, [x2]
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: the
|
|
.arch_extension nothe
|
|
rcwswp x0, x1, [x2]
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: the
|
|
// CHECK-NEXT: rcwswp x0, x1, [x2]
|
|
|
|
trcit x0
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: ite
|
|
.arch_extension noite
|
|
trcit x0
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: ite
|
|
// CHECK-NEXT: trcit x0
|
|
|
|
umax x0, x1, x2
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: cssc
|
|
.arch_extension nocssc
|
|
umax x0, x1, x2
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: cssc
|
|
// CHECK-NEXT: umax x0, x1, x2
|
|
|
|
mrs x0, ERXGSR_EL1
|
|
// CHECK-NOT: [[@LINE-1]]:9: error: expected readable system register
|
|
.arch_extension norasv2
|
|
mrs x0, ERXGSR_EL1
|
|
// CHECK: [[@LINE-1]]:9: error: expected readable system register
|
|
// CHECK-NEXT: mrs x0, ERXGSR_EL1
|
|
|
|
gcspushm x0
|
|
// CHECK-NOT: [[@LINE-1]]:1: error: instruction requires: gcs
|
|
.arch_extension nogcs
|
|
gcspushm x0
|
|
// CHECK: [[@LINE-1]]:1: error: instruction requires: gcs
|
|
// CHECK-NEXT: gcspushm x0
|