Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AArch64 / sve-streaming-mode-test-register-mov.ll
blob337a2134de5b8abdff83bc4631f963b18710e34f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mattr=+sve -force-streaming-compatible-sve < %s | FileCheck %s
3 ; RUN: llc -mattr=+sme -force-streaming-compatible-sve < %s | FileCheck %s
6 target triple = "aarch64-unknown-linux-gnu"
8 ; A NEON Q-register mov is not valid in streaming mode, but an SVE Z-register mov is.
9 define fp128 @test_streaming_compatible_register_mov(fp128 %q0, fp128 %q1) {
10 ; CHECK-LABEL: test_streaming_compatible_register_mov:
11 ; CHECK:       // %bb.0:
12 ; CHECK-NEXT:    mov z0.d, z1.d
13 ; CHECK-NEXT:    ret
14   ret fp128 %q1
17 ; Test that `movi` isn't used (invalid in streaming mode), but fmov or SVE mov instead.
18 define double @fp_zero_constant() {
19 ; CHECK-LABEL: fp_zero_constant:
20 ; CHECK:       // %bb.0:
21 ; CHECK-NEXT:    fmov d0, xzr
22 ; CHECK-NEXT:    ret
23   ret double 0.0
26 define <2 x i64> @fixed_vec_zero_constant() {
27 ; CHECK-LABEL: fixed_vec_zero_constant:
28 ; CHECK:       // %bb.0:
29 ; CHECK-NEXT:    mov z0.d, #0 // =0x0
30 ; CHECK-NEXT:    // kill: def $q0 killed $q0 killed $z0
31 ; CHECK-NEXT:    ret
32   ret <2 x i64> zeroinitializer
35 define <2 x double> @fixed_vec_fp_zero_constant() {
36 ; CHECK-LABEL: fixed_vec_fp_zero_constant:
37 ; CHECK:       // %bb.0:
38 ; CHECK-NEXT:    mov z0.d, #0 // =0x0
39 ; CHECK-NEXT:    // kill: def $q0 killed $q0 killed $z0
40 ; CHECK-NEXT:    ret
41   ret <2 x double> <double 0.0, double 0.0>