[ARM] More MVE compare vector splat combines for ANDs
[llvm-complete.git] / test / CodeGen / ARM / inlineasm-X-allocation.ll
blobff8dba6e38c0153ed12fc0e83c9ccdf967c25ac1
1 ; RUN: llc -mtriple=armv7-none-eabi -mattr=-neon,-vfp2d16sp %s -o - | FileCheck %s  -check-prefixes=COMMON,NOVFP
2 ; RUN: llc -mtriple=armv7-none-eabi -mattr=+neon %s -float-abi=hard -o - | FileCheck %s -check-prefixes=COMMON,VFP
4 ; The intent here is to test "X", which says that any operand whatsoever is allowed.
5 ; Using this mechanism, we want to test toggling allocating GPR or SPR registers
6 ; depending on whether the float registers are available. Thus, the mnemonic is
7 ; totally irrelevant here, which is why we use FOO and also comment it out using "@"
8 ; to avoid assembler errors.
10 ; Note that this kind of IR can be generated by a function such as:
11 ;  void f1(float f) {asm volatile ("@FOO $0, $0" : : "X" (f));}
13 define arm_aapcs_vfpcc void @func(float %f) {
14 ; COMMON-LABEL: func
15 ; NOVFP:        FOO r0, r0
16 ; VFP:          FOO s0, s0
17 entry:
18   call void asm sideeffect "@FOO $0, $0", "X" (float %f) nounwind
19   ret void