]> granicus.if.org Git - llvm/commitdiff
GISel: Canonicalize select tests using update_mir_test_checks
authorJustin Bogner <mail@justinbogner.com>
Wed, 18 Oct 2017 23:33:31 +0000 (23:33 +0000)
committerJustin Bogner <mail@justinbogner.com>
Wed, 18 Oct 2017 23:33:31 +0000 (23:33 +0000)
This runs `udpate_mir_test_checks --add-vreg-checks` on the tests taht
are already more or less in the format that generates, so that there
will be less churn in some upcoming changes.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@316139 91177308-0d34-0410-b5e6-96231b3b80d8

43 files changed:
test/CodeGen/AArch64/GlobalISel/regbankselect-default.mir
test/CodeGen/AArch64/GlobalISel/select-binop.mir
test/CodeGen/AArch64/GlobalISel/select-bitcast.mir
test/CodeGen/AArch64/GlobalISel/select-bswap.mir
test/CodeGen/AArch64/GlobalISel/select-fma.mir
test/CodeGen/AArch64/GlobalISel/select-fp-casts.mir
test/CodeGen/AArch64/GlobalISel/select-imm.mir
test/CodeGen/AArch64/GlobalISel/select-implicit-def.mir
test/CodeGen/AArch64/GlobalISel/select-int-ext.mir
test/CodeGen/AArch64/GlobalISel/select-int-ptr-casts.mir
test/CodeGen/AArch64/GlobalISel/select-intrinsic-aarch64-sdiv.mir
test/CodeGen/AArch64/GlobalISel/select-load.mir
test/CodeGen/AArch64/GlobalISel/select-muladd.mir
test/CodeGen/AArch64/GlobalISel/select-neon-vcvtfxu2fp.mir
test/CodeGen/AArch64/GlobalISel/select-store.mir
test/CodeGen/AArch64/GlobalISel/select-trunc.mir
test/CodeGen/AArch64/GlobalISel/select-xor.mir
test/CodeGen/X86/GlobalISel/select-add-v512.mir
test/CodeGen/X86/GlobalISel/select-add-x32.mir
test/CodeGen/X86/GlobalISel/select-and-scalar.mir
test/CodeGen/X86/GlobalISel/select-blsi.mir
test/CodeGen/X86/GlobalISel/select-blsr.mir
test/CodeGen/X86/GlobalISel/select-cmp.mir
test/CodeGen/X86/GlobalISel/select-constant.mir
test/CodeGen/X86/GlobalISel/select-ext-x86-64.mir
test/CodeGen/X86/GlobalISel/select-fpext-scalar.mir
test/CodeGen/X86/GlobalISel/select-gep.mir
test/CodeGen/X86/GlobalISel/select-insert-vec512.mir
test/CodeGen/X86/GlobalISel/select-intrinsic-x86-flags-read-u32.mir
test/CodeGen/X86/GlobalISel/select-leaf-constant.mir
test/CodeGen/X86/GlobalISel/select-memop-scalar-x32.mir
test/CodeGen/X86/GlobalISel/select-memop-v512.mir
test/CodeGen/X86/GlobalISel/select-merge-vec256.mir
test/CodeGen/X86/GlobalISel/select-merge-vec512.mir
test/CodeGen/X86/GlobalISel/select-mul-scalar.mir
test/CodeGen/X86/GlobalISel/select-mul-vec.mir
test/CodeGen/X86/GlobalISel/select-or-scalar.mir
test/CodeGen/X86/GlobalISel/select-sub-v512.mir
test/CodeGen/X86/GlobalISel/select-trunc.mir
test/CodeGen/X86/GlobalISel/select-undef.mir
test/CodeGen/X86/GlobalISel/select-unmerge-vec256.mir
test/CodeGen/X86/GlobalISel/select-unmerge-vec512.mir
test/CodeGen/X86/GlobalISel/select-xor-scalar.mir

index fe22db27087ee68530edc27e8624ef94e07afa68..a99104f9cbc7ce575c8699f371d03f8fcb99322c 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -O0 -mtriple arm64-- -run-pass=regbankselect -global-isel %s -o - | FileCheck %s
 
 # Check the default mappings for various instructions.
 ...
 
 ---
-# CHECK-LABEL: name: test_add_s32
 name:            test_add_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_ADD %0, %0
+    ; CHECK-LABEL: name: test_add_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[ADD:%[0-9]+]](s32) = G_ADD [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_ADD %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_add_v4s32
 name:            test_add_v4s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %q0
-    ; CHECK:      %0(<4 x s32>) = COPY %q0
-    ; CHECK:      %1(<4 x s32>) = G_ADD %0, %0
+    ; CHECK-LABEL: name: test_add_v4s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](<4 x s32>) = COPY %q0
+    ; CHECK: [[ADD:%[0-9]+]](<4 x s32>) = G_ADD [[COPY]], [[COPY]]
     %0(<4 x s32>) = COPY %q0
     %1(<4 x s32>) = G_ADD %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_sub_s32
 name:            test_sub_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_SUB %0, %0
+    ; CHECK-LABEL: name: test_sub_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[SUB:%[0-9]+]](s32) = G_SUB [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_SUB %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_sub_v4s32
 name:            test_sub_v4s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %q0
-    ; CHECK:      %0(<4 x s32>) = COPY %q0
-    ; CHECK:      %1(<4 x s32>) = G_SUB %0, %0
+    ; CHECK-LABEL: name: test_sub_v4s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](<4 x s32>) = COPY %q0
+    ; CHECK: [[SUB:%[0-9]+]](<4 x s32>) = G_SUB [[COPY]], [[COPY]]
     %0(<4 x s32>) = COPY %q0
     %1(<4 x s32>) = G_SUB %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_mul_s32
 name:            test_mul_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_MUL %0, %0
+    ; CHECK-LABEL: name: test_mul_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[MUL:%[0-9]+]](s32) = G_MUL [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_MUL %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_mul_v4s32
 name:            test_mul_v4s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %q0
-    ; CHECK:      %0(<4 x s32>) = COPY %q0
-    ; CHECK:      %1(<4 x s32>) = G_MUL %0, %0
+    ; CHECK-LABEL: name: test_mul_v4s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](<4 x s32>) = COPY %q0
+    ; CHECK: [[MUL:%[0-9]+]](<4 x s32>) = G_MUL [[COPY]], [[COPY]]
     %0(<4 x s32>) = COPY %q0
     %1(<4 x s32>) = G_MUL %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_and_s32
 name:            test_and_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_AND %0, %0
+    ; CHECK-LABEL: name: test_and_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[AND:%[0-9]+]](s32) = G_AND [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_AND %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_and_v4s32
 name:            test_and_v4s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %q0
-    ; CHECK:      %0(<4 x s32>) = COPY %q0
-    ; CHECK:      %1(<4 x s32>) = G_AND %0, %0
+    ; CHECK-LABEL: name: test_and_v4s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](<4 x s32>) = COPY %q0
+    ; CHECK: [[AND:%[0-9]+]](<4 x s32>) = G_AND [[COPY]], [[COPY]]
     %0(<4 x s32>) = COPY %q0
     %1(<4 x s32>) = G_AND %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_or_s32
 name:            test_or_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_OR %0, %0
+    ; CHECK-LABEL: name: test_or_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[OR:%[0-9]+]](s32) = G_OR [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_OR %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_or_v4s32
 name:            test_or_v4s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %q0
-    ; CHECK:      %0(<4 x s32>) = COPY %q0
-    ; CHECK:      %1(<4 x s32>) = G_OR %0, %0
+    ; CHECK-LABEL: name: test_or_v4s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](<4 x s32>) = COPY %q0
+    ; CHECK: [[OR:%[0-9]+]](<4 x s32>) = G_OR [[COPY]], [[COPY]]
     %0(<4 x s32>) = COPY %q0
     %1(<4 x s32>) = G_OR %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_xor_s32
 name:            test_xor_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_XOR %0, %0
+    ; CHECK-LABEL: name: test_xor_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[XOR:%[0-9]+]](s32) = G_XOR [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_XOR %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_xor_v4s32
 name:            test_xor_v4s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %q0
-    ; CHECK:      %0(<4 x s32>) = COPY %q0
-    ; CHECK:      %1(<4 x s32>) = G_XOR %0, %0
+    ; CHECK-LABEL: name: test_xor_v4s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](<4 x s32>) = COPY %q0
+    ; CHECK: [[XOR:%[0-9]+]](<4 x s32>) = G_XOR [[COPY]], [[COPY]]
     %0(<4 x s32>) = COPY %q0
     %1(<4 x s32>) = G_XOR %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_shl_s32
 name:            test_shl_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_SHL %0, %0
+    ; CHECK-LABEL: name: test_shl_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[SHL:%[0-9]+]](s32) = G_SHL [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_SHL %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_shl_v4s32
 name:            test_shl_v4s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %q0
-    ; CHECK:      %0(<4 x s32>) = COPY %q0
-    ; CHECK:      %1(<4 x s32>) = G_SHL %0, %0
+    ; CHECK-LABEL: name: test_shl_v4s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](<4 x s32>) = COPY %q0
+    ; CHECK: [[SHL:%[0-9]+]](<4 x s32>) = G_SHL [[COPY]], [[COPY]]
     %0(<4 x s32>) = COPY %q0
     %1(<4 x s32>) = G_SHL %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_lshr_s32
 name:            test_lshr_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_LSHR %0, %0
+    ; CHECK-LABEL: name: test_lshr_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[LSHR:%[0-9]+]](s32) = G_LSHR [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_LSHR %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_ashr_s32
 name:            test_ashr_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_ASHR %0, %0
+    ; CHECK-LABEL: name: test_ashr_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[ASHR:%[0-9]+]](s32) = G_ASHR [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_ASHR %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_sdiv_s32
 name:            test_sdiv_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_SDIV %0, %0
+    ; CHECK-LABEL: name: test_sdiv_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[SDIV:%[0-9]+]](s32) = G_SDIV [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_SDIV %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_udiv_s32
 name:            test_udiv_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_UDIV %0, %0
+    ; CHECK-LABEL: name: test_udiv_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[UDIV:%[0-9]+]](s32) = G_UDIV [[COPY]], [[COPY]]
     %0(s32) = COPY %w0
     %1(s32) = G_UDIV %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_anyext_s64_s32
 name:            test_anyext_s64_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s64) = G_ANYEXT %0
+    ; CHECK-LABEL: name: test_anyext_s64_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[ANYEXT:%[0-9]+]](s64) = G_ANYEXT [[COPY]](s32)
     %0(s32) = COPY %w0
     %1(s64) = G_ANYEXT %0
 ...
 
 ---
-# CHECK-LABEL: name: test_sext_s64_s32
 name:            test_sext_s64_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s64) = G_SEXT %0
+    ; CHECK-LABEL: name: test_sext_s64_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[SEXT:%[0-9]+]](s64) = G_SEXT [[COPY]](s32)
     %0(s32) = COPY %w0
     %1(s64) = G_SEXT %0
 ...
 
 ---
-# CHECK-LABEL: name: test_zext_s64_s32
 name:            test_zext_s64_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s64) = G_ZEXT %0
+    ; CHECK-LABEL: name: test_zext_s64_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[ZEXT:%[0-9]+]](s64) = G_ZEXT [[COPY]](s32)
     %0(s32) = COPY %w0
     %1(s64) = G_ZEXT %0
 ...
 
 ---
-# CHECK-LABEL: name: test_trunc_s32_s64
 name:            test_trunc_s32_s64
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %x0
-    ; CHECK:      %0(s64) = COPY %x0
-    ; CHECK:      %1(s32) = G_TRUNC %0
+    ; CHECK-LABEL: name: test_trunc_s32_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s64) = COPY %x0
+    ; CHECK: [[TRUNC:%[0-9]+]](s32) = G_TRUNC [[COPY]](s64)
     %0(s64) = COPY %x0
     %1(s32) = G_TRUNC %0
 ...
 
 ---
-# CHECK-LABEL: name: test_constant_s32
 name:            test_constant_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
 body: |
   bb.0:
-    ; CHECK:      %0(s32) = G_CONSTANT 123
+    ; CHECK-LABEL: name: test_constant_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK: [[C:%[0-9]+]](s32) = G_CONSTANT 123
     %0(s32) = G_CONSTANT 123
 ...
 
 ---
-# CHECK-LABEL: name: test_constant_p0
 name:            test_constant_p0
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
 body: |
   bb.0:
-    ; CHECK:      %0(p0) = G_CONSTANT 0
+    ; CHECK-LABEL: name: test_constant_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK: [[C:%[0-9]+]](p0) = G_CONSTANT 0
     %0(p0) = G_CONSTANT 0
 ...
 
 ---
-# CHECK-LABEL: name: test_icmp_s32
 name:            test_icmp_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
@@ -531,21 +528,22 @@ registers:
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s32) = G_ICMP intpred(ne), %0(s32), %0
-    ; CHECK:      %2(s1) = G_TRUNC %1(s32)
+    ; CHECK-LABEL: name: test_icmp_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[ICMP:%[0-9]+]](s32) = G_ICMP intpred(ne), [[COPY]](s32), [[COPY]]
+    ; CHECK: [[TRUNC:%[0-9]+]](s1) = G_TRUNC [[ICMP]](s32)
     %0(s32) = COPY %w0
     %1(s32) = G_ICMP intpred(ne), %0, %0
     %2(s1) = G_TRUNC %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: test_icmp_p0
 name:            test_icmp_p0
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
@@ -553,243 +551,244 @@ registers:
 body: |
   bb.0:
     liveins: %x0
-    ; CHECK:      %0(p0) = COPY %x0
-    ; CHECK:      %1(s32) = G_ICMP intpred(ne), %0(p0), %0
-    ; CHECK:      %2(s1) = G_TRUNC %1(s32)
+    ; CHECK-LABEL: name: test_icmp_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](p0) = COPY %x0
+    ; CHECK: [[ICMP:%[0-9]+]](s32) = G_ICMP intpred(ne), [[COPY]](p0), [[COPY]]
+    ; CHECK: [[TRUNC:%[0-9]+]](s1) = G_TRUNC [[ICMP]](s32)
     %0(p0) = COPY %x0
     %1(s32) = G_ICMP intpred(ne), %0, %0
     %2(s1) = G_TRUNC %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: test_frame_index_p0
 name:            test_frame_index_p0
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
 stack:
   - { id: 0, name: ptr0, offset: 0, size: 8, alignment: 8 }
 body: |
   bb.0:
-    ; CHECK:      %0(p0) = G_FRAME_INDEX %stack.0.ptr0
+    ; CHECK-LABEL: name: test_frame_index_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK: [[FRAME_INDEX:%[0-9]+]](p0) = G_FRAME_INDEX %stack.0.ptr0
     %0(p0) = G_FRAME_INDEX %stack.0.ptr0
 ...
 
 ---
-# CHECK-LABEL: name: test_ptrtoint_s64_p0
 name:            test_ptrtoint_s64_p0
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %x0
-    ; CHECK:      %0(p0) = COPY %x0
-    ; CHECK:      %1(s64) = G_PTRTOINT %0
+    ; CHECK-LABEL: name: test_ptrtoint_s64_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](p0) = COPY %x0
+    ; CHECK: [[PTRTOINT:%[0-9]+]](s64) = G_PTRTOINT [[COPY]](p0)
     %0(p0) = COPY %x0
     %1(s64) = G_PTRTOINT %0
 ...
 
 ---
-# CHECK-LABEL: name: test_inttoptr_p0_s64
 name:            test_inttoptr_p0_s64
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %x0
-    ; CHECK:      %0(s64) = COPY %x0
-    ; CHECK:      %1(p0) = G_INTTOPTR %0
+    ; CHECK-LABEL: name: test_inttoptr_p0_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s64) = COPY %x0
+    ; CHECK: [[INTTOPTR:%[0-9]+]](p0) = G_INTTOPTR [[COPY]](s64)
     %0(s64) = COPY %x0
     %1(p0) = G_INTTOPTR %0
 ...
 
 ---
-# CHECK-LABEL: name: test_load_s32_p0
 name:            test_load_s32_p0
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %x0
-    ; CHECK:      %0(p0) = COPY %x0
-    ; CHECK:      %1(s32) = G_LOAD %0
+    ; CHECK-LABEL: name: test_load_s32_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](p0) = COPY %x0
+    ; CHECK: [[LOAD:%[0-9]+]](s32) = G_LOAD [[COPY]](p0) :: (load 4)
     %0(p0) = COPY %x0
     %1(s32) = G_LOAD %0 :: (load 4)
 ...
 
 ---
-# CHECK-LABEL: name: test_store_s32_p0
 name:            test_store_s32_p0
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %x0, %w1
-    ; CHECK:      %0(p0) = COPY %x0
-    ; CHECK:      %1(s32) = COPY %w1
-    ; CHECK:      G_STORE %1(s32), %0(p0)
+    ; CHECK-LABEL: name: test_store_s32_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](p0) = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]](s32) = COPY %w1
+    ; CHECK: G_STORE [[COPY1]](s32), [[COPY]](p0) :: (store 4)
     %0(p0) = COPY %x0
     %1(s32) = COPY %w1
     G_STORE %1, %0 :: (store 4)
 ...
 
 ---
-# CHECK-LABEL: name: test_fadd_s32
 name:            test_fadd_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %s0
-    ; CHECK:      %0(s32) = COPY %s0
-    ; CHECK:      %1(s32) = G_FADD %0, %0
+    ; CHECK-LABEL: name: test_fadd_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %s0
+    ; CHECK: [[FADD:%[0-9]+]](s32) = G_FADD [[COPY]], [[COPY]]
     %0(s32) = COPY %s0
     %1(s32) = G_FADD %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fsub_s32
 name:            test_fsub_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %s0
-    ; CHECK:      %0(s32) = COPY %s0
-    ; CHECK:      %1(s32) = G_FSUB %0, %0
+    ; CHECK-LABEL: name: test_fsub_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %s0
+    ; CHECK: [[FSUB:%[0-9]+]](s32) = G_FSUB [[COPY]], [[COPY]]
     %0(s32) = COPY %s0
     %1(s32) = G_FSUB %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fmul_s32
 name:            test_fmul_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %s0
-    ; CHECK:      %0(s32) = COPY %s0
-    ; CHECK:      %1(s32) = G_FMUL %0, %0
+    ; CHECK-LABEL: name: test_fmul_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %s0
+    ; CHECK: [[FMUL:%[0-9]+]](s32) = G_FMUL [[COPY]], [[COPY]]
     %0(s32) = COPY %s0
     %1(s32) = G_FMUL %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fdiv_s32
 name:            test_fdiv_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %s0
-    ; CHECK:      %0(s32) = COPY %s0
-    ; CHECK:      %1(s32) = G_FDIV %0, %0
+    ; CHECK-LABEL: name: test_fdiv_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %s0
+    ; CHECK: [[FDIV:%[0-9]+]](s32) = G_FDIV [[COPY]], [[COPY]]
     %0(s32) = COPY %s0
     %1(s32) = G_FDIV %0, %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fpext_s64_s32
 name:            test_fpext_s64_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %s0
-    ; CHECK:      %0(s32) = COPY %s0
-    ; CHECK:      %1(s64) = G_FPEXT %0
+    ; CHECK-LABEL: name: test_fpext_s64_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %s0
+    ; CHECK: [[FPEXT:%[0-9]+]](s64) = G_FPEXT [[COPY]](s32)
     %0(s32) = COPY %s0
     %1(s64) = G_FPEXT %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fptrunc_s32_s64
 name:            test_fptrunc_s32_s64
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %d0
-    ; CHECK:      %0(s64) = COPY %d0
-    ; CHECK:      %1(s32) = G_FPTRUNC %0
+    ; CHECK-LABEL: name: test_fptrunc_s32_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s64) = COPY %d0
+    ; CHECK: [[FPTRUNC:%[0-9]+]](s32) = G_FPTRUNC [[COPY]](s64)
     %0(s64) = COPY %d0
     %1(s32) = G_FPTRUNC %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fconstant_s32
 name:            test_fconstant_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
 body: |
   bb.0:
-    ; CHECK:      %0(s32) = G_FCONSTANT float 1.0
+    ; CHECK-LABEL: name: test_fconstant_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK: [[C:%[0-9]+]](s32) = G_FCONSTANT float 1.000000e+00
     %0(s32) = G_FCONSTANT float 1.0
 ...
 
 ---
-# CHECK-LABEL: name: test_fcmp_s32
 name:            test_fcmp_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
@@ -797,100 +796,99 @@ registers:
 body: |
   bb.0:
     liveins: %s0
-    ; CHECK:      %0(s32) = COPY %s0
-    ; CHECK:      [[FCMP:%[0-9]+]](s32) = G_FCMP floatpred(olt), %0(s32), %0
-    ; CHECK:      [[TRUNC:%[0-9]+]](s1) = G_TRUNC [[FCMP]]
+    ; CHECK-LABEL: name: test_fcmp_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %s0
+    ; CHECK: [[FCMP:%[0-9]+]](s32) = G_FCMP floatpred(olt), [[COPY]](s32), [[COPY]]
+    ; CHECK: [[TRUNC:%[0-9]+]](s1) = G_TRUNC [[FCMP]](s32)
     %0(s32) = COPY %s0
     %1(s32) = G_FCMP floatpred(olt), %0, %0
     %2(s1) = G_TRUNC %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: test_sitofp_s64_s32
 name:            test_sitofp_s64_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %w0
-    ; CHECK:      %0(s32) = COPY %w0
-    ; CHECK:      %1(s64) = G_SITOFP %0
+    ; CHECK-LABEL: name: test_sitofp_s64_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %w0
+    ; CHECK: [[SITOFP:%[0-9]+]](s64) = G_SITOFP [[COPY]](s32)
     %0(s32) = COPY %w0
     %1(s64) = G_SITOFP %0
 ...
 
 ---
-# CHECK-LABEL: name: test_uitofp_s32_s64
 name:            test_uitofp_s32_s64
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: fpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %x0
-    ; CHECK:      %0(s64) = COPY %x0
-    ; CHECK:      %1(s32) = G_UITOFP %0
+    ; CHECK-LABEL: name: test_uitofp_s32_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: fpr
+    ; CHECK: [[COPY:%[0-9]+]](s64) = COPY %x0
+    ; CHECK: [[UITOFP:%[0-9]+]](s32) = G_UITOFP [[COPY]](s64)
     %0(s64) = COPY %x0
     %1(s32) = G_UITOFP %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fptosi_s64_s32
 name:            test_fptosi_s64_s32
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %s0
-    ; CHECK:      %0(s32) = COPY %s0
-    ; CHECK:      %1(s64) = G_FPTOSI %0
+    ; CHECK-LABEL: name: test_fptosi_s64_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s32) = COPY %s0
+    ; CHECK: [[FPTOSI:%[0-9]+]](s64) = G_FPTOSI [[COPY]](s32)
     %0(s32) = COPY %s0
     %1(s64) = G_FPTOSI %0
 ...
 
 ---
-# CHECK-LABEL: name: test_fptoui_s32_s64
 name:            test_fptoui_s32_s64
 legalized:       true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: fpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _ }
   - { id: 1, class: _ }
 body: |
   bb.0:
     liveins: %d0
-    ; CHECK:      %0(s64) = COPY %d0
-    ; CHECK:      %1(s32) = G_FPTOUI %0
+    ; CHECK-LABEL: name: test_fptoui_s32_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]](s64) = COPY %d0
+    ; CHECK: [[FPTOUI:%[0-9]+]](s32) = G_FPTOUI [[COPY]](s64)
     %0(s64) = COPY %d0
     %1(s32) = G_FPTOUI %0
 ...
 
 ---
-# CHECK-LABEL: name: test_gphi_ptr
 name:            test_gphi_ptr
 legalized:       true
 tracksRegLiveness: true
-# CHECK: registers:
-# CHECK:   - { id: 0, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 1, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 2, class: gpr, preferred-register: '' }
-# CHECK:   - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: _, preferred-register: '' }
   - { id: 1, class: _, preferred-register: '' }
@@ -899,6 +897,28 @@ registers:
   - { id: 4, class: _, preferred-register: '' }
   - { id: 5, class: _, preferred-register: '' }
 body:             |
+  ; CHECK-LABEL: name: test_gphi_ptr
+  ; CHECK: registers:
+  ; CHECK-NEXT: id: 0, class: gpr
+  ; CHECK-NEXT: id: 1, class: gpr
+  ; CHECK-NEXT: id: 2, class: gpr
+  ; CHECK-NEXT: id: 3, class: gpr
+  ; CHECK-NEXT: id: 4, class: _
+  ; CHECK-NEXT: id: 5, class: _
+  ; CHECK: bb.0:
+  ; CHECK:   successors: %bb.1(0x40000000), %bb.2(0x40000000)
+  ; CHECK:   liveins: %w2, %x0, %x1
+  ; CHECK:   [[COPY:%[0-9]+]](p0) = COPY %x0
+  ; CHECK:   [[COPY1:%[0-9]+]](p0) = COPY %x1
+  ; CHECK:   [[COPY2:%[0-9]+]](s1) = COPY %w2
+  ; CHECK:   G_BRCOND [[COPY2]](s1), %bb.1
+  ; CHECK:   G_BR %bb.2
+  ; CHECK: bb.1:
+  ; CHECK:   successors: %bb.2(0x80000000)
+  ; CHECK: bb.2:
+  ; CHECK:   [[PHI:%[0-9]+]](p0) = G_PHI [[COPY]](p0), %bb.0, [[COPY1]](p0), %bb.1
+  ; CHECK:   %x0 = COPY [[PHI]](p0)
+  ; CHECK:   RET_ReallyLR implicit %x0
   bb.0:
     successors: %bb.1, %bb.2
     liveins: %w2, %x0, %x1
index 70cda516d5f10535b258710cfd85c03f7814d360..78d34bf5655ce56508819f516fbb7af33e3bc870 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ---
 # Check that we select a 32-bit GPR G_ADD into ADDWrr on GPR32.
 # Also check that we constrain the register class of the COPY to GPR32.
-# CHECK-LABEL: name: add_s32_gpr
 name:            add_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = ADDWrr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: add_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[ADDWrr:%[0-9]+]] = ADDWrr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[ADDWrr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_ADD %0, %1
@@ -88,28 +89,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for 64-bit operations.
-# CHECK-LABEL: name: add_s64_gpr
 name:            add_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = ADDXrr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: add_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[ADDXrr:%[0-9]+]] = ADDXrr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[ADDXrr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_ADD %0, %1
@@ -117,27 +118,27 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: add_imm_s32_gpr
 name:            add_imm_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32sp, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %2 = ADDWri %0, 1, 0
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: add_imm_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr32sp
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[ADDWri:%[0-9]+]] = ADDWri [[COPY]], 1, 0
+    ; CHECK: %w0 = COPY [[ADDWri]]
     %0(s32) = COPY %w0
     %1(s32) = G_CONSTANT i32 1
     %2(s32) = G_ADD %0, %1
@@ -145,27 +146,27 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: add_imm_s64_gpr
 name:            add_imm_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64sp, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %2 = ADDXri %0, 1, 0
 body:             |
   bb.0:
     liveins: %x0, %w1
 
+    ; CHECK-LABEL: name: add_imm_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr64sp
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[ADDXri:%[0-9]+]] = ADDXri [[COPY]], 1, 0
+    ; CHECK: %x0 = COPY [[ADDXri]]
     %0(s64) = COPY %x0
     %1(s64) = G_CONSTANT i32 1
     %2(s64) = G_ADD %0, %1
@@ -173,25 +174,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: add_imm_s32_gpr_bb
 name:            add_imm_s32_gpr_bb
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32sp, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:  bb.1:
-# CHECK:    %2 = ADDWri %0, 1, 0
 body:             |
+  ; CHECK-LABEL: name: add_imm_s32_gpr_bb
+  ; CHECK: registers:
+  ; CHECK-NEXT: id: 0, class: gpr32sp
+  ; CHECK-NEXT: id: 1, class: gpr
+  ; CHECK-NEXT: id: 2, class: gpr32sp
+  ; CHECK: bb.0:
+  ; CHECK:   successors: %bb.1(0x80000000)
+  ; CHECK:   [[COPY:%[0-9]+]] = COPY %w0
+  ; CHECK:   B %bb.1
+  ; CHECK: bb.1:
+  ; CHECK:   [[ADDWri:%[0-9]+]] = ADDWri [[COPY]], 1, 0
+  ; CHECK:   %w0 = COPY [[ADDWri]]
   bb.0:
     liveins: %w0, %w1
     successors: %bb.1
@@ -207,28 +211,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_SUB operations.
-# CHECK-LABEL: name: sub_s32_gpr
 name:            sub_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = SUBSWrr %0, %1, implicit-def %nzcv
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: sub_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[SUBSWrr:%[0-9]+]] = SUBSWrr [[COPY]], [[COPY1]], implicit-def %nzcv
+    ; CHECK: %w0 = COPY [[SUBSWrr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_SUB %0, %1
@@ -237,28 +241,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_SUB operations.
-# CHECK-LABEL: name: sub_s64_gpr
 name:            sub_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = SUBSXrr %0, %1, implicit-def %nzcv
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: sub_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[SUBSXrr:%[0-9]+]] = SUBSXrr [[COPY]], [[COPY1]], implicit-def %nzcv
+    ; CHECK: %x0 = COPY [[SUBSXrr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_SUB %0, %1
@@ -267,28 +271,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_OR operations.
-# CHECK-LABEL: name: or_s32_gpr
 name:            or_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = ORRWrr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: or_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[ORRWrr:%[0-9]+]] = ORRWrr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[ORRWrr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_OR %0, %1
@@ -297,28 +301,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_OR operations.
-# CHECK-LABEL: name: or_s64_gpr
 name:            or_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = ORRXrr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: or_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[ORRXrr:%[0-9]+]] = ORRXrr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[ORRXrr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_OR %0, %1
@@ -327,30 +331,30 @@ body:             |
 
 ---
 # 64-bit G_OR on vector registers.
-# CHECK-LABEL: name: or_v2s32_fpr
 name:            or_v2s32_fpr
 legalized:       true
 regBankSelected: true
 #
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %d1
 # The actual OR does not matter as long as it is operating
 # on 64-bit width vector.
-# CHECK:    %2 = ORRv8i8 %0, %1
 body:             |
   bb.0:
     liveins: %d0, %d1
 
+    ; CHECK-LABEL: name: or_v2s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK-NEXT: id: 2, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %d1
+    ; CHECK: [[ORRv8i8_:%[0-9]+]] = ORRv8i8 [[COPY]], [[COPY1]]
+    ; CHECK: %d0 = COPY [[ORRv8i8_]]
       %0(<2 x s32>) = COPY %d0
       %1(<2 x s32>) = COPY %d1
       %2(<2 x s32>) = G_OR %0, %1
@@ -359,28 +363,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_AND operations.
-# CHECK-LABEL: name: and_s32_gpr
 name:            and_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = ANDWrr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: and_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[ANDWrr:%[0-9]+]] = ANDWrr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[ANDWrr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_AND %0, %1
@@ -389,28 +393,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_AND operations.
-# CHECK-LABEL: name: and_s64_gpr
 name:            and_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = ANDXrr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: and_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[ANDXrr:%[0-9]+]] = ANDXrr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[ANDXrr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_AND %0, %1
@@ -419,28 +423,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_SHL operations.
-# CHECK-LABEL: name: shl_s32_gpr
 name:            shl_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = LSLVWr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: shl_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[LSLVWr:%[0-9]+]] = LSLVWr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[LSLVWr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_SHL %0, %1
@@ -449,28 +453,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_SHL operations.
-# CHECK-LABEL: name: shl_s64_gpr
 name:            shl_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = LSLVXr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: shl_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[LSLVXr:%[0-9]+]] = LSLVXr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[LSLVXr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_SHL %0, %1
@@ -479,28 +483,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_LSHR operations.
-# CHECK-LABEL: name: lshr_s32_gpr
 name:            lshr_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = LSRVWr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: lshr_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[LSRVWr:%[0-9]+]] = LSRVWr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[LSRVWr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_LSHR %0, %1
@@ -509,28 +513,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_LSHR operations.
-# CHECK-LABEL: name: lshr_s64_gpr
 name:            lshr_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = LSRVXr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: lshr_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[LSRVXr:%[0-9]+]] = LSRVXr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[LSRVXr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_LSHR %0, %1
@@ -539,28 +543,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_ASHR operations.
-# CHECK-LABEL: name: ashr_s32_gpr
 name:            ashr_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = ASRVWr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: ashr_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[ASRVWr:%[0-9]+]] = ASRVWr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[ASRVWr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_ASHR %0, %1
@@ -569,28 +573,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_ASHR operations.
-# CHECK-LABEL: name: ashr_s64_gpr
 name:            ashr_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = ASRVXr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: ashr_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[ASRVXr:%[0-9]+]] = ASRVXr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[ASRVXr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_ASHR %0, %1
@@ -600,28 +604,28 @@ body:             |
 ---
 # Check that we select s32 GPR G_MUL. This is trickier than other binops because
 # there is only MADDWrrr, and we have to use the WZR physreg.
-# CHECK-LABEL: name: mul_s32_gpr
 name:            mul_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = MADDWrrr %0, %1, %wzr
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: mul_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[MADDWrrr:%[0-9]+]] = MADDWrrr [[COPY]], [[COPY1]], %wzr
+    ; CHECK: %w0 = COPY [[MADDWrrr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_MUL %0, %1
@@ -630,28 +634,28 @@ body:             |
 
 ---
 # Same as mul_s32_gpr for the s64 type.
-# CHECK-LABEL: name: mul_s64_gpr
 name:            mul_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = MADDXrrr %0, %1, %xzr
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: mul_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[MADDXrrr:%[0-9]+]] = MADDXrrr [[COPY]], [[COPY1]], %xzr
+    ; CHECK: %x0 = COPY [[MADDXrrr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_MUL %0, %1
@@ -660,26 +664,27 @@ body:             |
 
 ---
 # Same as mul_s32_gpr for the s64 type.
-# CHECK-LABEL: name: mulh_s64_gpr
 name:            mulh_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr64, preferred-register: '' }
-
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = SMULHrr %0, %1
-# CHECK:    %3 = UMULHrr %0, %1
+
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: mulh_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK-NEXT: id: 3, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[SMULHrr:%[0-9]+]] = SMULHrr [[COPY]], [[COPY1]]
+    ; CHECK: [[UMULHrr:%[0-9]+]] = UMULHrr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[SMULHrr]]
+    ; CHECK: %x0 = COPY [[UMULHrr]]
     %0:gpr(s64) = COPY %x0
     %1:gpr(s64) = COPY %x1
     %2:gpr(s64) = G_SMULH %0, %1
@@ -690,28 +695,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_SDIV operations.
-# CHECK-LABEL: name: sdiv_s32_gpr
 name:            sdiv_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = SDIVWr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: sdiv_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[SDIVWr:%[0-9]+]] = SDIVWr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[SDIVWr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_SDIV %0, %1
@@ -720,28 +725,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_SDIV operations.
-# CHECK-LABEL: name: sdiv_s64_gpr
 name:            sdiv_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = SDIVXr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: sdiv_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[SDIVXr:%[0-9]+]] = SDIVXr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[SDIVXr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_SDIV %0, %1
@@ -750,28 +755,28 @@ body:             |
 
 ---
 # Same as add_s32_gpr, for G_UDIV operations.
-# CHECK-LABEL: name: udiv_s32_gpr
 name:            udiv_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = UDIVWr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: udiv_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[UDIVWr:%[0-9]+]] = UDIVWr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[UDIVWr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_UDIV %0, %1
@@ -780,28 +785,28 @@ body:             |
 
 ---
 # Same as add_s64_gpr, for G_UDIV operations.
-# CHECK-LABEL: name: udiv_s64_gpr
 name:            udiv_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = UDIVXr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: udiv_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[UDIVXr:%[0-9]+]] = UDIVXr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[UDIVXr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_UDIV %0, %1
@@ -810,28 +815,28 @@ body:             |
 
 ---
 # Check that we select a s32 FPR G_FADD into FADDSrr.
-# CHECK-LABEL: name: fadd_s32_fpr
 name:            fadd_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = COPY %s1
-# CHECK:    %2 = FADDSrr %0, %1
 body:             |
   bb.0:
     liveins: %s0, %s1
 
+    ; CHECK-LABEL: name: fadd_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK-NEXT: id: 2, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %s1
+    ; CHECK: [[FADDSrr:%[0-9]+]] = FADDSrr [[COPY]], [[COPY1]]
+    ; CHECK: %s0 = COPY [[FADDSrr]]
     %0(s32) = COPY %s0
     %1(s32) = COPY %s1
     %2(s32) = G_FADD %0, %1
@@ -839,28 +844,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: fadd_s64_fpr
 name:            fadd_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %d1
-# CHECK:    %2 = FADDDrr %0, %1
 body:             |
   bb.0:
     liveins: %d0, %d1
 
+    ; CHECK-LABEL: name: fadd_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK-NEXT: id: 2, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %d1
+    ; CHECK: [[FADDDrr:%[0-9]+]] = FADDDrr [[COPY]], [[COPY1]]
+    ; CHECK: %d0 = COPY [[FADDDrr]]
     %0(s64) = COPY %d0
     %1(s64) = COPY %d1
     %2(s64) = G_FADD %0, %1
@@ -868,28 +873,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: fsub_s32_fpr
 name:            fsub_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = COPY %s1
-# CHECK:    %2 = FSUBSrr %0, %1
 body:             |
   bb.0:
     liveins: %s0, %s1
 
+    ; CHECK-LABEL: name: fsub_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK-NEXT: id: 2, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %s1
+    ; CHECK: [[FSUBSrr:%[0-9]+]] = FSUBSrr [[COPY]], [[COPY1]]
+    ; CHECK: %s0 = COPY [[FSUBSrr]]
     %0(s32) = COPY %s0
     %1(s32) = COPY %s1
     %2(s32) = G_FSUB %0, %1
@@ -897,28 +902,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: fsub_s64_fpr
 name:            fsub_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %d1
-# CHECK:    %2 = FSUBDrr %0, %1
 body:             |
   bb.0:
     liveins: %d0, %d1
 
+    ; CHECK-LABEL: name: fsub_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK-NEXT: id: 2, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %d1
+    ; CHECK: [[FSUBDrr:%[0-9]+]] = FSUBDrr [[COPY]], [[COPY1]]
+    ; CHECK: %d0 = COPY [[FSUBDrr]]
     %0(s64) = COPY %d0
     %1(s64) = COPY %d1
     %2(s64) = G_FSUB %0, %1
@@ -926,28 +931,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: fmul_s32_fpr
 name:            fmul_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = COPY %s1
-# CHECK:    %2 = FMULSrr %0, %1
 body:             |
   bb.0:
     liveins: %s0, %s1
 
+    ; CHECK-LABEL: name: fmul_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK-NEXT: id: 2, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %s1
+    ; CHECK: [[FMULSrr:%[0-9]+]] = FMULSrr [[COPY]], [[COPY1]]
+    ; CHECK: %s0 = COPY [[FMULSrr]]
     %0(s32) = COPY %s0
     %1(s32) = COPY %s1
     %2(s32) = G_FMUL %0, %1
@@ -955,28 +960,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: fmul_s64_fpr
 name:            fmul_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %d1
-# CHECK:    %2 = FMULDrr %0, %1
 body:             |
   bb.0:
     liveins: %d0, %d1
 
+    ; CHECK-LABEL: name: fmul_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK-NEXT: id: 2, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %d1
+    ; CHECK: [[FMULDrr:%[0-9]+]] = FMULDrr [[COPY]], [[COPY1]]
+    ; CHECK: %d0 = COPY [[FMULDrr]]
     %0(s64) = COPY %d0
     %1(s64) = COPY %d1
     %2(s64) = G_FMUL %0, %1
@@ -984,28 +989,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: fdiv_s32_fpr
 name:            fdiv_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = COPY %s1
-# CHECK:    %2 = FDIVSrr %0, %1
 body:             |
   bb.0:
     liveins: %s0, %s1
 
+    ; CHECK-LABEL: name: fdiv_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK-NEXT: id: 2, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %s1
+    ; CHECK: [[FDIVSrr:%[0-9]+]] = FDIVSrr [[COPY]], [[COPY1]]
+    ; CHECK: %s0 = COPY [[FDIVSrr]]
     %0(s32) = COPY %s0
     %1(s32) = COPY %s1
     %2(s32) = G_FDIV %0, %1
@@ -1013,28 +1018,28 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: fdiv_s64_fpr
 name:            fdiv_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %d1
-# CHECK:    %2 = FDIVDrr %0, %1
 body:             |
   bb.0:
     liveins: %d0, %d1
 
+    ; CHECK-LABEL: name: fdiv_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK-NEXT: id: 2, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %d1
+    ; CHECK: [[FDIVDrr:%[0-9]+]] = FDIVDrr [[COPY]], [[COPY1]]
+    ; CHECK: %d0 = COPY [[FDIVDrr]]
     %0(s64) = COPY %d0
     %1(s64) = COPY %d1
     %2(s64) = G_FDIV %0, %1
index fe077a25f7cbe1597bc07c30fdc6dca7b0f58d17..c19d0d4b18758477880bc3dd42b02e8969a38254 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -O0 -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s32_gpr
 name:            bitcast_s32_gpr
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32all, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: bitcast_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32all
+    ; CHECK-NEXT: id: 1, class: gpr32all
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(s32) = COPY %w0
     %1(s32) = G_BITCAST %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s32_fpr
 name:            bitcast_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %s0
 
+    ; CHECK-LABEL: name: bitcast_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %s0 = COPY [[COPY1]]
     %0(s32) = COPY %s0
     %1(s32) = G_BITCAST %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s32_gpr_fpr
 name:            bitcast_s32_gpr_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: bitcast_s32_gpr_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32all
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %s0 = COPY [[COPY1]]
     %0(s32) = COPY %w0
     %1(s32) = G_BITCAST %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s32_fpr_gpr
 name:            bitcast_s32_fpr_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %s0
 
+    ; CHECK-LABEL: name: bitcast_s32_fpr_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(s32) = COPY %s0
     %1(s32) = G_BITCAST %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s64_gpr
 name:            bitcast_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64all, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: bitcast_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64all
+    ; CHECK-NEXT: id: 1, class: gpr64all
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %x0 = COPY [[COPY1]]
     %0(s64) = COPY %x0
     %1(s64) = G_BITCAST %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s64_fpr
 name:            bitcast_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: bitcast_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %d0 = COPY [[COPY1]]
     %0(s64) = COPY %d0
     %1(s64) = G_BITCAST %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s64_gpr_fpr
 name:            bitcast_s64_gpr_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: bitcast_s64_gpr_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64all
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %d0 = COPY [[COPY1]]
     %0(s64) = COPY %x0
     %1(s64) = G_BITCAST %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s64_fpr_gpr
 name:            bitcast_s64_fpr_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: bitcast_s64_fpr_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %x0 = COPY [[COPY1]]
     %0(s64) = COPY %d0
     %1(s64) = G_BITCAST %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s64_v2f32_fpr
 name:            bitcast_s64_v2f32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: bitcast_s64_v2f32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %x0 = COPY [[COPY1]]
     %0(s64) = COPY %d0
     %1(<2 x s32>) = G_BITCAST %0
     %x0 = COPY %1(<2 x s32>)
 ...
 
 ---
-# CHECK-LABEL: name: bitcast_s64_v8i8_fpr
 name:            bitcast_s64_v8i8_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: bitcast_s64_v8i8_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %x0 = COPY [[COPY1]]
     %0(s64) = COPY %d0
     %1(<8 x s8>) = G_BITCAST %0
     %x0 = COPY %1(<8 x s8>)
index 56a964f106c41945c9fb1a1bf3e8f95607962666..d1118b64c52a8dfa03b919d09d22e93c2dc97a4b 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
@@ -8,52 +9,50 @@
 ...
 
 ---
-# CHECK-LABEL: name: bswap_s32
 name:            bswap_s32
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = REVWr %0
-# CHECK:    %w0 = COPY %1
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: bswap_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[REVWr:%[0-9]+]] = REVWr [[COPY]]
+    ; CHECK: %w0 = COPY [[REVWr]]
     %0(s32) = COPY %w0
     %1(s32) = G_BSWAP %0
     %w0 = COPY %1
 ...
 
 ---
-# CHECK-LABEL: name: bswap_s64
 name:            bswap_s64
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = REVXr %0
-# CHECK:    %x0 = COPY %1
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: bswap_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[REVXr:%[0-9]+]] = REVXr [[COPY]]
+    ; CHECK: %x0 = COPY [[REVXr]]
     %0(s64) = COPY %x0
     %1(s64) = G_BSWAP %0
     %x0 = COPY %1
index 3b2f3746b58771e45f59a641f58ca4427a70a161..1d38f4f759c11b7dde253b4a28db5b276b839a30 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -O0 -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
@@ -7,31 +8,31 @@
 ...
 
 ---
-# CHECK-LABEL: name: FMADDSrrr_fpr
 name:            FMADDSrrr_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
   - { id: 2, class: fpr }
   - { id: 3, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = COPY %w2
-# CHECK:    %3 = FMADDSrrr %0, %1, %2
 body:             |
   bb.0:
     liveins: %w0, %w1, %w2
 
+    ; CHECK-LABEL: name: FMADDSrrr_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK-NEXT: id: 2, class: fpr32
+    ; CHECK-NEXT: id: 3, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[COPY2:%[0-9]+]] = COPY %w2
+    ; CHECK: [[FMADDSrrr:%[0-9]+]] = FMADDSrrr [[COPY]], [[COPY1]], [[COPY2]]
+    ; CHECK: %x0 = COPY [[FMADDSrrr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = COPY %w2
index 3c343193557788d1a5666a5fa67ab4a206e97758..f3c81e7d9c1b163aae778b6200e6391c949912c5 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ...
 
 ---
-# CHECK-LABEL: name: fptrunc_s16_s32_fpr
 name:            fptrunc_s16_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK: - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK: - { id: 1, class: fpr16, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = FCVTHSr %0
 body:             |
   bb.0:
     liveins: %s0
 
+    ; CHECK-LABEL: name: fptrunc_s16_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr16
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[FCVTHSr:%[0-9]+]] = FCVTHSr [[COPY]]
+    ; CHECK: %h0 = COPY [[FCVTHSr]]
     %0(s32) = COPY %s0
     %1(s16) = G_FPTRUNC %0
     %h0 = COPY %1(s16)
 ...
 
 ---
-# CHECK-LABEL: name: fptrunc_s16_s64_fpr
 name:            fptrunc_s16_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK: - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK: - { id: 1, class: fpr16, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = FCVTHDr %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: fptrunc_s16_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr16
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[FCVTHDr:%[0-9]+]] = FCVTHDr [[COPY]]
+    ; CHECK: %h0 = COPY [[FCVTHDr]]
     %0(s64) = COPY %d0
     %1(s16) = G_FPTRUNC %0
     %h0 = COPY %1(s16)
 ...
 
 ---
-# CHECK-LABEL: name: fptrunc_s32_s64_fpr
 name:            fptrunc_s32_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK: - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK: - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = FCVTSDr %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: fptrunc_s32_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[FCVTSDr:%[0-9]+]] = FCVTSDr [[COPY]]
+    ; CHECK: %s0 = COPY [[FCVTSDr]]
     %0(s64) = COPY %d0
     %1(s32) = G_FPTRUNC %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: fpext_s32_s16_fpr
 name:            fpext_s32_s16_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK: - { id: 0, class: fpr16, preferred-register: '' }
-# CHECK: - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %h0
-# CHECK:    %1 = FCVTSHr %0
 body:             |
   bb.0:
     liveins: %h0
 
+    ; CHECK-LABEL: name: fpext_s32_s16_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr16
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %h0
+    ; CHECK: [[FCVTSHr:%[0-9]+]] = FCVTSHr [[COPY]]
+    ; CHECK: %s0 = COPY [[FCVTSHr]]
     %0(s16) = COPY %h0
     %1(s32) = G_FPEXT %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: fpext_s64_s16_fpr
 name:            fpext_s64_s16_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK: - { id: 0, class: fpr16, preferred-register: '' }
-# CHECK: - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %h0
-# CHECK:    %1 = FCVTDHr %0
 body:             |
   bb.0:
     liveins: %h0
 
+    ; CHECK-LABEL: name: fpext_s64_s16_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr16
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %h0
+    ; CHECK: [[FCVTDHr:%[0-9]+]] = FCVTDHr [[COPY]]
+    ; CHECK: %d0 = COPY [[FCVTDHr]]
     %0(s16) = COPY %h0
     %1(s64) = G_FPEXT %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: fpext_s64_s32_fpr
 name:            fpext_s64_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK: - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK: - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = FCVTDSr %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: fpext_s64_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[FCVTDSr:%[0-9]+]] = FCVTDSr [[COPY]]
+    ; CHECK: %d0 = COPY [[FCVTDSr]]
     %0(s32) = COPY %s0
     %1(s64) = G_FPEXT %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: sitofp_s32_s32_fpr
 name:            sitofp_s32_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = SCVTFUWSri %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: sitofp_s32_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SCVTFUWSri:%[0-9]+]] = SCVTFUWSri [[COPY]]
+    ; CHECK: %s0 = COPY [[SCVTFUWSri]]
     %0(s32) = COPY %w0
     %1(s32) = G_SITOFP %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: sitofp_s32_s64_fpr
 name:            sitofp_s32_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = SCVTFUXSri %0
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: sitofp_s32_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[SCVTFUXSri:%[0-9]+]] = SCVTFUXSri [[COPY]]
+    ; CHECK: %s0 = COPY [[SCVTFUXSri]]
     %0(s64) = COPY %x0
     %1(s32) = G_SITOFP %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: sitofp_s64_s32_fpr
 name:            sitofp_s64_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = SCVTFUWDri %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: sitofp_s64_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SCVTFUWDri:%[0-9]+]] = SCVTFUWDri [[COPY]]
+    ; CHECK: %d0 = COPY [[SCVTFUWDri]]
     %0(s32) = COPY %w0
     %1(s64) = G_SITOFP %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: sitofp_s64_s64_fpr
 name:            sitofp_s64_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = SCVTFUXDri %0
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: sitofp_s64_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[SCVTFUXDri:%[0-9]+]] = SCVTFUXDri [[COPY]]
+    ; CHECK: %d0 = COPY [[SCVTFUXDri]]
     %0(s64) = COPY %x0
     %1(s64) = G_SITOFP %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: uitofp_s32_s32_fpr
 name:            uitofp_s32_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = UCVTFUWSri %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: uitofp_s32_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[UCVTFUWSri:%[0-9]+]] = UCVTFUWSri [[COPY]]
+    ; CHECK: %s0 = COPY [[UCVTFUWSri]]
     %0(s32) = COPY %w0
     %1(s32) = G_UITOFP %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: uitofp_s32_s64_fpr
 name:            uitofp_s32_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = UCVTFUXSri %0
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: uitofp_s32_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[UCVTFUXSri:%[0-9]+]] = UCVTFUXSri [[COPY]]
+    ; CHECK: %s0 = COPY [[UCVTFUXSri]]
     %0(s64) = COPY %x0
     %1(s32) = G_UITOFP %0
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: uitofp_s64_s32_fpr
 name:            uitofp_s64_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = UCVTFUWDri %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: uitofp_s64_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[UCVTFUWDri:%[0-9]+]] = UCVTFUWDri [[COPY]]
+    ; CHECK: %d0 = COPY [[UCVTFUWDri]]
     %0(s32) = COPY %w0
     %1(s64) = G_UITOFP %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: uitofp_s64_s64_fpr
 name:            uitofp_s64_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = UCVTFUXDri %0
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: uitofp_s64_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[UCVTFUXDri:%[0-9]+]] = UCVTFUXDri [[COPY]]
+    ; CHECK: %d0 = COPY [[UCVTFUXDri]]
     %0(s64) = COPY %x0
     %1(s64) = G_UITOFP %0
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: fptosi_s32_s32_gpr
 name:            fptosi_s32_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = FCVTZSUWSr %0
 body:             |
   bb.0:
     liveins: %s0
 
+    ; CHECK-LABEL: name: fptosi_s32_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[FCVTZSUWSr:%[0-9]+]] = FCVTZSUWSr [[COPY]]
+    ; CHECK: %w0 = COPY [[FCVTZSUWSr]]
     %0(s32) = COPY %s0
     %1(s32) = G_FPTOSI %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: fptosi_s32_s64_gpr
 name:            fptosi_s32_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = FCVTZSUWDr %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: fptosi_s32_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[FCVTZSUWDr:%[0-9]+]] = FCVTZSUWDr [[COPY]]
+    ; CHECK: %w0 = COPY [[FCVTZSUWDr]]
     %0(s64) = COPY %d0
     %1(s32) = G_FPTOSI %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: fptosi_s64_s32_gpr
 name:            fptosi_s64_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = FCVTZSUXSr %0
 body:             |
   bb.0:
     liveins: %s0
 
+    ; CHECK-LABEL: name: fptosi_s64_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[FCVTZSUXSr:%[0-9]+]] = FCVTZSUXSr [[COPY]]
+    ; CHECK: %x0 = COPY [[FCVTZSUXSr]]
     %0(s32) = COPY %s0
     %1(s64) = G_FPTOSI %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: fptosi_s64_s64_gpr
 name:            fptosi_s64_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = FCVTZSUXDr %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: fptosi_s64_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[FCVTZSUXDr:%[0-9]+]] = FCVTZSUXDr [[COPY]]
+    ; CHECK: %x0 = COPY [[FCVTZSUXDr]]
     %0(s64) = COPY %d0
     %1(s64) = G_FPTOSI %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: fptoui_s32_s32_gpr
 name:            fptoui_s32_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = FCVTZUUWSr %0
 body:             |
   bb.0:
     liveins: %s0
 
+    ; CHECK-LABEL: name: fptoui_s32_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[FCVTZUUWSr:%[0-9]+]] = FCVTZUUWSr [[COPY]]
+    ; CHECK: %w0 = COPY [[FCVTZUUWSr]]
     %0(s32) = COPY %s0
     %1(s32) = G_FPTOUI %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: fptoui_s32_s64_gpr
 name:            fptoui_s32_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = FCVTZUUWDr %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: fptoui_s32_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[FCVTZUUWDr:%[0-9]+]] = FCVTZUUWDr [[COPY]]
+    ; CHECK: %w0 = COPY [[FCVTZUUWDr]]
     %0(s64) = COPY %d0
     %1(s32) = G_FPTOUI %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: fptoui_s64_s32_gpr
 name:            fptoui_s64_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %s0
-# CHECK:    %1 = FCVTZUUXSr %0
 body:             |
   bb.0:
     liveins: %s0
 
+    ; CHECK-LABEL: name: fptoui_s64_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr32
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %s0
+    ; CHECK: [[FCVTZUUXSr:%[0-9]+]] = FCVTZUUXSr [[COPY]]
+    ; CHECK: %x0 = COPY [[FCVTZUUXSr]]
     %0(s32) = COPY %s0
     %1(s64) = G_FPTOUI %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: fptoui_s64_s64_gpr
 name:            fptoui_s64_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %1 = FCVTZUUXDr %0
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: fptoui_s64_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[FCVTZUUXDr:%[0-9]+]] = FCVTZUUXDr [[COPY]]
+    ; CHECK: %x0 = COPY [[FCVTZUUXDr]]
     %0(s64) = COPY %d0
     %1(s64) = G_FPTOUI %0
     %x0 = COPY %1(s64)
index 1fc20ff98f7fa0179ff11400b499934126bbfaa4..a89adc2797113b41a4347068e35db05167b4af8d 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -O0 -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 
 ---
 # Check that we select a 32-bit immediate into a MOVi32imm.
-# CHECK-LABEL: name: imm_s32_gpr
 name:            imm_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = MOVi32imm -1234
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: imm_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK: [[MOVi32imm:%[0-9]+]] = MOVi32imm -1234
+    ; CHECK: %w0 = COPY [[MOVi32imm]]
     %0(s32) = G_CONSTANT i32 -1234
     %w0 = COPY %0(s32)
 ...
 
 ---
 # Check that we select a 64-bit immediate into a MOVi64imm.
-# CHECK-LABEL: name: imm_s64_gpr
 name:            imm_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = MOVi64imm 1234
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: imm_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK: [[MOVi64imm:%[0-9]+]] = MOVi64imm 1234
+    ; CHECK: %w0 = COPY [[MOVi64imm]]
     %0(s64) = G_CONSTANT i64 1234
     %w0 = COPY %0(s64)
 ...
index 8604b2769ba3086859f91c1826e3cf4ff0ac519d..e2744e99d1545fe513aadaa5076ccc1fc1efff2a 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -O0 -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
@@ -7,23 +8,22 @@
 ...
 
 ---
-# CHECK-LABEL: name: implicit_def
 name:            implicit_def
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    [[DEF:%[0-9]+]] = IMPLICIT_DEF
-# CHECK:    [[ADD:%[0-9]+]] = ADDWrr [[DEF]], [[DEF]]
-# CHECK:    %w0 = COPY [[ADD]]
 body:             |
   bb.0:
+    ; CHECK-LABEL: name: implicit_def
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; CHECK: [[ADDWrr:%[0-9]+]] = ADDWrr [[DEF]], [[DEF]]
+    ; CHECK: %w0 = COPY [[ADDWrr]]
     %0(s32) = G_IMPLICIT_DEF
     %1(s32) = G_ADD %0, %0
     %w0 = COPY %1(s32)
index 5f29f8b62fab154459e099a6d7882aee0a465a22..b7b7de4ae618f83fdd46ad60c90d9d0874e2d433 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ...
 
 ---
-# CHECK-LABEL: name: anyext_s64_from_s32
 name:            anyext_s64_from_s32
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64all, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %2 = SUBREG_TO_REG 0, %0, 15
-# CHECK:    %1 = COPY %2
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: anyext_s64_from_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32all
+    ; CHECK-NEXT: id: 1, class: gpr64all
+    ; CHECK-NEXT: id: 2, class: gpr64all
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY]], 15
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[SUBREG_TO_REG]]
+    ; CHECK: %x0 = COPY [[COPY1]]
     %0(s32) = COPY %w0
     %1(s64) = G_ANYEXT %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: anyext_s32_from_s8
 name:            anyext_s32_from_s8
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32all, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: anyext_s32_from_s8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32all
+    ; CHECK-NEXT: id: 1, class: gpr32all
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(s8) = COPY %w0
     %1(s32) = G_ANYEXT %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: zext_s64_from_s32
 name:            zext_s64_from_s32
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %2 = SUBREG_TO_REG 0, %0, 15
-# CHECK:    %1 = UBFMXri %2, 0, 31
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: zext_s64_from_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY]], 15
+    ; CHECK: [[UBFMXri:%[0-9]+]] = UBFMXri [[SUBREG_TO_REG]], 0, 31
+    ; CHECK: %x0 = COPY [[UBFMXri]]
     %0(s32) = COPY %w0
     %1(s64) = G_ZEXT %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: zext_s32_from_s16
 name:            zext_s32_from_s16
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = UBFMWri %0, 0, 15
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: zext_s32_from_s16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[UBFMWri:%[0-9]+]] = UBFMWri [[COPY]], 0, 15
+    ; CHECK: %w0 = COPY [[UBFMWri]]
     %0(s16) = COPY %w0
     %1(s32) = G_ZEXT %0
     %w0 = COPY %1
 ...
 
 ---
-# CHECK-LABEL: name: zext_s32_from_s8
 name:            zext_s32_from_s8
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = UBFMWri %0, 0, 7
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: zext_s32_from_s8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[UBFMWri:%[0-9]+]] = UBFMWri [[COPY]], 0, 7
+    ; CHECK: %w0 = COPY [[UBFMWri]]
     %0(s8) = COPY %w0
     %1(s32) = G_ZEXT %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: zext_s16_from_s8
 name:            zext_s16_from_s8
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = UBFMWri %0, 0, 7
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: zext_s16_from_s8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[UBFMWri:%[0-9]+]] = UBFMWri [[COPY]], 0, 7
+    ; CHECK: %w0 = COPY [[UBFMWri]]
     %0(s8) = COPY %w0
     %1(s16) = G_ZEXT %0
     %w0 = COPY %1(s16)
 ...
 
 ---
-# CHECK-LABEL: name: sext_s64_from_s32
 name:            sext_s64_from_s32
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %2 = SUBREG_TO_REG 0, %0, 15
-# CHECK:    %1 = SBFMXri %2, 0, 31
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: sext_s64_from_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY]], 15
+    ; CHECK: [[SBFMXri:%[0-9]+]] = SBFMXri [[SUBREG_TO_REG]], 0, 31
+    ; CHECK: %x0 = COPY [[SBFMXri]]
     %0(s32) = COPY %w0
     %1(s64) = G_SEXT %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: sext_s32_from_s16
 name:            sext_s32_from_s16
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = SBFMWri %0, 0, 15
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: sext_s32_from_s16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SBFMWri:%[0-9]+]] = SBFMWri [[COPY]], 0, 15
+    ; CHECK: %w0 = COPY [[SBFMWri]]
     %0(s16) = COPY %w0
     %1(s32) = G_SEXT %0
     %w0 = COPY %1
 ...
 
 ---
-# CHECK-LABEL: name: sext_s32_from_s8
 name:            sext_s32_from_s8
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = SBFMWri %0, 0, 7
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: sext_s32_from_s8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SBFMWri:%[0-9]+]] = SBFMWri [[COPY]], 0, 7
+    ; CHECK: %w0 = COPY [[SBFMWri]]
     %0(s8) = COPY %w0
     %1(s32) = G_SEXT %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: sext_s16_from_s8
 name:            sext_s16_from_s8
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = SBFMWri %0, 0, 7
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: sext_s16_from_s8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[SBFMWri:%[0-9]+]] = SBFMWri [[COPY]], 0, 7
+    ; CHECK: %w0 = COPY [[SBFMWri]]
     %0(s8) = COPY %w0
     %1(s16) = G_SEXT %0
     %w0 = COPY %1(s16)
index b71a9a3d731ebc54ede5a1ef4e2c577496b56707..585664649d87f94f7d76f86d899e1602eedbd39f 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ...
 
 ---
-# CHECK-LABEL: name: inttoptr_p0_s64
 name:            inttoptr_p0_s64
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64all, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64all, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %x0
+    ; CHECK-LABEL: name: inttoptr_p0_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64all
+    ; CHECK-NEXT: id: 1, class: gpr64all
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %x0 = COPY [[COPY1]]
     %0(s64) = COPY %x0
     %1(p0) = G_INTTOPTR %0
     %x0 = COPY %1(p0)
 ...
 
 ---
-# CHECK-LABEL: name: ptrtoint_s64_p0
 name:            ptrtoint_s64_p0
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %x0
+    ; CHECK-LABEL: name: ptrtoint_s64_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %x0 = COPY [[COPY1]]
     %0(p0) = COPY %x0
     %1(s64) = G_PTRTOINT %0
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: ptrtoint_s32_p0
 name:            ptrtoint_s32_p0
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0.sub_32
 body:             |
   bb.0:
     liveins: %x0
+    ; CHECK-LABEL: name: ptrtoint_s32_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(p0) = COPY %x0
     %1(s32) = G_PTRTOINT %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: ptrtoint_s16_p0
 name:            ptrtoint_s16_p0
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0.sub_32
 body:             |
   bb.0:
     liveins: %x0
+    ; CHECK-LABEL: name: ptrtoint_s16_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(p0) = COPY %x0
     %1(s16) = G_PTRTOINT %0
     %w0 = COPY %1(s16)
 ...
 
 ---
-# CHECK-LABEL: name: ptrtoint_s8_p0
 name:            ptrtoint_s8_p0
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0.sub_32
 body:             |
   bb.0:
     liveins: %x0
+    ; CHECK-LABEL: name: ptrtoint_s8_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(p0) = COPY %x0
     %1(s8) = G_PTRTOINT %0
     %w0 = COPY %1(s8)
 ...
 
 ---
-# CHECK-LABEL: name: ptrtoint_s1_p0
 name:            ptrtoint_s1_p0
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %0.sub_32
 body:             |
   bb.0:
     liveins: %x0
+    ; CHECK-LABEL: name: ptrtoint_s1_p0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(p0) = COPY %x0
     %1(s1) = G_PTRTOINT %0
     %w0 = COPY %1(s1)
index 43e682c6b6ca5b70732c7d3d219be41b32ae681e..7f0fc2cad6f73e1b3ea2280e2f520546744a24d6 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ---
 # Check that we select a 32-bit GPR sdiv intrinsic into SDIVWrr for GPR32.
 # Also check that we constrain the register class of the COPY to GPR32.
-# CHECK-LABEL: name: sdiv_s32_gpr
 name:            sdiv_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = SDIVWr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: sdiv_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[SDIVWr:%[0-9]+]] = SDIVWr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[SDIVWr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_INTRINSIC intrinsic(@llvm.aarch64.sdiv.i32), %0, %1
index 2955788a71e77a09bd1672259ce266516a62cbed..801ba35bd4cd41ec8107c85f84dc7cdb031e14b7 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ...
 
 ---
-# CHECK-LABEL: name: load_s64_gpr
 name:            load_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRXui %0, 0 :: (load 8 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRXui:%[0-9]+]] = LDRXui [[COPY]], 0 :: (load 8 from %ir.addr)
+    ; CHECK: %x0 = COPY [[LDRXui]]
     %0(p0) = COPY %x0
     %1(s64) = G_LOAD  %0 :: (load 8 from %ir.addr)
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: load_s32_gpr
 name:            load_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRWui %0, 0 :: (load 4 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRWui:%[0-9]+]] = LDRWui [[COPY]], 0 :: (load 4 from %ir.addr)
+    ; CHECK: %w0 = COPY [[LDRWui]]
     %0(p0) = COPY %x0
     %1(s32) = G_LOAD  %0 :: (load 4 from %ir.addr)
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: load_s16_gpr
 name:            load_s16_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRHHui %0, 0 :: (load 2 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s16_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRHHui:%[0-9]+]] = LDRHHui [[COPY]], 0 :: (load 2 from %ir.addr)
+    ; CHECK: %w0 = COPY [[LDRHHui]]
     %0(p0) = COPY %x0
     %1(s16) = G_LOAD  %0 :: (load 2 from %ir.addr)
     %w0 = COPY %1(s16)
 ...
 
 ---
-# CHECK-LABEL: name: load_s8_gpr
 name:            load_s8_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRBBui %0, 0 :: (load 1 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s8_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRBBui:%[0-9]+]] = LDRBBui [[COPY]], 0 :: (load 1 from %ir.addr)
+    ; CHECK: %w0 = COPY [[LDRBBui]]
     %0(p0) = COPY %x0
     %1(s8) = G_LOAD  %0 :: (load 1 from %ir.addr)
     %w0 = COPY %1(s8)
 ...
 
 ---
-# CHECK-LABEL: name: load_fi_s64_gpr
 name:            load_fi_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -147,43 +144,45 @@ registers:
 stack:
   - { id: 0, name: ptr0, offset: 0, size: 8, alignment: 8 }
 
-# CHECK:  body:
-# CHECK: %1 = LDRXui %stack.0.ptr0, 0 :: (load 8)
-# CHECK: %x0 = COPY %1
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_fi_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[LDRXui:%[0-9]+]] = LDRXui %stack.0.ptr0, 0 :: (load 8)
+    ; CHECK: %x0 = COPY [[LDRXui]]
     %0(p0) = G_FRAME_INDEX %stack.0.ptr0
     %1(s64) = G_LOAD %0 :: (load 8)
     %x0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_128_s64_gpr
 name:            load_gep_128_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRXui %0, 16 :: (load 8 from %ir.addr)
-# CHECK: %x0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_128_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRXui:%[0-9]+]] = LDRXui [[COPY]], 16 :: (load 8 from %ir.addr)
+    ; CHECK: %x0 = COPY [[LDRXui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 128
     %2(p0) = G_GEP %0, %1
@@ -192,30 +191,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_512_s32_gpr
 name:            load_gep_512_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRWui %0, 128 :: (load 4 from %ir.addr)
-# CHECK: %w0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_512_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRWui:%[0-9]+]] = LDRWui [[COPY]], 128 :: (load 4 from %ir.addr)
+    ; CHECK: %w0 = COPY [[LDRWui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 512
     %2(p0) = G_GEP %0, %1
@@ -224,30 +222,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_64_s16_gpr
 name:            load_gep_64_s16_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRHHui %0, 32 :: (load 2 from %ir.addr)
-# CHECK: %w0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_64_s16_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRHHui:%[0-9]+]] = LDRHHui [[COPY]], 32 :: (load 2 from %ir.addr)
+    ; CHECK: %w0 = COPY [[LDRHHui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 64
     %2(p0) = G_GEP %0, %1
@@ -256,30 +253,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_1_s8_gpr
 name:            load_gep_1_s8_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRBBui %0, 1 :: (load 1 from %ir.addr)
-# CHECK: %w0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_1_s8_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRBBui:%[0-9]+]] = LDRBBui [[COPY]], 1 :: (load 1 from %ir.addr)
+    ; CHECK: %w0 = COPY [[LDRBBui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 1
     %2(p0) = G_GEP %0, %1
@@ -288,130 +284,129 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: load_s64_fpr
 name:            load_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRDui %0, 0 :: (load 8 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRDui:%[0-9]+]] = LDRDui [[COPY]], 0 :: (load 8 from %ir.addr)
+    ; CHECK: %d0 = COPY [[LDRDui]]
     %0(p0) = COPY %x0
     %1(s64) = G_LOAD  %0 :: (load 8 from %ir.addr)
     %d0 = COPY %1(s64)
 ...
 
 ---
-# CHECK-LABEL: name: load_s32_fpr
 name:            load_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRSui %0, 0 :: (load 4 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRSui:%[0-9]+]] = LDRSui [[COPY]], 0 :: (load 4 from %ir.addr)
+    ; CHECK: %s0 = COPY [[LDRSui]]
     %0(p0) = COPY %x0
     %1(s32) = G_LOAD  %0 :: (load 4 from %ir.addr)
     %s0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: load_s16_fpr
 name:            load_s16_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRHui %0, 0 :: (load 2 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s16_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr16
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRHui:%[0-9]+]] = LDRHui [[COPY]], 0 :: (load 2 from %ir.addr)
+    ; CHECK: %h0 = COPY [[LDRHui]]
     %0(p0) = COPY %x0
     %1(s16) = G_LOAD  %0 :: (load 2 from %ir.addr)
     %h0 = COPY %1(s16)
 ...
 
 ---
-# CHECK-LABEL: name: load_s8_fpr
 name:            load_s8_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = LDRBui %0, 0 :: (load 1 from %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_s8_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr8
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRBui:%[0-9]+]] = LDRBui [[COPY]], 0 :: (load 1 from %ir.addr)
+    ; CHECK: %b0 = COPY [[LDRBui]]
     %0(p0) = COPY %x0
     %1(s8) = G_LOAD  %0 :: (load 1 from %ir.addr)
     %b0 = COPY %1(s8)
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_8_s64_fpr
 name:            load_gep_8_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRDui %0, 1 :: (load 8 from %ir.addr)
-# CHECK: %d0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_8_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRDui:%[0-9]+]] = LDRDui [[COPY]], 1 :: (load 8 from %ir.addr)
+    ; CHECK: %d0 = COPY [[LDRDui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 8
     %2(p0) = G_GEP %0, %1
@@ -420,30 +415,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_16_s32_fpr
 name:            load_gep_16_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRSui %0, 4 :: (load 4 from %ir.addr)
-# CHECK: %s0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_16_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRSui:%[0-9]+]] = LDRSui [[COPY]], 4 :: (load 4 from %ir.addr)
+    ; CHECK: %s0 = COPY [[LDRSui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 16
     %2(p0) = G_GEP %0, %1
@@ -452,30 +446,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_64_s16_fpr
 name:            load_gep_64_s16_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: fpr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRHui %0, 32 :: (load 2 from %ir.addr)
-# CHECK: %h0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_64_s16_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: fpr16
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRHui:%[0-9]+]] = LDRHui [[COPY]], 32 :: (load 2 from %ir.addr)
+    ; CHECK: %h0 = COPY [[LDRHui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 64
     %2(p0) = G_GEP %0, %1
@@ -484,30 +477,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: load_gep_32_s8_fpr
 name:            load_gep_32_s8_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: fpr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %3 = LDRBui %0, 32 :: (load 1 from %ir.addr)
-# CHECK: %b0 = COPY %3
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_gep_32_s8_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: fpr8
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRBui:%[0-9]+]] = LDRBui [[COPY]], 32 :: (load 1 from %ir.addr)
+    ; CHECK: %b0 = COPY [[LDRBui]]
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 32
     %2(p0) = G_GEP %0, %1
@@ -515,26 +507,25 @@ body:             |
     %b0 = COPY %3
 ...
 ---
-# CHECK-LABEL: name: load_v2s32
 name:            load_v2s32
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = LDRDui %0, 0 :: (load 8 from %ir.addr)
-# CHECK:    %d0 = COPY %1
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: load_v2s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[LDRDui:%[0-9]+]] = LDRDui [[COPY]], 0 :: (load 8 from %ir.addr)
+    ; CHECK: %d0 = COPY [[LDRDui]]
     %0(p0) = COPY %x0
     %1(<2 x s32>) = G_LOAD %0 :: (load 8 from %ir.addr)
     %d0 = COPY %1(<2 x s32>)
index cd7a79f17d952198bfb57c20ae082ecd2ab61ab0..119812575c56b68aefffaf31f5a1455d90ed18b0 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -O0 -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
@@ -7,19 +8,10 @@
 ...
 
 ---
-# CHECK-LABEL: name: SMADDLrrr_gpr
 name:            SMADDLrrr_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 4, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 5, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 6, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -29,15 +21,24 @@ registers:
   - { id: 5, class: gpr }
   - { id: 6, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = COPY %w2
-# CHECK:    %6 = SMADDLrrr %1, %2, %0
 body:             |
   bb.0:
     liveins: %x0, %w1, %w2
 
+    ; CHECK-LABEL: name: SMADDLrrr_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK-NEXT: id: 3, class: gpr
+    ; CHECK-NEXT: id: 4, class: gpr
+    ; CHECK-NEXT: id: 5, class: gpr
+    ; CHECK-NEXT: id: 6, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[COPY2:%[0-9]+]] = COPY %w2
+    ; CHECK: [[SMADDLrrr:%[0-9]+]] = SMADDLrrr [[COPY1]], [[COPY2]], [[COPY]]
+    ; CHECK: %x0 = COPY [[SMADDLrrr]]
     %0(s64) = COPY %x0
     %1(s32) = COPY %w1
     %2(s32) = COPY %w2
index a7a33acab25970557e496bb569f39a54b7bd2fce..4c3b069e88adc9c912e0514d9874d39d818750a9 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -mattr=+neon,+fullfp16 -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
@@ -8,28 +9,27 @@
 
 ---
 # Check that we select a 64-bit FPR vcvtfxu2fp intrinsic into UCVTFd for FPR64.
-# CHECK-LABEL: name: vcvtfxu2fp_s64_fpr
 name:            vcvtfxu2fp_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: fpr }
   - { id: 1, class: gpr }
   - { id: 2, class: fpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %d0
-# CHECK:    %2 = UCVTFd %0, 12
-# CHECK:    %d1 = COPY %2
 body:             |
   bb.0:
     liveins: %d0
 
+    ; CHECK-LABEL: name: vcvtfxu2fp_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: fpr64
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %d0
+    ; CHECK: [[UCVTFd:%[0-9]+]] = UCVTFd [[COPY]], 12
+    ; CHECK: %d1 = COPY [[UCVTFd]]
     %0(s64) = COPY %d0
     %1(s32) = G_CONSTANT i32 12
     %2(s64) = G_INTRINSIC intrinsic(@llvm.aarch64.neon.vcvtfxu2fp.f64), %0, %1
index 536e236c27387a3590b8c679056f2bfb7dc5cd4c..38eeb7f8060dc99d73639e2af51e7ed0a253e275 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ...
 
 ---
-# CHECK-LABEL: name: store_s64_gpr
 name:            store_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %x1
-# CHECK: STRXui %1, %0, 0 :: (store 8 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: store_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: STRXui [[COPY1]], [[COPY]], 0 :: (store 8 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s64) = COPY %x1
     G_STORE  %1, %0 :: (store 8 into %ir.addr)
@@ -56,26 +56,25 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_s32_gpr
 name:            store_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %w1
-# CHECK: STRWui %1, %0, 0 :: (store 4 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %w1
 
+    ; CHECK-LABEL: name: store_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: STRWui [[COPY1]], [[COPY]], 0 :: (store 4 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s32) = COPY %w1
     G_STORE  %1, %0 :: (store 4 into %ir.addr)
@@ -83,26 +82,25 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_s16_gpr
 name:            store_s16_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %w1
-# CHECK: STRHHui %1, %0, 0 :: (store 2 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %w1
 
+    ; CHECK-LABEL: name: store_s16_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: STRHHui [[COPY1]], [[COPY]], 0 :: (store 2 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s16) = COPY %w1
     G_STORE  %1, %0 :: (store 2 into %ir.addr)
@@ -110,26 +108,25 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_s8_gpr
 name:            store_s8_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %w1
-# CHECK: STRBBui %1, %0, 0 :: (store 1 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %w1
 
+    ; CHECK-LABEL: name: store_s8_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: STRBBui [[COPY1]], [[COPY]], 0 :: (store 1 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s8) = COPY %w1
     G_STORE  %1, %0 :: (store 1 into %ir.addr)
@@ -137,25 +134,24 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_zero_s64_gpr
 name:            store_zero_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: STRXui %xzr, %0, 0 :: (store 8 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: store_zero_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: STRXui %xzr, [[COPY]], 0 :: (store 8 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s64) = G_CONSTANT i64 0
     G_STORE  %1, %0 :: (store 8 into %ir.addr)
@@ -163,25 +159,24 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_zero_s32_gpr
 name:            store_zero_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: STRWui %wzr, %0, 0 :: (store 4 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: store_zero_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: STRWui %wzr, [[COPY]], 0 :: (store 4 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s32) = G_CONSTANT i32 0
     G_STORE  %1, %0 :: (store 4 into %ir.addr)
@@ -189,14 +184,10 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_fi_s64_gpr
 name:            store_fi_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -204,43 +195,45 @@ registers:
 stack:
   - { id: 0, name: ptr0, offset: 0, size: 8, alignment: 8 }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: STRXui %0, %stack.0.ptr0, 0 :: (store 8)
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: store_fi_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: STRXui [[COPY]], %stack.0.ptr0, 0 :: (store 8)
     %0(p0) = COPY %x0
     %1(p0) = G_FRAME_INDEX %stack.0.ptr0
     G_STORE  %0, %1 :: (store 8)
 ...
 
 ---
-# CHECK-LABEL: name: store_gep_128_s64_gpr
 name:            store_gep_128_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %x1
-# CHECK: STRXui %1, %0, 16 :: (store 8 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: store_gep_128_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: STRXui [[COPY1]], [[COPY]], 16 :: (store 8 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_CONSTANT i64 128
@@ -249,30 +242,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_gep_512_s32_gpr
 name:            store_gep_512_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %w1
-# CHECK: STRWui %1, %0, 128 :: (store 4 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %w1
 
+    ; CHECK-LABEL: name: store_gep_512_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: STRWui [[COPY1]], [[COPY]], 128 :: (store 4 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s32) = COPY %w1
     %2(s64) = G_CONSTANT i64 512
@@ -281,30 +273,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_gep_64_s16_gpr
 name:            store_gep_64_s16_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %w1
-# CHECK: STRHHui %1, %0, 32 :: (store 2 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %w1
 
+    ; CHECK-LABEL: name: store_gep_64_s16_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: STRHHui [[COPY1]], [[COPY]], 32 :: (store 2 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s16) = COPY %w1
     %2(s64) = G_CONSTANT i64 64
@@ -313,30 +304,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_gep_1_s8_gpr
 name:            store_gep_1_s8_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %w1
-# CHECK: STRBBui %1, %0, 1 :: (store 1 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %w1
 
+    ; CHECK-LABEL: name: store_gep_1_s8_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: STRBBui [[COPY1]], [[COPY]], 1 :: (store 1 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s8) = COPY %w1
     %2(s64) = G_CONSTANT i64 1
@@ -345,26 +335,25 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_s64_fpr
 name:            store_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %d1
-# CHECK: STRDui %1, %0, 0 :: (store 8 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %d1
 
+    ; CHECK-LABEL: name: store_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %d1
+    ; CHECK: STRDui [[COPY1]], [[COPY]], 0 :: (store 8 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s64) = COPY %d1
     G_STORE  %1, %0 :: (store 8 into %ir.addr)
@@ -372,26 +361,25 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_s32_fpr
 name:            store_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %s1
-# CHECK: STRSui %1, %0, 0 :: (store 4 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %s1
 
+    ; CHECK-LABEL: name: store_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %s1
+    ; CHECK: STRSui [[COPY1]], [[COPY]], 0 :: (store 4 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s32) = COPY %s1
     G_STORE  %1, %0 :: (store 4 into %ir.addr)
@@ -399,30 +387,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_gep_8_s64_fpr
 name:            store_gep_8_s64_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %d1
-# CHECK: STRDui %1, %0, 1 :: (store 8 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %d1
 
+    ; CHECK-LABEL: name: store_gep_8_s64_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr64
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %d1
+    ; CHECK: STRDui [[COPY1]], [[COPY]], 1 :: (store 8 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s64) = COPY %d1
     %2(s64) = G_CONSTANT i64 8
@@ -431,30 +418,29 @@ body:             |
 ...
 
 ---
-# CHECK-LABEL: name: store_gep_8_s32_fpr
 name:            store_gep_8_s32_fpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: fpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: fpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 
-# CHECK:  body:
-# CHECK: %0 = COPY %x0
-# CHECK: %1 = COPY %s1
-# CHECK: STRSui %1, %0, 2 :: (store 4 into %ir.addr)
 body:             |
   bb.0:
     liveins: %x0, %s1
 
+    ; CHECK-LABEL: name: store_gep_8_s32_fpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: fpr32
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gpr
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %s1
+    ; CHECK: STRSui [[COPY1]], [[COPY]], 2 :: (store 4 into %ir.addr)
     %0(p0) = COPY %x0
     %1(s32) = COPY %s1
     %2(s64) = G_CONSTANT i64 8
index f43a9ab34ffd2b652849692a76a02fd7ca770e12..1d6664402e8eff642dbcc845fc2023e468faf5cd 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ...
 
 ---
-# CHECK-LABEL: name: trunc_s32_s64
 name:            trunc_s32_s64
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64sp, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32sp, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %1 = COPY %0.sub_32
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: trunc_s32_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64sp
+    ; CHECK-NEXT: id: 1, class: gpr32sp
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(s64) = COPY %x0
     %1(s32) = G_TRUNC %0
     %w0 = COPY %1(s32)
 ...
 
 ---
-# CHECK-LABEL: name: trunc_s8_s64
 name:            trunc_s8_s64
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %1 = COPY %0.sub_32
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: trunc_s8_s64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(s64) = COPY %x0
     %1(s8) = G_TRUNC %0
     %w0 = COPY %1(s8)
 ...
 
 ---
-# CHECK-LABEL: name: trunc_s1_s32
 name:            trunc_s1_s32
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %1 = COPY %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: trunc_s1_s32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; CHECK: %w0 = COPY [[COPY1]]
     %0(s32) = COPY %w0
     %1(s1) = G_TRUNC %0
     %w0 = COPY %1(s1)
index 7190fda15b8eed5f9d9f522c061c24577a6d45f2..ec6b1e4c8c93357f11ab52ca99e109fe4187d76c 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -O0 -mtriple=aarch64-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
 ---
 # Check that we select a 32-bit GPR G_XOR into EORWrr on GPR32.
 # Also check that we constrain the register class of the COPY to GPR32.
-# CHECK-LABEL: name: xor_s32_gpr
 name:            xor_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %1 = COPY %w1
-# CHECK:    %2 = EORWrr %0, %1
 body:             |
   bb.0:
     liveins: %w0, %w1
 
+    ; CHECK-LABEL: name: xor_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr32
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %w1
+    ; CHECK: [[EORWrr:%[0-9]+]] = EORWrr [[COPY]], [[COPY1]]
+    ; CHECK: %w0 = COPY [[EORWrr]]
     %0(s32) = COPY %w0
     %1(s32) = COPY %w1
     %2(s32) = G_XOR %0, %1
@@ -44,28 +45,28 @@ body:             |
 
 ---
 # Same as xor_s64_gpr, for 64-bit operations.
-# CHECK-LABEL: name: xor_s64_gpr
 name:            xor_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %1 = COPY %x1
-# CHECK:    %2 = EORXrr %0, %1
 body:             |
   bb.0:
     liveins: %x0, %x1
 
+    ; CHECK-LABEL: name: xor_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr64
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %x1
+    ; CHECK: [[EORXrr:%[0-9]+]] = EORXrr [[COPY]], [[COPY1]]
+    ; CHECK: %x0 = COPY [[EORXrr]]
     %0(s64) = COPY %x0
     %1(s64) = COPY %x1
     %2(s64) = G_XOR %0, %1
@@ -75,27 +76,27 @@ body:             |
 ---
 # Check that we select a 32-bit GPR G_XOR into EORWrr on GPR32.
 # Also check that we constrain the register class of the COPY to GPR32.
-# CHECK-LABEL: name: xor_constant_n1_s32_gpr
 name:            xor_constant_n1_s32_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %w0
-# CHECK:    %2 = ORNWrr %wzr, %0
 body:             |
   bb.0:
     liveins: %w0
 
+    ; CHECK-LABEL: name: xor_constant_n1_s32_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr32
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %w0
+    ; CHECK: [[ORNWrr:%[0-9]+]] = ORNWrr %wzr, [[COPY]]
+    ; CHECK: %w0 = COPY [[ORNWrr]]
     %0(s32) = COPY %w0
     %1(s32) = G_CONSTANT i32 -1
     %2(s32) = G_XOR %0, %1
@@ -104,27 +105,27 @@ body:             |
 
 ---
 # Same as xor_constant_n1_s64_gpr, for 64-bit operations.
-# CHECK-LABEL: name: xor_constant_n1_s64_gpr
 name:            xor_constant_n1_s64_gpr
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr64, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = COPY %x0
-# CHECK:    %2 = ORNXrr %xzr, %0
 body:             |
   bb.0:
     liveins: %x0
 
+    ; CHECK-LABEL: name: xor_constant_n1_s64_gpr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gpr64
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %x0
+    ; CHECK: [[ORNXrr:%[0-9]+]] = ORNXrr %xzr, [[COPY]]
+    ; CHECK: %x0 = COPY [[ORNXrr]]
     %0(s64) = COPY %x0
     %1(s64) = G_CONSTANT i64 -1
     %2(s64) = G_XOR %0, %1
@@ -133,26 +134,29 @@ body:             |
 
 ---
 # Check that we can obtain constants from other basic blocks.
-# CHECK-LABEL: name: xor_constant_n1_s32_gpr_2bb
 name:            xor_constant_n1_s32_gpr_2bb
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gpr32, preferred-register: '' }
-# CHECK-NEXT:  - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:  - { id: 2, class: gpr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 
-# CHECK:  body:
-# CHECK:    B %bb.1
-# CHECK:    %0 = COPY %w0
-# CHECK:    %2 = ORNWrr %wzr, %0
 
 body:             |
+  ; CHECK-LABEL: name: xor_constant_n1_s32_gpr_2bb
+  ; CHECK: registers:
+  ; CHECK-NEXT: id: 0, class: gpr32
+  ; CHECK-NEXT: id: 1, class: gpr
+  ; CHECK-NEXT: id: 2, class: gpr32
+  ; CHECK: bb.0:
+  ; CHECK:   successors: %bb.1(0x80000000)
+  ; CHECK:   B %bb.1
+  ; CHECK: bb.1:
+  ; CHECK:   [[COPY:%[0-9]+]] = COPY %w0
+  ; CHECK:   [[ORNWrr:%[0-9]+]] = ORNWrr %wzr, [[COPY]]
+  ; CHECK:   %w0 = COPY [[ORNWrr]]
   bb.0:
     liveins: %w0, %w1
     successors: %bb.1
index 6a0cd32eefd55d70ff7e677a0c820b2a4b5e8c01..8814e26d7b4f4cc7806bee3d8cb61f1d842ebdef 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
 ...
 ---
 name:            test_add_v64i8
-# ALL-LABEL: name:  test_add_v64i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPADDBZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_add_v64i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPADDBZrr:%[0-9]+]] = VPADDBZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPADDBZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<64 x s8>) = COPY %zmm0
     %1(<64 x s8>) = COPY %zmm1
     %2(<64 x s8>) = G_ADD %0, %1
@@ -52,23 +57,27 @@ body:             |
 ...
 ---
 name:            test_add_v32i16
-# ALL-LABEL: name:  test_add_v32i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPADDWZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_add_v32i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPADDWZrr:%[0-9]+]] = VPADDWZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPADDWZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<32 x s16>) = COPY %zmm0
     %1(<32 x s16>) = COPY %zmm1
     %2(<32 x s16>) = G_ADD %0, %1
@@ -78,23 +87,27 @@ body:             |
 ...
 ---
 name:            test_add_v16i32
-# ALL-LABEL: name:  test_add_v16i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPADDDZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_add_v16i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPADDDZrr:%[0-9]+]] = VPADDDZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPADDDZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<16 x s32>) = COPY %zmm0
     %1(<16 x s32>) = COPY %zmm1
     %2(<16 x s32>) = G_ADD %0, %1
@@ -104,23 +117,27 @@ body:             |
 ...
 ---
 name:            test_add_v8i64
-# ALL-LABEL: name:  test_add_v8i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPADDQZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_add_v8i64
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPADDQZrr:%[0-9]+]] = VPADDQZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPADDQZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<8 x s64>) = COPY %zmm0
     %1(<8 x s64>) = COPY %zmm1
     %2(<8 x s64>) = G_ADD %0, %1
index 0b864f4173670ddc9c8dea75dcde1e463f50deea..a945b4060e08cc96a476610cc721c7761ab27ab9 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=i386-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=X32
 --- |
   define i64 @test_add_i64(i64 %a, i64 %b) {
@@ -8,21 +9,9 @@
 ...
 ---
 name:            test_add_i64
-# X32-LABEL: name:  test_add_i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# X32:      registers:
-# X32-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 2, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 4, class: gpr, preferred-register: '' }
-# X32-NEXT:   - { id: 5, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 6, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 7, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 8, class: gr32, preferred-register: '' }
-# X32-NEXT:   - { id: 9, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -34,20 +23,32 @@ registers:
   - { id: 7, class: gpr }
   - { id: 8, class: gpr }
   - { id: 9, class: gpr }
-# X32:          %0 = IMPLICIT_DEF
-# X32-NEXT:     %1 = IMPLICIT_DEF
-# X32-NEXT:     %2 = IMPLICIT_DEF
-# X32-NEXT:     %3 = IMPLICIT_DEF
-# X32-NEXT:     %5 = ADD32rr %0, %2, implicit-def %eflags
-# X32-NEXT:     %6 = COPY %eflags
-# X32-NEXT:     %eflags = COPY %6
-# X32-NEXT:     %7 = ADC32rr %1, %3, implicit-def %eflags, implicit %eflags
-# X32-NEXT:     %8 = COPY %eflags
-# X32-NEXT:     %eax = COPY %5
-# X32-NEXT:     %edx = COPY %7
-# X32-NEXT:     RET 0, implicit %eax, implicit %edx
 body:             |
   bb.0 (%ir-block.0):
+    ; X32-LABEL: name: test_add_i64
+    ; X32: registers:
+    ; X32-NEXT: id: 0, class: gr32
+    ; X32-NEXT: id: 1, class: gr32
+    ; X32-NEXT: id: 2, class: gr32
+    ; X32-NEXT: id: 3, class: gr32
+    ; X32-NEXT: id: 4, class: gpr
+    ; X32-NEXT: id: 5, class: gr32
+    ; X32-NEXT: id: 6, class: gr32
+    ; X32-NEXT: id: 7, class: gr32
+    ; X32-NEXT: id: 8, class: gr32
+    ; X32-NEXT: id: 9, class: gpr
+    ; X32: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; X32: [[DEF1:%[0-9]+]] = IMPLICIT_DEF
+    ; X32: [[DEF2:%[0-9]+]] = IMPLICIT_DEF
+    ; X32: [[DEF3:%[0-9]+]] = IMPLICIT_DEF
+    ; X32: [[ADD32rr:%[0-9]+]] = ADD32rr [[DEF]], [[DEF2]], implicit-def %eflags
+    ; X32: [[COPY:%[0-9]+]] = COPY %eflags
+    ; X32: %eflags = COPY [[COPY]]
+    ; X32: [[ADC32rr:%[0-9]+]] = ADC32rr [[DEF1]], [[DEF3]], implicit-def %eflags, implicit %eflags
+    ; X32: [[COPY1:%[0-9]+]] = COPY %eflags
+    ; X32: %eax = COPY [[ADD32rr]]
+    ; X32: %edx = COPY [[ADC32rr]]
+    ; X32: RET 0, implicit %eax, implicit %edx
     %0(s32) = IMPLICIT_DEF
     %1(s32) = IMPLICIT_DEF
     %2(s32) = IMPLICIT_DEF
index bc7ad57d22da21af2705840f1c894e936fca66d6..4085eea2ab0b28ad624e1e24ed29b19383425fa5 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
 ...
 ---
 name:            test_and_i8
-# ALL-LABEL: name:  test_and_i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -40,15 +36,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %dil
-# ALL-NEXT:     %1 = COPY %sil
-# ALL-NEXT:     %2 = AND8rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %al = COPY %2
-# ALL-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_and_i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL-NEXT: id: 1, class: gr8
+    ; ALL-NEXT: id: 2, class: gr8
+    ; ALL: [[COPY:%[0-9]+]] = COPY %dil
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %sil
+    ; ALL: [[AND8rr:%[0-9]+]] = AND8rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %al = COPY [[AND8rr]]
+    ; ALL: RET 0, implicit %al
     %0(s8) = COPY %dil
     %1(s8) = COPY %sil
     %2(s8) = G_AND %0, %1
@@ -58,14 +59,9 @@ body:             |
 ...
 ---
 name:            test_and_i16
-# ALL-LABEL: name:  test_and_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -74,15 +70,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %di
-# ALL-NEXT:     %1 = COPY %si
-# ALL-NEXT:     %2 = AND16rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %ax = COPY %2
-# ALL-NEXT:     RET 0, implicit %ax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_and_i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr16
+    ; ALL-NEXT: id: 1, class: gr16
+    ; ALL-NEXT: id: 2, class: gr16
+    ; ALL: [[COPY:%[0-9]+]] = COPY %di
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %si
+    ; ALL: [[AND16rr:%[0-9]+]] = AND16rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %ax = COPY [[AND16rr]]
+    ; ALL: RET 0, implicit %ax
     %0(s16) = COPY %di
     %1(s16) = COPY %si
     %2(s16) = G_AND %0, %1
@@ -92,14 +93,9 @@ body:             |
 ...
 ---
 name:            test_and_i32
-# ALL-LABEL: name:  test_and_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -108,15 +104,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %edi
-# ALL-NEXT:     %1 = COPY %esi
-# ALL-NEXT:     %2 = AND32rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %eax = COPY %2
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_and_i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gr32
+    ; ALL: [[COPY:%[0-9]+]] = COPY %edi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %esi
+    ; ALL: [[AND32rr:%[0-9]+]] = AND32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %eax = COPY [[AND32rr]]
+    ; ALL: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s32) = G_AND %0, %1
@@ -126,14 +127,9 @@ body:             |
 ...
 ---
 name:            test_and_i64
-# ALL-LABEL: name:  test_and_i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -142,15 +138,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %rsi
-# ALL-NEXT:     %2 = AND64rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi, %rsi
 
+    ; ALL-LABEL: name: test_and_i64
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64
+    ; ALL-NEXT: id: 1, class: gr64
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %rsi
+    ; ALL: [[AND64rr:%[0-9]+]] = AND64rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %rax = COPY [[AND64rr]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s64) = COPY %rsi
     %2(s64) = G_AND %0, %1
index ec590010e492aa43c56d3ecdd6e46483999cde75..6545678ccb2a88d05e963fffb646bf50fe860688 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+bmi -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s
 #
 # Test that rules where multiple operands must be the same operand successfully
 
 ---
 name:            test_blsi32rr
-# CHECK-LABEL: name:  test_blsi32rr
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:       registers:
-# CHECK-NEXT:     - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:     - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:     - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:     - { id: 3, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 # G_SUB and G_AND both use %0 so we should match this.
-# CHECK: %3 = BLSI32rr %0
 body:             |
   bb.1:
     liveins: %edi
 
+    ; CHECK-LABEL: name: test_blsi32rr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[BLSI32rr:%[0-9]+]] = BLSI32rr [[COPY]], implicit-def %eflags
+    ; CHECK: %edi = COPY [[BLSI32rr]]
     %0(s32) = COPY %edi
     %1(s32) = G_CONSTANT i32 0
     %2(s32) = G_SUB %1, %0
@@ -38,7 +41,6 @@ body:             |
 ...
 ---
 name:            test_blsi32rr_nomatch
-# CHECK-LABEL: name:  test_blsi32rr_nomatch
 alignment:       4
 legalized:       true
 regBankSelected: true
@@ -48,11 +50,21 @@ registers:
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 # G_SUB and G_AND use different operands so we shouldn't match this.
-# CHECK-NOT: BLSI32rr
 body:             |
   bb.1:
     liveins: %edi
 
+    ; CHECK-LABEL: name: test_blsi32rr_nomatch
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr32
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[MOV32r0_:%[0-9]+]] = MOV32r0 implicit-def %eflags
+    ; CHECK: [[SUB32ri:%[0-9]+]] = SUB32ri [[MOV32r0_]], 0, implicit-def %eflags
+    ; CHECK: [[AND32rr:%[0-9]+]] = AND32rr [[SUB32ri]], [[COPY]], implicit-def %eflags
+    ; CHECK: %edi = COPY [[AND32rr]]
     %0(s32) = COPY %edi
     %1(s32) = G_CONSTANT i32 0
     %2(s32) = G_SUB %1, %1
index 55c2bafa5f42d4284761b8cfc1e4a658a22ffbb0..737502ff1e907be83d008d769ec99b5ba8010103 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+bmi -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s
 #
 # Test that rules where multiple operands must be the same operand successfully
@@ -6,26 +7,28 @@
 
 ---
 name:            test_blsr32rr
-# CHECK-LABEL: name:  test_blsr32rr
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:       registers:
-# CHECK-NEXT:     - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:     - { id: 1, class: gpr, preferred-register: '' }
-# CHECK-NEXT:     - { id: 2, class: gpr, preferred-register: '' }
-# CHECK-NEXT:     - { id: 3, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 # G_ADD and G_AND both use %0 so we should match this.
-# CHECK: %3 = BLSR32rr %0
 body:             |
   bb.1:
     liveins: %edi
 
+    ; CHECK-LABEL: name: test_blsr32rr
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gpr
+    ; CHECK-NEXT: id: 2, class: gpr
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[BLSR32rr:%[0-9]+]] = BLSR32rr [[COPY]], implicit-def %eflags
+    ; CHECK: %edi = COPY [[BLSR32rr]]
     %0(s32) = COPY %edi
     %1(s32) = G_CONSTANT i32 -1
     %2(s32) = G_ADD %0, %1
@@ -35,7 +38,6 @@ body:             |
 ...
 ---
 name:            test_blsr32rr_nomatch
-# CHECK-LABEL: name:  test_blsr32rr_nomatch
 alignment:       4
 legalized:       true
 regBankSelected: true
@@ -45,11 +47,21 @@ registers:
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
 # G_ADD and G_AND use different operands so we shouldn't match this.
-# CHECK-NOT: BLSR32rr
 body:             |
   bb.1:
     liveins: %edi
 
+    ; CHECK-LABEL: name: test_blsr32rr_nomatch
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr32
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[MOV32ri:%[0-9]+]] = MOV32ri 4294967295
+    ; CHECK: [[DEC32r:%[0-9]+]] = DEC32r [[MOV32ri]], implicit-def %eflags
+    ; CHECK: [[AND32rr:%[0-9]+]] = AND32rr [[DEC32r]], [[COPY]], implicit-def %eflags
+    ; CHECK: %edi = COPY [[AND32rr]]
     %0(s32) = COPY %edi
     %1(s32) = G_CONSTANT i32 -1
     %2(s32) = G_ADD %1, %1
index 9a79214cc70302591e2ecf09ac4c46d7074f9226..4403053fc51d773ac16b012d2c828e6395328aba 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=CHECK
 
 --- |
 ...
 ---
 name:            test_icmp_eq_i8
-# CHECK-LABEL: name:  test_icmp_eq_i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %dil
-# CHECK-NEXT:     %1 = COPY %sil
-# CHECK-NEXT:     CMP8rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_eq_i8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr8
+    ; CHECK-NEXT: id: 1, class: gr8
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %dil
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %sil
+    ; CHECK: CMP8rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETEr:%[0-9]+]] = SETEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s8) = COPY %dil
     %1(s8) = COPY %sil
     %2(s1) = G_ICMP intpred(eq), %0(s8), %1
@@ -119,33 +120,33 @@ body:             |
 ...
 ---
 name:            test_icmp_eq_i16
-# CHECK-LABEL: name:  test_icmp_eq_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr16, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %di
-# CHECK-NEXT:     %1 = COPY %si
-# CHECK-NEXT:     CMP16rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_eq_i16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr16
+    ; CHECK-NEXT: id: 1, class: gr16
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %di
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %si
+    ; CHECK: CMP16rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETEr:%[0-9]+]] = SETEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s16) = COPY %di
     %1(s16) = COPY %si
     %2(s1) = G_ICMP intpred(eq), %0(s16), %1
@@ -156,33 +157,33 @@ body:             |
 ...
 ---
 name:            test_icmp_eq_i64
-# CHECK-LABEL: name:  test_icmp_eq_i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %rdi
-# CHECK-NEXT:     %1 = COPY %rsi
-# CHECK-NEXT:     CMP64rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi, %rsi
 
+    ; CHECK-LABEL: name: test_icmp_eq_i64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK-NEXT: id: 1, class: gr64
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %rdi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %rsi
+    ; CHECK: CMP64rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETEr:%[0-9]+]] = SETEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s64) = COPY %rdi
     %1(s64) = COPY %rsi
     %2(s1) = G_ICMP intpred(eq), %0(s64), %1
@@ -193,33 +194,33 @@ body:             |
 ...
 ---
 name:            test_icmp_eq_i32
-# CHECK-LABEL: name:  test_icmp_eq_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_eq_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETEr:%[0-9]+]] = SETEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(eq), %0(s32), %1
@@ -230,33 +231,33 @@ body:             |
 ...
 ---
 name:            test_icmp_ne_i32
-# CHECK-LABEL: name:  test_icmp_ne_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETNEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_ne_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETNEr:%[0-9]+]] = SETNEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETNEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(ne), %0(s32), %1
@@ -267,33 +268,33 @@ body:             |
 ...
 ---
 name:            test_icmp_ugt_i32
-# CHECK-LABEL: name:  test_icmp_ugt_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETAr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_ugt_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETAr:%[0-9]+]] = SETAr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETAr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(ugt), %0(s32), %1
@@ -304,33 +305,33 @@ body:             |
 ...
 ---
 name:            test_icmp_uge_i32
-# CHECK-LABEL: name:  test_icmp_uge_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETAEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_uge_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETAEr:%[0-9]+]] = SETAEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETAEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(uge), %0(s32), %1
@@ -341,33 +342,33 @@ body:             |
 ...
 ---
 name:            test_icmp_ult_i32
-# CHECK-LABEL: name:  test_icmp_ult_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETBr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_ult_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETBr:%[0-9]+]] = SETBr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETBr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(ult), %0(s32), %1
@@ -378,33 +379,33 @@ body:             |
 ...
 ---
 name:            test_icmp_ule_i32
-# CHECK-LABEL: name:  test_icmp_ule_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETBEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_ule_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETBEr:%[0-9]+]] = SETBEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETBEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(ule), %0(s32), %1
@@ -415,33 +416,33 @@ body:             |
 ...
 ---
 name:            test_icmp_sgt_i32
-# CHECK-LABEL: name:  test_icmp_sgt_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETGr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_sgt_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETGr:%[0-9]+]] = SETGr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETGr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(sgt), %0(s32), %1
@@ -452,33 +453,33 @@ body:             |
 ...
 ---
 name:            test_icmp_sge_i32
-# CHECK-LABEL: name:  test_icmp_sge_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETGEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_sge_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETGEr:%[0-9]+]] = SETGEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETGEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(sge), %0(s32), %1
@@ -489,33 +490,33 @@ body:             |
 ...
 ---
 name:            test_icmp_slt_i32
-# CHECK-LABEL: name:  test_icmp_slt_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETLr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_slt_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETLr:%[0-9]+]] = SETLr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETLr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(slt), %0(s32), %1
@@ -526,33 +527,33 @@ body:             |
 ...
 ---
 name:            test_icmp_sle_i32
-# CHECK-LABEL: name:  test_icmp_sle_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
-# CHECK-NEXT:   - { id: 3, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 4, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
   - { id: 3, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %esi
-# CHECK-NEXT:     CMP32rr %0, %1, implicit-def %eflags
-# CHECK-NEXT:     %2 = SETLEr implicit %eflags
-# CHECK-NEXT:     %4 = SUBREG_TO_REG 0, %2, 1
-# CHECK-NEXT:     %3 = AND32ri8 %4, 1, implicit-def %eflags
-# CHECK-NEXT:     %eax = COPY %3
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; CHECK-LABEL: name: test_icmp_sle_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK-NEXT: id: 2, class: gr8
+    ; CHECK-NEXT: id: 3, class: gr32
+    ; CHECK-NEXT: id: 4, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %esi
+    ; CHECK: CMP32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; CHECK: [[SETLEr:%[0-9]+]] = SETLEr implicit %eflags
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[SETLEr]], 1
+    ; CHECK: [[AND32ri8_:%[0-9]+]] = AND32ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; CHECK: %eax = COPY [[AND32ri8_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s1) = G_ICMP intpred(sle), %0(s32), %1
index 30f57418b4ce0b612a44180f0a72705b3d06a4bc..db6c8c984a8cc5c8c6fb998da314a8e84afec23a 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=CHECK
 
 --- |
@@ -40,15 +41,16 @@ name:            const_i8
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name:            const_i8
-# CHECK: registers:
-# CHECK-NEXT:  - { id: 0, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV8ri 2
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr8
+    ; CHECK: [[MOV8ri:%[0-9]+]] = MOV8ri 2
+    ; CHECK: %al = COPY [[MOV8ri]]
+    ; CHECK: RET 0, implicit %al
     %0(s8) = G_CONSTANT i8 2
     %al = COPY %0(s8)
     RET 0, implicit %al
@@ -59,15 +61,16 @@ name:            const_i16
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name:            const_i16
-# CHECK: registers:
-# CHECK-NEXT:  - { id: 0, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV16ri 3
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr16
+    ; CHECK: [[MOV16ri:%[0-9]+]] = MOV16ri 3
+    ; CHECK: %ax = COPY [[MOV16ri]]
+    ; CHECK: RET 0, implicit %ax
     %0(s16) = G_CONSTANT i16 3
     %ax = COPY %0(s16)
     RET 0, implicit %ax
@@ -78,15 +81,16 @@ name:            const_i32
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name:            const_i32
-# CHECK: registers:
-# CHECK-NEXT:  - { id: 0, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV32ri 4
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK: [[MOV32ri:%[0-9]+]] = MOV32ri 4
+    ; CHECK: %eax = COPY [[MOV32ri]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = G_CONSTANT i32 4
     %eax = COPY %0(s32)
     RET 0, implicit %eax
@@ -94,16 +98,18 @@ body:             |
 ...
 ---
 name:            const_i32_0
-# CHECK-LABEL: name:  const_i32_0
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:          %0 = MOV32r0 implicit-def %eflags
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i32_0
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK: [[MOV32r0_:%[0-9]+]] = MOV32r0 implicit-def %eflags
+    ; CHECK: %eax = COPY [[MOV32r0_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = G_CONSTANT i32 0
     %eax = COPY %0(s32)
     RET 0, implicit %eax
@@ -114,15 +120,16 @@ name:            const_i64
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name:            const_i64
-# CHECK: registers:
-# CHECK-NEXT:  - { id: 0, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV64ri 68719476720
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK: [[MOV64ri:%[0-9]+]] = MOV64ri 68719476720
+    ; CHECK: %rax = COPY [[MOV64ri]]
+    ; CHECK: RET 0, implicit %rax
     %0(s64) = G_CONSTANT i64 68719476720
     %rax = COPY %0(s64)
     RET 0, implicit %rax
@@ -134,15 +141,16 @@ alignment:       4
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name:            const_i64_u32
-# CHECK: registers:
-# CHECK-NEXT:  - { id: 0, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV64ri32 1879048192
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i64_u32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK: [[MOV64ri32_:%[0-9]+]] = MOV64ri32 1879048192
+    ; CHECK: %rax = COPY [[MOV64ri32_]]
+    ; CHECK: RET 0, implicit %rax
     %0(s64) = G_CONSTANT i64 1879048192
     %rax = COPY %0(s64)
     RET 0, implicit %rax
@@ -153,15 +161,16 @@ name:            const_i64_i32
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name:            const_i64_i32
-# CHECK: registers:
-# CHECK-NEXT:  - { id: 0, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV64ri32 -1
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i64_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK: [[MOV64ri32_:%[0-9]+]] = MOV64ri32 -1
+    ; CHECK: %rax = COPY [[MOV64ri32_]]
+    ; CHECK: RET 0, implicit %rax
     %0(s64) = G_CONSTANT i64 -1
     %rax = COPY %0(s64)
     RET 0, implicit %rax
@@ -169,24 +178,24 @@ body:             |
 ...
 ---
 name:            main
-# CHECK-LABEL: name:  main
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
-# CHECK:          %0 = COPY %rdi
-# CHECK-NEXT:     %1 = MOV64ri32 0
-# CHECK-NEXT:     MOV64mr %0, 1, _, 0, _, %1 :: (store 8 into %ir.data)
-# CHECK-NEXT:     RET 0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi
 
+    ; CHECK-LABEL: name: main
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK-NEXT: id: 1, class: gr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %rdi
+    ; CHECK: [[MOV64ri32_:%[0-9]+]] = MOV64ri32 0
+    ; CHECK: MOV64mr [[COPY]], 1, _, 0, _, [[MOV64ri32_]] :: (store 8 into %ir.data)
+    ; CHECK: RET 0
     %0(p0) = COPY %rdi
     %1(p0) = G_CONSTANT i64 0
     G_STORE %1(p0), %0(p0) :: (store 8 into %ir.data)
index 48a4ecfaa9190f2ea61a532beedc23a1d03bdb17..df9265e45fec463d3a478818ccdd56fd58f5e1b9 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL --check-prefix=X64
 
 --- |
 ...
 ---
 name:            test_zext_i1
-# ALL-LABEL: name:  test_zext_i1
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:          %0 = COPY %dil
-# ALL-NEXT:     %1 = COPY %0
-# ALL-NEXT:     %3 = SUBREG_TO_REG 0, %1, 1
-# ALL-NEXT:     %2 = AND64ri8 %3, 1, implicit-def %eflags
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: test_zext_i1
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL-NEXT: id: 1, class: gr8
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL-NEXT: id: 3, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %dil
+    ; ALL: [[COPY1:%[0-9]+]] = COPY [[COPY]]
+    ; ALL: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY1]], 1
+    ; ALL: [[AND64ri8_:%[0-9]+]] = AND64ri8 [[SUBREG_TO_REG]], 1, implicit-def %eflags
+    ; ALL: %rax = COPY [[AND64ri8_]]
+    ; ALL: RET 0, implicit %rax
     %0(s8) = COPY %dil
     %1(s1) = G_TRUNC %0(s8)
     %2(s64) = G_ZEXT %1(s1)
@@ -56,24 +57,24 @@ body:             |
 ...
 ---
 name:            test_sext_i8
-# ALL-LABEL: name:  test_sext_i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# ALL:          %0 = COPY %dil
-# ALL-NEXT:     %1 = MOVSX64rr8 %0
-# ALL-NEXT:     %rax = COPY %1
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: test_sext_i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL-NEXT: id: 1, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %dil
+    ; ALL: [[MOVSX64rr8_:%[0-9]+]] = MOVSX64rr8 [[COPY]]
+    ; ALL: %rax = COPY [[MOVSX64rr8_]]
+    ; ALL: RET 0, implicit %rax
     %0(s8) = COPY %dil
     %1(s64) = G_SEXT %0(s8)
     %rax = COPY %1(s64)
@@ -82,24 +83,24 @@ body:             |
 ...
 ---
 name:            test_sext_i16
-# ALL-LABEL: name:  test_sext_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# ALL:          %0 = COPY %di
-# ALL-NEXT:     %1 = MOVSX64rr16 %0
-# ALL-NEXT:     %rax = COPY %1
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: test_sext_i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr16
+    ; ALL-NEXT: id: 1, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %di
+    ; ALL: [[MOVSX64rr16_:%[0-9]+]] = MOVSX64rr16 [[COPY]]
+    ; ALL: %rax = COPY [[MOVSX64rr16_]]
+    ; ALL: RET 0, implicit %rax
     %0(s16) = COPY %di
     %1(s64) = G_SEXT %0(s16)
     %rax = COPY %1(s64)
@@ -108,27 +109,27 @@ body:             |
 ...
 ---
 name:            anyext_s64_from_s1
-# ALL-LABEL: name:  anyext_s64_from_s1
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64_with_sub_8bit, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %0.sub_8bit
-# ALL-NEXT:     %2 = SUBREG_TO_REG 0, %1, 1
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: anyext_s64_from_s1
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64_with_sub_8bit
+    ; ALL-NEXT: id: 1, class: gr8
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_8bit
+    ; ALL: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY1]], 1
+    ; ALL: %rax = COPY [[SUBREG_TO_REG]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s1) = G_TRUNC %0(s64)
     %2(s64) = G_ANYEXT %1(s1)
@@ -137,27 +138,27 @@ body:             |
 ...
 ---
 name:            anyext_s64_from_s8
-# ALL-LABEL: name:  anyext_s64_from_s8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64_with_sub_8bit, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %0.sub_8bit
-# ALL-NEXT:     %2 = SUBREG_TO_REG 0, %1, 1
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: anyext_s64_from_s8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64_with_sub_8bit
+    ; ALL-NEXT: id: 1, class: gr8
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_8bit
+    ; ALL: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY1]], 1
+    ; ALL: %rax = COPY [[SUBREG_TO_REG]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s8) = G_TRUNC %0(s64)
     %2(s64) = G_ANYEXT %1(s8)
@@ -166,27 +167,27 @@ body:             |
 ...
 ---
 name:            anyext_s64_from_s16
-# ALL-LABEL: name:  anyext_s64_from_s16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %0.sub_16bit
-# ALL-NEXT:     %2 = SUBREG_TO_REG 0, %1, 3
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: anyext_s64_from_s16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64
+    ; ALL-NEXT: id: 1, class: gr16
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_16bit
+    ; ALL: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY1]], 3
+    ; ALL: %rax = COPY [[SUBREG_TO_REG]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s16) = G_TRUNC %0(s64)
     %2(s64) = G_ANYEXT %1(s16)
@@ -195,27 +196,27 @@ body:             |
 ...
 ---
 name:            anyext_s64_from_s32
-# ALL-LABEL: name:  anyext_s64_from_s32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %0.sub_32bit
-# ALL-NEXT:     %2 = SUBREG_TO_REG 0, %1, 4
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: anyext_s64_from_s32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32bit
+    ; ALL: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[COPY1]], 4
+    ; ALL: %rax = COPY [[SUBREG_TO_REG]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s32) = G_TRUNC %0(s64)
     %2(s64) = G_ANYEXT %1(s32)
index 8bbc82a270e4f73fcc05b3974f3eab0f2f01f20a..1cc9dda4877a8f0e9f64fae93ff4f9125298f42f 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 --- |
 
 ...
 ---
 name:            test
-# ALL-LABEL: name:  test
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: fr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: fr64, preferred-register: '' }
 registers:
   - { id: 0, class: vecr, preferred-register: '' }
   - { id: 1, class: vecr, preferred-register: '' }
@@ -24,14 +21,18 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %xmm0
-# ALL-NEXT:     %1 = CVTSS2SDrr %0
-# ALL-NEXT:     %xmm0 = COPY %1
-# ALL-NEXT:     RET 0, implicit %xmm0
 body:             |
   bb.1.entry:
     liveins: %xmm0
 
+    ; ALL-LABEL: name: test
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: fr32
+    ; ALL-NEXT: id: 1, class: fr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; ALL: [[CVTSS2SDrr:%[0-9]+]] = CVTSS2SDrr [[COPY]]
+    ; ALL: %xmm0 = COPY [[CVTSS2SDrr]]
+    ; ALL: RET 0, implicit %xmm0
     %0(s32) = COPY %xmm0
     %1(s64) = G_FPEXT %0(s32)
     %xmm0 = COPY %1(s64)
index 61c7662300358e3803c92ff3005374c045530307..440817b4e1cc29debe8bb8fb97282867f8f64c1d 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=CHECK
 
 --- |
@@ -12,22 +13,24 @@ alignment:       4
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name:            test_gep_i32
-# CHECK: registers:
-# CHECK-NEXT: - { id: 0, class: gr64, preferred-register: '' }
-# CHECK-NEXT: - { id: 1, class: gr64_nosp, preferred-register: '' }
-# CHECK-NEXT: - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# CHECK:  body:
-# CHECK:       %1 = MOV64ri32 20
-# CHECK-NEXT:  %2 = LEA64r %0, 1, %1, 0, _
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi
 
+    ; CHECK-LABEL: name: test_gep_i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK-NEXT: id: 1, class: gr64_nosp
+    ; CHECK-NEXT: id: 2, class: gr64
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %rdi
+    ; CHECK: [[MOV64ri32_:%[0-9]+]] = MOV64ri32 20
+    ; CHECK: [[LEA64r:%[0-9]+]] = LEA64r [[COPY]], 1, [[MOV64ri32_]], 0, _
+    ; CHECK: %rax = COPY [[LEA64r]]
+    ; CHECK: RET 0, implicit %rax
     %0(p0) = COPY %rdi
     %1(s64) = G_CONSTANT i64 20
     %2(p0) = G_GEP %0, %1(s64)
index 216f9a955d876d695c03640b76b7f669b3e4e155..aae03113ad24fb461d0272b7f2610a298ce6bfd6 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
 ...
 ---
 name:            test_insert_128_idx0
-# ALL-LABEL: name:  test_insert_128_idx0
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %0 = COPY %zmm0
-# ALL-NEXT:     %1 = COPY %xmm1
-# ALL-NEXT:     %2 = VINSERTF32x4Zrr %0, %1, 0
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_128_idx0
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr128x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; ALL: [[VINSERTF32x4Zrr:%[0-9]+]] = VINSERTF32x4Zrr [[COPY]], [[COPY1]], 0
+    ; ALL: %zmm0 = COPY [[VINSERTF32x4Zrr]]
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = COPY %zmm0
     %1(<4 x s32>) = COPY %xmm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<4 x s32>), 0
@@ -66,26 +67,26 @@ body:             |
 ...
 ---
 name:            test_insert_128_idx0_undef
-# ALL-LABEL: name:  test_insert_128_idx0_undef
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vecr, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %1 = COPY %xmm1
-# ALL-NEXT:     undef %2.sub_xmm = COPY %1
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_128_idx0_undef
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vecr
+    ; ALL-NEXT: id: 1, class: vr128x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %xmm1
+    ; ALL: undef %2.sub_xmm = COPY [[COPY]]
+    ; ALL: %zmm0 = COPY %2
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = IMPLICIT_DEF
     %1(<4 x s32>) = COPY %xmm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<4 x s32>), 0
@@ -95,27 +96,27 @@ body:             |
 ...
 ---
 name:            test_insert_128_idx1
-# ALL-LABEL: name:  test_insert_128_idx1
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %0 = COPY %zmm0
-# ALL-NEXT:     %1 = COPY %xmm1
-# ALL-NEXT:     %2 = VINSERTF32x4Zrr %0, %1, 1
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_128_idx1
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr128x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; ALL: [[VINSERTF32x4Zrr:%[0-9]+]] = VINSERTF32x4Zrr [[COPY]], [[COPY1]], 1
+    ; ALL: %zmm0 = COPY [[VINSERTF32x4Zrr]]
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = COPY %zmm0
     %1(<4 x s32>) = COPY %xmm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<4 x s32>), 128
@@ -124,27 +125,27 @@ body:             |
 ...
 ---
 name:            test_insert_128_idx1_undef
-# ALL-LABEL: name:  test_insert_128_idx1_undef
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %0 = IMPLICIT_DEF
-# ALL-NEXT:     %1 = COPY %xmm1
-# ALL-NEXT:     %2 = VINSERTF32x4Zrr %0, %1, 1
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_128_idx1_undef
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr128x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: [[COPY:%[0-9]+]] = COPY %xmm1
+    ; ALL: [[VINSERTF32x4Zrr:%[0-9]+]] = VINSERTF32x4Zrr [[DEF]], [[COPY]], 1
+    ; ALL: %zmm0 = COPY [[VINSERTF32x4Zrr]]
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = IMPLICIT_DEF
     %1(<4 x s32>) = COPY %xmm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<4 x s32>), 128
@@ -153,27 +154,27 @@ body:             |
 ...
 ---
 name:            test_insert_256_idx0
-# ALL-LABEL: name:  test_insert_256_idx0
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %0 = COPY %zmm0
-# ALL-NEXT:     %1 = COPY %ymm1
-# ALL-NEXT:     %2 = VINSERTF64x4Zrr %0, %1, 0
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_256_idx0
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr256x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %ymm1
+    ; ALL: [[VINSERTF64x4Zrr:%[0-9]+]] = VINSERTF64x4Zrr [[COPY]], [[COPY1]], 0
+    ; ALL: %zmm0 = COPY [[VINSERTF64x4Zrr]]
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = COPY %zmm0
     %1(<8 x s32>) = COPY %ymm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<8 x s32>), 0
@@ -183,26 +184,26 @@ body:             |
 ...
 ---
 name:            test_insert_256_idx0_undef
-# ALL-LABEL: name:  test_insert_256_idx0_undef
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vecr, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %1 = COPY %ymm1
-# ALL-NEXT:     undef %2.sub_ymm = COPY %1
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_256_idx0_undef
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vecr
+    ; ALL-NEXT: id: 1, class: vr256x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %ymm1
+    ; ALL: undef %2.sub_ymm = COPY [[COPY]]
+    ; ALL: %zmm0 = COPY %2
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = IMPLICIT_DEF
     %1(<8 x s32>) = COPY %ymm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<8 x s32>), 0
@@ -212,27 +213,27 @@ body:             |
 ...
 ---
 name:            test_insert_256_idx1
-# ALL-LABEL: name:  test_insert_256_idx1
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %0 = COPY %zmm0
-# ALL-NEXT:     %1 = COPY %ymm1
-# ALL-NEXT:     %2 = VINSERTF64x4Zrr %0, %1, 1
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_256_idx1
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr256x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %ymm1
+    ; ALL: [[VINSERTF64x4Zrr:%[0-9]+]] = VINSERTF64x4Zrr [[COPY]], [[COPY1]], 1
+    ; ALL: %zmm0 = COPY [[VINSERTF64x4Zrr]]
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = COPY %zmm0
     %1(<8 x s32>) = COPY %ymm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<8 x s32>), 256
@@ -241,27 +242,27 @@ body:             |
 ...
 ---
 name:            test_insert_256_idx1_undef
-# ALL-LABEL: name:  test_insert_256_idx1_undef
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %0 = IMPLICIT_DEF
-# ALL-NEXT:     %1 = COPY %ymm1
-# ALL-NEXT:     %2 = VINSERTF64x4Zrr %0, %1, 1
-# ALL-NEXT:     %zmm0 = COPY %2
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; ALL-LABEL: name: test_insert_256_idx1_undef
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr256x
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: [[COPY:%[0-9]+]] = COPY %ymm1
+    ; ALL: [[VINSERTF64x4Zrr:%[0-9]+]] = VINSERTF64x4Zrr [[DEF]], [[COPY]], 1
+    ; ALL: %zmm0 = COPY [[VINSERTF64x4Zrr]]
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = IMPLICIT_DEF
     %1(<8 x s32>) = COPY %ymm1
     %2(<16 x s32>) = G_INSERT %0(<16 x s32>), %1(<8 x s32>), 256
index 33ffc6e790cb29159ae31cf39c369264e6d587bf..77c11b12e2348536522f0127e193fe3666b76856 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=i386-- -run-pass=instruction-select -verify-machineinstrs -global-isel %s -o - | FileCheck %s
 
 --- |
@@ -8,20 +9,22 @@
 # Check that we select a the x86.flags.read.u32 intrinsic into a RDFLAGS
 # instruction. Also check that we constrain the register class of the COPY to
 # gr32.
-# CHECK-LABEL: name: read_flags
 name:            read_flags
 legalized:       true
 regBankSelected: true
 
-# CHECK:      registers:
-# CHECK-NEXT:  - { id: 0, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
 
-# CHECK:  body:
-# CHECK:    %0 = RDFLAGS32
 body:             |
   bb.0:
+    ; CHECK-LABEL: name: read_flags
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr64
+    ; CHECK: [[RDFLAGS32_:%[0-9]+]] = RDFLAGS32 implicit-def %esp, implicit %esp
+    ; CHECK: [[SUBREG_TO_REG:%[0-9]+]] = SUBREG_TO_REG 0, [[RDFLAGS32_]], 4
+    ; CHECK: %rax = COPY [[SUBREG_TO_REG]]
     %0(s32) = G_INTRINSIC_W_SIDE_EFFECTS intrinsic(@llvm.x86.flags.read.u32)
     %rax = COPY %0(s32)
 ...
index 9128f19b1d248e388d0a7497c92caf34f58dab54..f38b3b80f709a59e3d4cf0fc5becf16682fb5ed9 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=i586-linux-gnu -mcpu=haswell -mattr=-slow-incdec -global-isel -run-pass=instruction-select %s -o - | FileCheck %s --check-prefix=CHECK
 #
 # This is necessary to test that attribute-based rule predicates work and that
@@ -27,15 +28,16 @@ name:            const_i32_1
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name: const_i32_1
-# CHECK:       registers:
-# CHECK-NEXT:  - { id: 0, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV32ri 1
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i32_1
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK: [[MOV32ri:%[0-9]+]] = MOV32ri 1
+    ; CHECK: %eax = COPY [[MOV32ri]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = G_CONSTANT i32 1
     %eax = COPY %0(s32)
     RET 0, implicit %eax
@@ -45,15 +47,16 @@ name:            const_i32_1_optsize
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name: const_i32_1_optsize
-# CHECK:       registers:
-# CHECK-NEXT:  - { id: 0, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV32r1
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i32_1_optsize
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK: [[MOV32r1_:%[0-9]+]] = MOV32r1 implicit-def %eflags
+    ; CHECK: %eax = COPY [[MOV32r1_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = G_CONSTANT i32 1
     %eax = COPY %0(s32)
     RET 0, implicit %eax
@@ -63,15 +66,16 @@ name:            const_i32_1b
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name: const_i32_1b
-# CHECK:       registers:
-# CHECK-NEXT:  - { id: 0, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV32ri 1
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i32_1b
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK: [[MOV32ri:%[0-9]+]] = MOV32ri 1
+    ; CHECK: %eax = COPY [[MOV32ri]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = G_CONSTANT i32 1
     %eax = COPY %0(s32)
     RET 0, implicit %eax
@@ -81,15 +85,16 @@ name:            const_i32_1_optsizeb
 legalized:       true
 regBankSelected: true
 selected:        false
-# CHECK-LABEL: name: const_i32_1_optsizeb
-# CHECK:       registers:
-# CHECK-NEXT:  - { id: 0, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
-# CHECK:  body:
-# CHECK:    %0 = MOV32r1
 body:             |
   bb.1 (%ir-block.0):
+    ; CHECK-LABEL: name: const_i32_1_optsizeb
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK: [[MOV32r1_:%[0-9]+]] = MOV32r1 implicit-def %eflags
+    ; CHECK: %eax = COPY [[MOV32r1_]]
+    ; CHECK: RET 0, implicit %eax
     %0(s32) = G_CONSTANT i32 1
     %eax = COPY %0(s32)
     RET 0, implicit %eax
index af09ea04929585c150540fbe98083301c5a94267..ce4e769d86a8def102fa420d05e6abe6b6d1f81c 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=i386-linux-gnu  -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
 ...
 ---
 name:            test_load_i8
-# ALL-LABEL: name:  test_load_i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 fixedStack:
   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %2 = MOV8rm %0, 1, _, 0, _ :: (load 1 from %ir.p1)
-# ALL-NEXT:     %al = COPY %2
-# ALL-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_load_i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gpr
+    ; ALL-NEXT: id: 2, class: gr8
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV8rm:%[0-9]+]] = MOV8rm [[MOV32rm]], 1, _, 0, _ :: (load 1 from %ir.p1)
+    ; ALL: %al = COPY [[MOV8rm]]
+    ; ALL: RET 0, implicit %al
     %1(p0) = G_FRAME_INDEX %fixed-stack.0
     %0(p0) = G_LOAD %1(p0) :: (invariant load 4 from %fixed-stack.0, align 0)
     %2(s8) = G_LOAD %0(p0) :: (load 1 from %ir.p1)
@@ -73,26 +74,26 @@ body:             |
 ...
 ---
 name:            test_load_i16
-# ALL-LABEL: name:  test_load_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 fixedStack:
   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %2 = MOV16rm %0, 1, _, 0, _ :: (load 2 from %ir.p1)
-# ALL-NEXT:     %ax = COPY %2
-# ALL-NEXT:     RET 0, implicit %ax
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_load_i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gpr
+    ; ALL-NEXT: id: 2, class: gr16
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV16rm:%[0-9]+]] = MOV16rm [[MOV32rm]], 1, _, 0, _ :: (load 2 from %ir.p1)
+    ; ALL: %ax = COPY [[MOV16rm]]
+    ; ALL: RET 0, implicit %ax
     %1(p0) = G_FRAME_INDEX %fixed-stack.0
     %0(p0) = G_LOAD %1(p0) :: (invariant load 4 from %fixed-stack.0, align 0)
     %2(s16) = G_LOAD %0(p0) :: (load 2 from %ir.p1)
@@ -102,26 +103,26 @@ body:             |
 ...
 ---
 name:            test_load_i32
-# ALL-LABEL: name:  test_load_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 fixedStack:
   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %2 = MOV32rm %0, 1, _, 0, _ :: (load 4 from %ir.p1)
-# ALL-NEXT:     %eax = COPY %2
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_load_i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gpr
+    ; ALL-NEXT: id: 2, class: gr32
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV32rm1:%[0-9]+]] = MOV32rm [[MOV32rm]], 1, _, 0, _ :: (load 4 from %ir.p1)
+    ; ALL: %eax = COPY [[MOV32rm1]]
+    ; ALL: RET 0, implicit %eax
     %1(p0) = G_FRAME_INDEX %fixed-stack.0
     %0(p0) = G_LOAD %1(p0) :: (invariant load 4 from %fixed-stack.0, align 0)
     %2(s32) = G_LOAD %0(p0) :: (load 4 from %ir.p1)
@@ -131,15 +132,9 @@ body:             |
 ...
 ---
 name:            test_store_i8
-# ALL-LABEL: name:  test_store_i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -148,13 +143,19 @@ registers:
 fixedStack:
   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
   - { id: 1, offset: 0, size: 1, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV8rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 1 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %1 = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
-# ALL-NEXT:     MOV8mr %1, 1, _, 0, _, %0 :: (store 1 into %ir.p1)
-# ALL-NEXT:     %eax = COPY %1
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_store_i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gpr
+    ; ALL-NEXT: id: 3, class: gpr
+    ; ALL: [[MOV8rm:%[0-9]+]] = MOV8rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 1 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
+    ; ALL: MOV8mr [[MOV32rm]], 1, _, 0, _, [[MOV8rm]] :: (store 1 into %ir.p1)
+    ; ALL: %eax = COPY [[MOV32rm]]
+    ; ALL: RET 0, implicit %eax
     %2(p0) = G_FRAME_INDEX %fixed-stack.1
     %0(s8) = G_LOAD %2(p0) :: (invariant load 1 from %fixed-stack.1, align 0)
     %3(p0) = G_FRAME_INDEX %fixed-stack.0
@@ -166,15 +167,9 @@ body:             |
 ...
 ---
 name:            test_store_i16
-# ALL-LABEL: name:  test_store_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -183,13 +178,19 @@ registers:
 fixedStack:
   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
   - { id: 1, offset: 0, size: 2, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV16rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 2 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %1 = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
-# ALL-NEXT:     MOV16mr %1, 1, _, 0, _, %0 :: (store 2 into %ir.p1)
-# ALL-NEXT:     %eax = COPY %1
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_store_i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr16
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gpr
+    ; ALL-NEXT: id: 3, class: gpr
+    ; ALL: [[MOV16rm:%[0-9]+]] = MOV16rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 2 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
+    ; ALL: MOV16mr [[MOV32rm]], 1, _, 0, _, [[MOV16rm]] :: (store 2 into %ir.p1)
+    ; ALL: %eax = COPY [[MOV32rm]]
+    ; ALL: RET 0, implicit %eax
     %2(p0) = G_FRAME_INDEX %fixed-stack.1
     %0(s16) = G_LOAD %2(p0) :: (invariant load 2 from %fixed-stack.1, align 0)
     %3(p0) = G_FRAME_INDEX %fixed-stack.0
@@ -201,15 +202,9 @@ body:             |
 ...
 ---
 name:            test_store_i32
-# ALL-LABEL: name:  test_store_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -218,13 +213,19 @@ registers:
 fixedStack:
   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
   - { id: 1, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %1 = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
-# ALL-NEXT:     MOV32mr %1, 1, _, 0, _, %0 :: (store 4 into %ir.p1)
-# ALL-NEXT:     %eax = COPY %1
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_store_i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gpr
+    ; ALL-NEXT: id: 3, class: gpr
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV32rm1:%[0-9]+]] = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
+    ; ALL: MOV32mr [[MOV32rm1]], 1, _, 0, _, [[MOV32rm]] :: (store 4 into %ir.p1)
+    ; ALL: %eax = COPY [[MOV32rm1]]
+    ; ALL: RET 0, implicit %eax
     %2(p0) = G_FRAME_INDEX %fixed-stack.1
     %0(s32) = G_LOAD %2(p0) :: (invariant load 4 from %fixed-stack.1, align 0)
     %3(p0) = G_FRAME_INDEX %fixed-stack.0
@@ -236,26 +237,26 @@ body:             |
 ...
 ---
 name:            test_load_ptr
-# ALL-LABEL: name:  test_load_ptr
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
 fixedStack:
   - { id: 0, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %2 = MOV32rm %0, 1, _, 0, _ :: (load 4 from %ir.ptr1)
-# ALL-NEXT:     %eax = COPY %2
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_load_ptr
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gpr
+    ; ALL-NEXT: id: 2, class: gr32
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV32rm1:%[0-9]+]] = MOV32rm [[MOV32rm]], 1, _, 0, _ :: (load 4 from %ir.ptr1)
+    ; ALL: %eax = COPY [[MOV32rm1]]
+    ; ALL: RET 0, implicit %eax
     %1(p0) = G_FRAME_INDEX %fixed-stack.0
     %0(p0) = G_LOAD %1(p0) :: (invariant load 4 from %fixed-stack.0, align 0)
     %2(p0) = G_LOAD %0(p0) :: (load 4 from %ir.ptr1)
@@ -265,15 +266,9 @@ body:             |
 ...
 ---
 name:            test_store_ptr
-# ALL-LABEL: name:  test_store_ptr
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gpr, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: gpr, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
@@ -282,12 +277,18 @@ registers:
 fixedStack:
   - { id: 0, offset: 4, size: 4, alignment: 4, isImmutable: true, isAliased: false }
   - { id: 1, offset: 0, size: 4, alignment: 16, isImmutable: true, isAliased: false }
-# ALL:          %0 = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
-# ALL-NEXT:     %1 = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
-# ALL-NEXT:     MOV32mr %0, 1, _, 0, _, %1 :: (store 4 into %ir.ptr1)
-# ALL-NEXT:     RET 0
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test_store_ptr
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gpr
+    ; ALL-NEXT: id: 3, class: gpr
+    ; ALL: [[MOV32rm:%[0-9]+]] = MOV32rm %fixed-stack.0, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.0, align 0)
+    ; ALL: [[MOV32rm1:%[0-9]+]] = MOV32rm %fixed-stack.1, 1, _, 0, _ :: (invariant load 4 from %fixed-stack.1, align 0)
+    ; ALL: MOV32mr [[MOV32rm]], 1, _, 0, _, [[MOV32rm1]] :: (store 4 into %ir.ptr1)
+    ; ALL: RET 0
     %2(p0) = G_FRAME_INDEX %fixed-stack.1
     %0(p0) = G_LOAD %2(p0) :: (invariant load 4 from %fixed-stack.1, align 0)
     %3(p0) = G_FRAME_INDEX %fixed-stack.0
index 131902d81a0039b7acfa6b3f5c443c9a024928dc..8d216418c9c4565e5581704dd3f4d26b8c68f2c2 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=AVX512F
 --- |
   define <16 x i32> @test_load_v16i32_noalign(<16 x i32>* %p1) {
 ...
 ---
 name:            test_load_v16i32_noalign
-# AVX512F-LABEL: name:  test_load_v16i32_noalign
 alignment:       4
 legalized:       true
 regBankSelected: true
-# AVX512F:      registers:
-# AVX512F-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# AVX512F-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: vecr }
-# AVX512F:          %0 = COPY %rdi
-# AVX512F-NEXT:     %1 = VMOVUPSZrm %0, 1, _, 0, _ :: (load 64 from %ir.p1, align 1)
-# AVX512F-NEXT:     %zmm0 = COPY %1
-# AVX512F-NEXT:     RET 0, implicit %zmm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi
 
+    ; AVX512F-LABEL: name: test_load_v16i32_noalign
+    ; AVX512F: registers:
+    ; AVX512F-NEXT: id: 0, class: gr64
+    ; AVX512F-NEXT: id: 1, class: vr512
+    ; AVX512F: [[COPY:%[0-9]+]] = COPY %rdi
+    ; AVX512F: [[VMOVUPSZrm:%[0-9]+]] = VMOVUPSZrm [[COPY]], 1, _, 0, _ :: (load 64 from %ir.p1, align 1)
+    ; AVX512F: %zmm0 = COPY [[VMOVUPSZrm]]
+    ; AVX512F: RET 0, implicit %zmm0
     %0(p0) = COPY %rdi
     %1(<16 x s32>) = G_LOAD %0(p0) :: (load 64 from %ir.p1, align 1)
     %zmm0 = COPY %1(<16 x s32>)
@@ -49,24 +50,24 @@ body:             |
 ...
 ---
 name:            test_load_v16i32_align
-# AVX512F-LABEL: name:  test_load_v16i32_align
 alignment:       4
 legalized:       true
 regBankSelected: true
-# AVX512F:      registers:
-# AVX512F-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# AVX512F-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: vecr }
-# AVX512F:          %0 = COPY %rdi
-# AVX512F-NEXT:     %1 = VMOVUPSZrm %0, 1, _, 0, _ :: (load 64 from %ir.p1, align 32)
-# AVX512F-NEXT:     %zmm0 = COPY %1
-# AVX512F-NEXT:     RET 0, implicit %zmm0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi
 
+    ; AVX512F-LABEL: name: test_load_v16i32_align
+    ; AVX512F: registers:
+    ; AVX512F-NEXT: id: 0, class: gr64
+    ; AVX512F-NEXT: id: 1, class: vr512
+    ; AVX512F: [[COPY:%[0-9]+]] = COPY %rdi
+    ; AVX512F: [[VMOVUPSZrm:%[0-9]+]] = VMOVUPSZrm [[COPY]], 1, _, 0, _ :: (load 64 from %ir.p1, align 32)
+    ; AVX512F: %zmm0 = COPY [[VMOVUPSZrm]]
+    ; AVX512F: RET 0, implicit %zmm0
     %0(p0) = COPY %rdi
     %1(<16 x s32>) = G_LOAD %0(p0) :: (load 64 from %ir.p1, align 32)
     %zmm0 = COPY %1(<16 x s32>)
@@ -75,24 +76,24 @@ body:             |
 ...
 ---
 name:            test_store_v16i32_noalign
-# AVX512F-LABEL: name:  test_store_v16i32_noalign
 alignment:       4
 legalized:       true
 regBankSelected: true
-# AVX512F:      registers:
-# AVX512F-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# AVX512F-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: gpr }
-# AVX512F:          %0 = COPY %zmm0
-# AVX512F-NEXT:     %1 = COPY %rdi
-# AVX512F-NEXT:     VMOVUPSZmr %1, 1, _, 0, _, %0 :: (store 64 into %ir.p1, align 1)
-# AVX512F-NEXT:     RET 0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi, %zmm0
 
+    ; AVX512F-LABEL: name: test_store_v16i32_noalign
+    ; AVX512F: registers:
+    ; AVX512F-NEXT: id: 0, class: vr512
+    ; AVX512F-NEXT: id: 1, class: gr64
+    ; AVX512F: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; AVX512F: [[COPY1:%[0-9]+]] = COPY %rdi
+    ; AVX512F: VMOVUPSZmr [[COPY1]], 1, _, 0, _, [[COPY]] :: (store 64 into %ir.p1, align 1)
+    ; AVX512F: RET 0
     %0(<16 x s32>) = COPY %zmm0
     %1(p0) = COPY %rdi
     G_STORE %0(<16 x s32>), %1(p0) :: (store 64 into %ir.p1, align 1)
@@ -101,24 +102,24 @@ body:             |
 ...
 ---
 name:            test_store_v16i32_align
-# AVX512F-LABEL: name:  test_store_v16i32_align
 alignment:       4
 legalized:       true
 regBankSelected: true
-# AVX512F:      registers:
-# AVX512F-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# AVX512F-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: gpr }
-# AVX512F:          %0 = COPY %zmm0
-# AVX512F-NEXT:     %1 = COPY %rdi
-# AVX512F-NEXT:     VMOVUPSZmr %1, 1, _, 0, _, %0 :: (store 64 into %ir.p1, align 32)
-# AVX512F-NEXT:     RET 0
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi, %zmm0
 
+    ; AVX512F-LABEL: name: test_store_v16i32_align
+    ; AVX512F: registers:
+    ; AVX512F-NEXT: id: 0, class: vr512
+    ; AVX512F-NEXT: id: 1, class: gr64
+    ; AVX512F: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; AVX512F: [[COPY1:%[0-9]+]] = COPY %rdi
+    ; AVX512F: VMOVUPSZmr [[COPY1]], 1, _, 0, _, [[COPY]] :: (store 64 into %ir.p1, align 32)
+    ; AVX512F: RET 0
     %0(<16 x s32>) = COPY %zmm0
     %1(p0) = COPY %rdi
     G_STORE %0(<16 x s32>), %1(p0) :: (store 64 into %ir.p1, align 32)
index 8e31a904e3607167d89a22f976bc38dda39f8205..87ea38dd16fd50d166ee40a0954be00b64672d45 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx               -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=AVX
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f,+avx512vl -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=AVX512VL
 --- |
@@ -7,42 +8,42 @@
 ...
 ---
 name:            test_merge
-# AVX-LABEL: name:  test_merge
 #
-# AVX512VL-LABEL: name:  test_merge
 alignment:       4
 legalized:       true
 regBankSelected: true
-# AVX:           registers:
-# AVX-NEXT:        - { id: 0, class: vr128, preferred-register: '' }
-# AVX-NEXT:        - { id: 1, class: vr256, preferred-register: '' }
-# AVX-NEXT:        - { id: 2, class: vr256, preferred-register: '' }
-# AVX-NEXT:        - { id: 3, class: vr256, preferred-register: '' }
 #
-# AVX512VL:      registers:
-# AVX512VL-NEXT:   - { id: 0, class: vr128x, preferred-register: '' }
-# AVX512VL-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# AVX512VL-NEXT:   - { id: 2, class: vr256x, preferred-register: '' }
-# AVX512VL-NEXT:   - { id: 3, class: vr256x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
-# AVX:               %0 = IMPLICIT_DEF
-# AVX-NEXT:          undef %2.sub_xmm = COPY %0
-# AVX-NEXT:          %3 = VINSERTF128rr %2, %0, 1
-# AVX-NEXT:          %1 = COPY %3
-# AVX-NEXT:          %ymm0 = COPY %1
-# AVX-NEXT:          RET 0, implicit %ymm0
 #
-# AVX512VL:          %0 = IMPLICIT_DEF
-# AVX512VL-NEXT:     undef %2.sub_xmm = COPY %0
-# AVX512VL-NEXT:     %3 = VINSERTF32x4Z256rr %2, %0, 1
-# AVX512VL-NEXT:     %1 = COPY %3
-# AVX512VL-NEXT:     %ymm0 = COPY %1
-# AVX512VL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
 
+    ; AVX-LABEL: name: test_merge
+    ; AVX: registers:
+    ; AVX-NEXT: id: 0, class: vr128
+    ; AVX-NEXT: id: 1, class: vr256
+    ; AVX-NEXT: id: 2, class: vr256
+    ; AVX-NEXT: id: 3, class: vr256
+    ; AVX: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; AVX: undef %2.sub_xmm = COPY [[DEF]]
+    ; AVX: [[VINSERTF128rr:%[0-9]+]] = VINSERTF128rr %2, [[DEF]], 1
+    ; AVX: [[COPY:%[0-9]+]] = COPY [[VINSERTF128rr]]
+    ; AVX: %ymm0 = COPY [[COPY]]
+    ; AVX: RET 0, implicit %ymm0
+    ; AVX512VL-LABEL: name: test_merge
+    ; AVX512VL: registers:
+    ; AVX512VL-NEXT: id: 0, class: vr128x
+    ; AVX512VL-NEXT: id: 1, class: vr256x
+    ; AVX512VL-NEXT: id: 2, class: vr256x
+    ; AVX512VL-NEXT: id: 3, class: vr256x
+    ; AVX512VL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; AVX512VL: undef %2.sub_xmm = COPY [[DEF]]
+    ; AVX512VL: [[VINSERTF32x4Z256rr:%[0-9]+]] = VINSERTF32x4Z256rr %2, [[DEF]], 1
+    ; AVX512VL: [[COPY:%[0-9]+]] = COPY [[VINSERTF32x4Z256rr]]
+    ; AVX512VL: %ymm0 = COPY [[COPY]]
+    ; AVX512VL: RET 0, implicit %ymm0
     %0(<4 x s32>) = IMPLICIT_DEF
     %1(<8 x s32>) = G_MERGE_VALUES %0(<4 x s32>), %0(<4 x s32>)
     %ymm0 = COPY %1(<8 x s32>)
index a072d582e505f10b1c11c17b938fe559008da495..0cddb35ca405a628aa5ea2f6e245aa3090d8afa2 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 --- |
   define void @test_merge_v128() {
 ...
 ---
 name:            test_merge_v128
-# ALL-LABEL: name:  test_merge_v128
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 4, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 5, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
-# ALL:          %0 = IMPLICIT_DEF
-# ALL-NEXT:     undef %2.sub_xmm = COPY %0
-# ALL-NEXT:     %3 = VINSERTF32x4Zrr %2, %0, 1
-# ALL-NEXT:     %4 = VINSERTF32x4Zrr %3, %0, 2
-# ALL-NEXT:     %5 = VINSERTF32x4Zrr %4, %0, 3
-# ALL-NEXT:     %1 = COPY %5
-# ALL-NEXT:     %zmm0 = COPY %1
-# ALL-NEXT:     RET 0, implicit %zmm0
 body:             |
   bb.1 (%ir-block.0):
 
+    ; ALL-LABEL: name: test_merge_v128
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr128x
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL-NEXT: id: 3, class: vr512
+    ; ALL-NEXT: id: 4, class: vr512
+    ; ALL-NEXT: id: 5, class: vr512
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: undef %2.sub_xmm = COPY [[DEF]]
+    ; ALL: [[VINSERTF32x4Zrr:%[0-9]+]] = VINSERTF32x4Zrr %2, [[DEF]], 1
+    ; ALL: [[VINSERTF32x4Zrr1:%[0-9]+]] = VINSERTF32x4Zrr [[VINSERTF32x4Zrr]], [[DEF]], 2
+    ; ALL: [[VINSERTF32x4Zrr2:%[0-9]+]] = VINSERTF32x4Zrr [[VINSERTF32x4Zrr1]], [[DEF]], 3
+    ; ALL: [[COPY:%[0-9]+]] = COPY [[VINSERTF32x4Zrr2]]
+    ; ALL: %zmm0 = COPY [[COPY]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<4 x s32>) = IMPLICIT_DEF
     %1(<16 x s32>) = G_MERGE_VALUES %0(<4 x s32>), %0(<4 x s32>), %0(<4 x s32>), %0(<4 x s32>)
     %zmm0 = COPY %1(<16 x s32>)
@@ -44,27 +45,27 @@ body:             |
 ...
 ---
 name:            test_merge_v256
-# ALL-LABEL: name:  test_merge_v256
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr256x, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
-# ALL:          %0 = IMPLICIT_DEF
-# ALL-NEXT:     undef %2.sub_ymm = COPY %0
-# ALL-NEXT:     %3 = VINSERTF64x4Zrr %2, %0, 1
-# ALL-NEXT:     %1 = COPY %3
-# ALL-NEXT:     %zmm0 = COPY %1
-# ALL-NEXT:     RET 0, implicit %zmm0
 body:             |
   bb.1 (%ir-block.0):
 
+    ; ALL-LABEL: name: test_merge_v256
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr256x
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL-NEXT: id: 3, class: vr512
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: undef %2.sub_ymm = COPY [[DEF]]
+    ; ALL: [[VINSERTF64x4Zrr:%[0-9]+]] = VINSERTF64x4Zrr %2, [[DEF]], 1
+    ; ALL: [[COPY:%[0-9]+]] = COPY [[VINSERTF64x4Zrr]]
+    ; ALL: %zmm0 = COPY [[COPY]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<8 x s32>) = IMPLICIT_DEF
     %1(<16 x s32>) = G_MERGE_VALUES %0(<8 x s32>), %0(<8 x s32>)
     %zmm0 = COPY %1(<16 x s32>)
index 52dcb7ab19eb364d4eee6ffc758aeb7893e31359..58f830be960703398b5f6437ea3b4ab54a08a948 100644 (file)
@@ -1,4 +1,5 @@
-# RUN: llc -mtriple=x86_64-linux-gnu                                  -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL 
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
+# RUN: llc -mtriple=x86_64-linux-gnu                                  -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
   define i16 @test_mul_i16(i16 %arg1, i16 %arg2) {
 ...
 ---
 name:            test_mul_i16
-# ALL-LABEL: name:  test_mul_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:      body:             |
-# ALL:          %0 = COPY %di
-# ALL-NEXT:     %1 = COPY %si
-# ALL-NEXT:     %2 = IMUL16rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %ax = COPY %2
-# ALL-NEXT:     RET 0, implicit %ax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_mul_i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr16
+    ; ALL-NEXT: id: 1, class: gr16
+    ; ALL-NEXT: id: 2, class: gr16
+    ; ALL: [[COPY:%[0-9]+]] = COPY %di
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %si
+    ; ALL: [[IMUL16rr:%[0-9]+]] = IMUL16rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %ax = COPY [[IMUL16rr]]
+    ; ALL: RET 0, implicit %ax
     %0(s16) = COPY %di
     %1(s16) = COPY %si
     %2(s16) = G_MUL %0, %1
@@ -50,28 +50,27 @@ body:             |
 ...
 ---
 name:            test_mul_i32
-# ALL-LABEL: name:  test_mul_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:      body:             |
-# ALL:          %0 = COPY %edi
-# ALL-NEXT:     %1 = COPY %esi
-# ALL-NEXT:     %2 = IMUL32rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %eax = COPY %2
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_mul_i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gr32
+    ; ALL: [[COPY:%[0-9]+]] = COPY %edi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %esi
+    ; ALL: [[IMUL32rr:%[0-9]+]] = IMUL32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %eax = COPY [[IMUL32rr]]
+    ; ALL: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s32) = G_MUL %0, %1
@@ -81,28 +80,27 @@ body:             |
 ...
 ---
 name:            test_mul_i64
-# ALL-LABEL: name:  test_mul_i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
   - { id: 2, class: gpr }
-# ALL:      body:             |
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %rsi
-# ALL-NEXT:     %2 = IMUL64rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi, %rsi
 
+    ; ALL-LABEL: name: test_mul_i64
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64
+    ; ALL-NEXT: id: 1, class: gr64
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %rsi
+    ; ALL: [[IMUL64rr:%[0-9]+]] = IMUL64rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %rax = COPY [[IMUL64rr]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s64) = COPY %rsi
     %2(s64) = G_MUL %0, %1
index d3651ccd1ab92a752838277417ed114447630043..d00aa015152954dae6d58296541ef3e6ef10dd1f 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s
 
 --- |
 ...
 ---
 name:            test_mul_v8i16
-# CHECK-LABEL: name:  test_mul_v8i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr128, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = PMULLWrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %xmm0, %xmm1
 
+    ; CHECK-LABEL: name: test_mul_v8i16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr128
+    ; CHECK-NEXT: id: 1, class: vr128
+    ; CHECK-NEXT: id: 2, class: vr128
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; CHECK: [[PMULLWrr:%[0-9]+]] = PMULLWrr [[COPY]], [[COPY1]]
+    ; CHECK: %xmm0 = COPY [[PMULLWrr]]
+    ; CHECK: RET 0, implicit %xmm0
     %0(<8 x s16>) = COPY %xmm0
     %1(<8 x s16>) = COPY %xmm1
     %2(<8 x s16>) = G_MUL %0, %1
@@ -116,23 +121,27 @@ body:             |
 ...
 ---
 name:            test_mul_v8i16_avx
-# CHECK-LABEL: name:  test_mul_v8i16_avx
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr128, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLWrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %xmm0, %xmm1
 
+    ; CHECK-LABEL: name: test_mul_v8i16_avx
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr128
+    ; CHECK-NEXT: id: 1, class: vr128
+    ; CHECK-NEXT: id: 2, class: vr128
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; CHECK: [[VPMULLWrr:%[0-9]+]] = VPMULLWrr [[COPY]], [[COPY1]]
+    ; CHECK: %xmm0 = COPY [[VPMULLWrr]]
+    ; CHECK: RET 0, implicit %xmm0
     %0(<8 x s16>) = COPY %xmm0
     %1(<8 x s16>) = COPY %xmm1
     %2(<8 x s16>) = G_MUL %0, %1
@@ -142,23 +151,27 @@ body:             |
 ...
 ---
 name:            test_mul_v8i16_avx512bwvl
-# CHECK-LABEL: name:  test_mul_v8i16_avx512bwvl
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr128x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr128x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLWZ128rr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %xmm0, %xmm1
 
+    ; CHECK-LABEL: name: test_mul_v8i16_avx512bwvl
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr128x
+    ; CHECK-NEXT: id: 1, class: vr128x
+    ; CHECK-NEXT: id: 2, class: vr128x
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; CHECK: [[VPMULLWZ128rr:%[0-9]+]] = VPMULLWZ128rr [[COPY]], [[COPY1]]
+    ; CHECK: %xmm0 = COPY [[VPMULLWZ128rr]]
+    ; CHECK: RET 0, implicit %xmm0
     %0(<8 x s16>) = COPY %xmm0
     %1(<8 x s16>) = COPY %xmm1
     %2(<8 x s16>) = G_MUL %0, %1
@@ -168,23 +181,27 @@ body:             |
 ...
 ---
 name:            test_mul_v4i32
-# CHECK-LABEL: name:  test_mul_v4i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr128, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = PMULLDrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %xmm0, %xmm1
 
+    ; CHECK-LABEL: name: test_mul_v4i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr128
+    ; CHECK-NEXT: id: 1, class: vr128
+    ; CHECK-NEXT: id: 2, class: vr128
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; CHECK: [[PMULLDrr:%[0-9]+]] = PMULLDrr [[COPY]], [[COPY1]]
+    ; CHECK: %xmm0 = COPY [[PMULLDrr]]
+    ; CHECK: RET 0, implicit %xmm0
     %0(<4 x s32>) = COPY %xmm0
     %1(<4 x s32>) = COPY %xmm1
     %2(<4 x s32>) = G_MUL %0, %1
@@ -194,23 +211,27 @@ body:             |
 ...
 ---
 name:            test_mul_v4i32_avx
-# CHECK-LABEL: name:  test_mul_v4i32_avx
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr128, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr128, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLDrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %xmm0, %xmm1
 
+    ; CHECK-LABEL: name: test_mul_v4i32_avx
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr128
+    ; CHECK-NEXT: id: 1, class: vr128
+    ; CHECK-NEXT: id: 2, class: vr128
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; CHECK: [[VPMULLDrr:%[0-9]+]] = VPMULLDrr [[COPY]], [[COPY1]]
+    ; CHECK: %xmm0 = COPY [[VPMULLDrr]]
+    ; CHECK: RET 0, implicit %xmm0
     %0(<4 x s32>) = COPY %xmm0
     %1(<4 x s32>) = COPY %xmm1
     %2(<4 x s32>) = G_MUL %0, %1
@@ -220,23 +241,27 @@ body:             |
 ...
 ---
 name:            test_mul_v4i32_avx512vl
-# CHECK-LABEL: name:  test_mul_v4i32_avx512vl
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr128x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr128x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLDZ128rr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %xmm0, %xmm1
 
+    ; CHECK-LABEL: name: test_mul_v4i32_avx512vl
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr128x
+    ; CHECK-NEXT: id: 1, class: vr128x
+    ; CHECK-NEXT: id: 2, class: vr128x
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; CHECK: [[VPMULLDZ128rr:%[0-9]+]] = VPMULLDZ128rr [[COPY]], [[COPY1]]
+    ; CHECK: %xmm0 = COPY [[VPMULLDZ128rr]]
+    ; CHECK: RET 0, implicit %xmm0
     %0(<4 x s32>) = COPY %xmm0
     %1(<4 x s32>) = COPY %xmm1
     %2(<4 x s32>) = G_MUL %0, %1
@@ -246,23 +271,27 @@ body:             |
 ...
 ---
 name:            test_mul_v2i64
-# CHECK-LABEL: name:  test_mul_v2i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr128x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr128x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLQZ128rr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %xmm0, %xmm1
 
+    ; CHECK-LABEL: name: test_mul_v2i64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr128x
+    ; CHECK-NEXT: id: 1, class: vr128x
+    ; CHECK-NEXT: id: 2, class: vr128x
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %xmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %xmm1
+    ; CHECK: [[VPMULLQZ128rr:%[0-9]+]] = VPMULLQZ128rr [[COPY]], [[COPY1]]
+    ; CHECK: %xmm0 = COPY [[VPMULLQZ128rr]]
+    ; CHECK: RET 0, implicit %xmm0
     %0(<2 x s64>) = COPY %xmm0
     %1(<2 x s64>) = COPY %xmm1
     %2(<2 x s64>) = G_MUL %0, %1
@@ -272,23 +301,27 @@ body:             |
 ...
 ---
 name:            test_mul_v16i16
-# CHECK-LABEL: name:  test_mul_v16i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr256, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr256, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr256, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLWYrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; CHECK-LABEL: name: test_mul_v16i16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr256
+    ; CHECK-NEXT: id: 1, class: vr256
+    ; CHECK-NEXT: id: 2, class: vr256
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %ymm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %ymm1
+    ; CHECK: [[VPMULLWYrr:%[0-9]+]] = VPMULLWYrr [[COPY]], [[COPY1]]
+    ; CHECK: %ymm0 = COPY [[VPMULLWYrr]]
+    ; CHECK: RET 0, implicit %ymm0
     %0(<16 x s16>) = COPY %ymm0
     %1(<16 x s16>) = COPY %ymm1
     %2(<16 x s16>) = G_MUL %0, %1
@@ -298,23 +331,27 @@ body:             |
 ...
 ---
 name:            test_mul_v16i16_avx512bwvl
-# CHECK-LABEL: name:  test_mul_v16i16_avx512bwvl
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr256x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr256x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLWZ256rr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; CHECK-LABEL: name: test_mul_v16i16_avx512bwvl
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr256x
+    ; CHECK-NEXT: id: 1, class: vr256x
+    ; CHECK-NEXT: id: 2, class: vr256x
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %ymm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %ymm1
+    ; CHECK: [[VPMULLWZ256rr:%[0-9]+]] = VPMULLWZ256rr [[COPY]], [[COPY1]]
+    ; CHECK: %ymm0 = COPY [[VPMULLWZ256rr]]
+    ; CHECK: RET 0, implicit %ymm0
     %0(<16 x s16>) = COPY %ymm0
     %1(<16 x s16>) = COPY %ymm1
     %2(<16 x s16>) = G_MUL %0, %1
@@ -324,23 +361,27 @@ body:             |
 ...
 ---
 name:            test_mul_v8i32
-# CHECK-LABEL: name:  test_mul_v8i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr256, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr256, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr256, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLDYrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; CHECK-LABEL: name: test_mul_v8i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr256
+    ; CHECK-NEXT: id: 1, class: vr256
+    ; CHECK-NEXT: id: 2, class: vr256
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %ymm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %ymm1
+    ; CHECK: [[VPMULLDYrr:%[0-9]+]] = VPMULLDYrr [[COPY]], [[COPY1]]
+    ; CHECK: %ymm0 = COPY [[VPMULLDYrr]]
+    ; CHECK: RET 0, implicit %ymm0
     %0(<8 x s32>) = COPY %ymm0
     %1(<8 x s32>) = COPY %ymm1
     %2(<8 x s32>) = G_MUL %0, %1
@@ -350,23 +391,27 @@ body:             |
 ...
 ---
 name:            test_mul_v8i32_avx512vl
-# CHECK-LABEL: name:  test_mul_v8i32_avx512vl
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr256x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr256x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLDZ256rr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; CHECK-LABEL: name: test_mul_v8i32_avx512vl
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr256x
+    ; CHECK-NEXT: id: 1, class: vr256x
+    ; CHECK-NEXT: id: 2, class: vr256x
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %ymm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %ymm1
+    ; CHECK: [[VPMULLDZ256rr:%[0-9]+]] = VPMULLDZ256rr [[COPY]], [[COPY1]]
+    ; CHECK: %ymm0 = COPY [[VPMULLDZ256rr]]
+    ; CHECK: RET 0, implicit %ymm0
     %0(<8 x s32>) = COPY %ymm0
     %1(<8 x s32>) = COPY %ymm1
     %2(<8 x s32>) = G_MUL %0, %1
@@ -376,23 +421,27 @@ body:             |
 ...
 ---
 name:            test_mul_v4i64
-# CHECK-LABEL: name:  test_mul_v4i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr256x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr256x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLQZ256rr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %ymm0, %ymm1
 
+    ; CHECK-LABEL: name: test_mul_v4i64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr256x
+    ; CHECK-NEXT: id: 1, class: vr256x
+    ; CHECK-NEXT: id: 2, class: vr256x
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %ymm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %ymm1
+    ; CHECK: [[VPMULLQZ256rr:%[0-9]+]] = VPMULLQZ256rr [[COPY]], [[COPY1]]
+    ; CHECK: %ymm0 = COPY [[VPMULLQZ256rr]]
+    ; CHECK: RET 0, implicit %ymm0
     %0(<4 x s64>) = COPY %ymm0
     %1(<4 x s64>) = COPY %ymm1
     %2(<4 x s64>) = G_MUL %0, %1
@@ -402,23 +451,27 @@ body:             |
 ...
 ---
 name:            test_mul_v32i16
-# CHECK-LABEL: name:  test_mul_v32i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLWZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; CHECK-LABEL: name: test_mul_v32i16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr512
+    ; CHECK-NEXT: id: 1, class: vr512
+    ; CHECK-NEXT: id: 2, class: vr512
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; CHECK: [[VPMULLWZrr:%[0-9]+]] = VPMULLWZrr [[COPY]], [[COPY1]]
+    ; CHECK: %zmm0 = COPY [[VPMULLWZrr]]
+    ; CHECK: RET 0, implicit %zmm0
     %0(<32 x s16>) = COPY %zmm0
     %1(<32 x s16>) = COPY %zmm1
     %2(<32 x s16>) = G_MUL %0, %1
@@ -428,23 +481,27 @@ body:             |
 ...
 ---
 name:            test_mul_v16i32
-# CHECK-LABEL: name:  test_mul_v16i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLDZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; CHECK-LABEL: name: test_mul_v16i32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr512
+    ; CHECK-NEXT: id: 1, class: vr512
+    ; CHECK-NEXT: id: 2, class: vr512
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; CHECK: [[VPMULLDZrr:%[0-9]+]] = VPMULLDZrr [[COPY]], [[COPY1]]
+    ; CHECK: %zmm0 = COPY [[VPMULLDZrr]]
+    ; CHECK: RET 0, implicit %zmm0
     %0(<16 x s32>) = COPY %zmm0
     %1(<16 x s32>) = COPY %zmm1
     %2(<16 x s32>) = G_MUL %0, %1
@@ -454,23 +511,27 @@ body:             |
 ...
 ---
 name:            test_mul_v8i64
-# CHECK-LABEL: name:  test_mul_v8i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# CHECK-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# CHECK:          %2 = VPMULLQZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; CHECK-LABEL: name: test_mul_v8i64
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: vr512
+    ; CHECK-NEXT: id: 1, class: vr512
+    ; CHECK-NEXT: id: 2, class: vr512
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; CHECK: [[VPMULLQZrr:%[0-9]+]] = VPMULLQZrr [[COPY]], [[COPY1]]
+    ; CHECK: %zmm0 = COPY [[VPMULLQZrr]]
+    ; CHECK: RET 0, implicit %zmm0
     %0(<8 x s64>) = COPY %zmm0
     %1(<8 x s64>) = COPY %zmm1
     %2(<8 x s64>) = G_MUL %0, %1
index 1e53720328c4f7318f42073865fef67ed5bb78f5..bbd877d21fbb356930f349c72dfbbad4e0454f27 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu                                  -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
 ...
 ---
 name:            test_or_i8
-# ALL-LABEL: name:  test_or_i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -40,15 +36,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %dil
-# ALL-NEXT:     %1 = COPY %sil
-# ALL-NEXT:     %2 = OR8rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %al = COPY %2
-# ALL-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_or_i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL-NEXT: id: 1, class: gr8
+    ; ALL-NEXT: id: 2, class: gr8
+    ; ALL: [[COPY:%[0-9]+]] = COPY %dil
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %sil
+    ; ALL: [[OR8rr:%[0-9]+]] = OR8rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %al = COPY [[OR8rr]]
+    ; ALL: RET 0, implicit %al
     %0(s8) = COPY %dil
     %1(s8) = COPY %sil
     %2(s8) = G_OR %0, %1
@@ -58,14 +59,9 @@ body:             |
 ...
 ---
 name:            test_or_i16
-# ALL-LABEL: name:  test_or_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -74,15 +70,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %di
-# ALL-NEXT:     %1 = COPY %si
-# ALL-NEXT:     %2 = OR16rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %ax = COPY %2
-# ALL-NEXT:     RET 0, implicit %ax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_or_i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr16
+    ; ALL-NEXT: id: 1, class: gr16
+    ; ALL-NEXT: id: 2, class: gr16
+    ; ALL: [[COPY:%[0-9]+]] = COPY %di
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %si
+    ; ALL: [[OR16rr:%[0-9]+]] = OR16rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %ax = COPY [[OR16rr]]
+    ; ALL: RET 0, implicit %ax
     %0(s16) = COPY %di
     %1(s16) = COPY %si
     %2(s16) = G_OR %0, %1
@@ -92,14 +93,9 @@ body:             |
 ...
 ---
 name:            test_or_i32
-# ALL-LABEL: name:  test_or_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -108,15 +104,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %edi
-# ALL-NEXT:     %1 = COPY %esi
-# ALL-NEXT:     %2 = OR32rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %eax = COPY %2
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_or_i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gr32
+    ; ALL: [[COPY:%[0-9]+]] = COPY %edi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %esi
+    ; ALL: [[OR32rr:%[0-9]+]] = OR32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %eax = COPY [[OR32rr]]
+    ; ALL: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s32) = G_OR %0, %1
@@ -126,14 +127,9 @@ body:             |
 ...
 ---
 name:            test_or_i64
-# ALL-LABEL: name:  test_or_i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -142,15 +138,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %rsi
-# ALL-NEXT:     %2 = OR64rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi, %rsi
 
+    ; ALL-LABEL: name: test_or_i64
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64
+    ; ALL-NEXT: id: 1, class: gr64
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %rsi
+    ; ALL: [[OR64rr:%[0-9]+]] = OR64rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %rax = COPY [[OR64rr]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s64) = COPY %rsi
     %2(s64) = G_OR %0, %1
index 828a243b26567497d3b68d4b0f764e659116b3ee..b32910ce725d17ce740881601efc973bc7cb0136 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
 ...
 ---
 name:            test_sub_v64i8
-# ALL-LABEL: name:  test_sub_v64i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPSUBBZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_sub_v64i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPSUBBZrr:%[0-9]+]] = VPSUBBZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPSUBBZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<64 x s8>) = COPY %zmm0
     %1(<64 x s8>) = COPY %zmm1
     %2(<64 x s8>) = G_SUB %0, %1
@@ -52,23 +57,27 @@ body:             |
 ...
 ---
 name:            test_sub_v32i16
-# ALL-LABEL: name:  test_sub_v32i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPSUBWZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_sub_v32i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPSUBWZrr:%[0-9]+]] = VPSUBWZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPSUBWZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<32 x s16>) = COPY %zmm0
     %1(<32 x s16>) = COPY %zmm1
     %2(<32 x s16>) = G_SUB %0, %1
@@ -78,23 +87,27 @@ body:             |
 ...
 ---
 name:            test_sub_v16i32
-# ALL-LABEL: name:  test_sub_v16i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPSUBDZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_sub_v16i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPSUBDZrr:%[0-9]+]] = VPSUBDZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPSUBDZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<16 x s32>) = COPY %zmm0
     %1(<16 x s32>) = COPY %zmm1
     %2(<16 x s32>) = G_SUB %0, %1
@@ -104,23 +117,27 @@ body:             |
 ...
 ---
 name:            test_sub_v8i64
-# ALL-LABEL: name:  test_sub_v8i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr512, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %2 = VPSUBQZrr %0, %1
 body:             |
   bb.1 (%ir-block.0):
     liveins: %zmm0, %zmm1
 
+    ; ALL-LABEL: name: test_sub_v8i64
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr512
+    ; ALL-NEXT: id: 2, class: vr512
+    ; ALL: [[COPY:%[0-9]+]] = COPY %zmm0
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %zmm1
+    ; ALL: [[VPSUBQZrr:%[0-9]+]] = VPSUBQZrr [[COPY]], [[COPY1]]
+    ; ALL: %zmm0 = COPY [[VPSUBQZrr]]
+    ; ALL: RET 0, implicit %zmm0
     %0(<8 x s64>) = COPY %zmm0
     %1(<8 x s64>) = COPY %zmm1
     %2(<8 x s64>) = G_SUB %0, %1
index 4df585628ddc55c81be6bf42173f355a301e8ab1..ebb28e7178238391cf9302af91b0b553fd058f36 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=CHECK
 --- |
   define i1 @trunc_i32toi1(i32 %a) {
 ...
 ---
 name:            trunc_i32toi1
-# CHECK-LABEL: name:  trunc_i32toi1
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %0.sub_8bit
-# CHECK-NEXT:     %al = COPY %1
-# CHECK-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; CHECK-LABEL: name: trunc_i32toi1
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr8
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_8bit
+    ; CHECK: %al = COPY [[COPY1]]
+    ; CHECK: RET 0, implicit %al
     %0(s32) = COPY %edi
     %1(s1) = G_TRUNC %0(s32)
     %al = COPY %1(s1)
@@ -59,24 +60,24 @@ body:             |
 ...
 ---
 name:            trunc_i32toi8
-# CHECK-LABEL: name:  trunc_i32toi8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %0.sub_8bit
-# CHECK-NEXT:     %al = COPY %1
-# CHECK-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; CHECK-LABEL: name: trunc_i32toi8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr8
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_8bit
+    ; CHECK: %al = COPY [[COPY1]]
+    ; CHECK: RET 0, implicit %al
     %0(s32) = COPY %edi
     %1(s8) = G_TRUNC %0(s32)
     %al = COPY %1(s8)
@@ -85,24 +86,24 @@ body:             |
 ...
 ---
 name:            trunc_i32toi16
-# CHECK-LABEL: name:  trunc_i32toi16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:          %0 = COPY %edi
-# CHECK-NEXT:     %1 = COPY %0.sub_16bit
-# CHECK-NEXT:     %ax = COPY %1
-# CHECK-NEXT:     RET 0, implicit %ax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; CHECK-LABEL: name: trunc_i32toi16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr32
+    ; CHECK-NEXT: id: 1, class: gr16
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %edi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_16bit
+    ; CHECK: %ax = COPY [[COPY1]]
+    ; CHECK: RET 0, implicit %ax
     %0(s32) = COPY %edi
     %1(s16) = G_TRUNC %0(s32)
     %ax = COPY %1(s16)
@@ -111,24 +112,24 @@ body:             |
 ...
 ---
 name:            trunc_i64toi8
-# CHECK-LABEL: name:  trunc_i64toi8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr64_with_sub_8bit, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:          %0 = COPY %rdi
-# CHECK-NEXT:     %1 = COPY %0.sub_8bit
-# CHECK-NEXT:     %al = COPY %1
-# CHECK-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi
 
+    ; CHECK-LABEL: name: trunc_i64toi8
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64_with_sub_8bit
+    ; CHECK-NEXT: id: 1, class: gr8
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %rdi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_8bit
+    ; CHECK: %al = COPY [[COPY1]]
+    ; CHECK: RET 0, implicit %al
     %0(s64) = COPY %rdi
     %1(s8) = G_TRUNC %0(s64)
     %al = COPY %1(s8)
@@ -137,24 +138,24 @@ body:             |
 ...
 ---
 name:            trunc_i64toi16
-# CHECK-LABEL: name:  trunc_i64toi16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:          %0 = COPY %rdi
-# CHECK-NEXT:     %1 = COPY %0.sub_16bit
-# CHECK-NEXT:     %ax = COPY %1
-# CHECK-NEXT:     RET 0, implicit %ax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi
 
+    ; CHECK-LABEL: name: trunc_i64toi16
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK-NEXT: id: 1, class: gr16
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %rdi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_16bit
+    ; CHECK: %ax = COPY [[COPY1]]
+    ; CHECK: RET 0, implicit %ax
     %0(s64) = COPY %rdi
     %1(s16) = G_TRUNC %0(s64)
     %ax = COPY %1(s16)
@@ -163,24 +164,24 @@ body:             |
 ...
 ---
 name:            trunc_i64toi32
-# CHECK-LABEL: name:  trunc_i64toi32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# CHECK:      registers:
-# CHECK-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# CHECK-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr }
   - { id: 1, class: gpr }
-# CHECK:          %0 = COPY %rdi
-# CHECK-NEXT:     %1 = COPY %0.sub_32bit
-# CHECK-NEXT:     %eax = COPY %1
-# CHECK-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi
 
+    ; CHECK-LABEL: name: trunc_i64toi32
+    ; CHECK: registers:
+    ; CHECK-NEXT: id: 0, class: gr64
+    ; CHECK-NEXT: id: 1, class: gr32
+    ; CHECK: [[COPY:%[0-9]+]] = COPY %rdi
+    ; CHECK: [[COPY1:%[0-9]+]] = COPY [[COPY]].sub_32bit
+    ; CHECK: %eax = COPY [[COPY1]]
+    ; CHECK: RET 0, implicit %eax
     %0(s64) = COPY %rdi
     %1(s32) = G_TRUNC %0(s64)
     %eax = COPY %1(s32)
index 00fb75b7e20b8bdd480e7a5cc864c57935d445a7..2099c2ccff0dca7d85860df397f2eda2d7193294 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 --- |
 
 ...
 ---
 name:            test
-# ALL-LABEL: name:  test
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
 liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = IMPLICIT_DEF
-# ALL-NEXT:     %al = COPY %0
-# ALL-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
+    ; ALL-LABEL: name: test
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: %al = COPY [[DEF]]
+    ; ALL: RET 0, implicit %al
     %0(s8) = G_IMPLICIT_DEF
     %al = COPY %0(s8)
     RET 0, implicit %al
@@ -37,14 +38,9 @@ body:             |
 ...
 ---
 name:            test2
-# ALL-LABEL: name:  test2
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -53,15 +49,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %dil
-# ALL-NEXT:     %1 = IMPLICIT_DEF
-# ALL-NEXT:     %2 = ADD8rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %al = COPY %2
-# ALL-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi
 
+    ; ALL-LABEL: name: test2
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL-NEXT: id: 1, class: gr8
+    ; ALL-NEXT: id: 2, class: gr8
+    ; ALL: [[COPY:%[0-9]+]] = COPY %dil
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: [[ADD8rr:%[0-9]+]] = ADD8rr [[COPY]], [[DEF]], implicit-def %eflags
+    ; ALL: %al = COPY [[ADD8rr]]
+    ; ALL: RET 0, implicit %al
     %0(s8) = COPY %dil
     %1(s8) = G_IMPLICIT_DEF
     %2(s8) = G_ADD %0, %1
index 09dc5344796f9d5d636ff483c02e004b82327572..c0aafdd45cfd5a8f584962805152ac501c883867 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx               -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=AVX
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f,+avx512vl -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=AVX512VL
 --- |
@@ -8,41 +9,41 @@
 ...
 ---
 name:            test_unmerge
-# AVX-LABEL: name:  test_unmerge
 #
-# AVX512VL-LABEL: name:  test_unmerge
 alignment:       4
 legalized:       true
 regBankSelected: true
-# AVX:           registers:
-# AVX-NEXT:        - { id: 0, class: vr256, preferred-register: '' }
-# AVX-NEXT:        - { id: 1, class: vr128, preferred-register: '' }
-# AVX-NEXT:        - { id: 2, class: vr128, preferred-register: '' }
 #
-# AVX512VL:      registers:
-# AVX512VL-NEXT:   - { id: 0, class: vr256x, preferred-register: '' }
-# AVX512VL-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# AVX512VL-NEXT:   - { id: 2, class: vr128x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# AVX:               %0 = IMPLICIT_DEF
-# AVX-NEXT:          %1 = COPY %0.sub_xmm
-# AVX-NEXT:          %2 = VEXTRACTF128rr %0, 1
-# AVX-NEXT:          %xmm0 = COPY %1
-# AVX-NEXT:          %xmm1 = COPY %2
-# AVX-NEXT:          RET 0, implicit %xmm0, implicit %xmm1
 #
-# AVX512VL:          %0 = IMPLICIT_DEF
-# AVX512VL-NEXT:     %1 = COPY %0.sub_xmm
-# AVX512VL-NEXT:     %2 = VEXTRACTF32x4Z256rr %0, 1
-# AVX512VL-NEXT:     %xmm0 = COPY %1
-# AVX512VL-NEXT:     %xmm1 = COPY %2
-# AVX512VL-NEXT:     RET 0, implicit %xmm0, implicit %xmm1
 body:             |
   bb.1 (%ir-block.0):
 
+    ; AVX-LABEL: name: test_unmerge
+    ; AVX: registers:
+    ; AVX-NEXT: id: 0, class: vr256
+    ; AVX-NEXT: id: 1, class: vr128
+    ; AVX-NEXT: id: 2, class: vr128
+    ; AVX: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; AVX: [[COPY:%[0-9]+]] = COPY [[DEF]].sub_xmm
+    ; AVX: [[VEXTRACTF128rr:%[0-9]+]] = VEXTRACTF128rr [[DEF]], 1
+    ; AVX: %xmm0 = COPY [[COPY]]
+    ; AVX: %xmm1 = COPY [[VEXTRACTF128rr]]
+    ; AVX: RET 0, implicit %xmm0, implicit %xmm1
+    ; AVX512VL-LABEL: name: test_unmerge
+    ; AVX512VL: registers:
+    ; AVX512VL-NEXT: id: 0, class: vr256x
+    ; AVX512VL-NEXT: id: 1, class: vr128x
+    ; AVX512VL-NEXT: id: 2, class: vr128x
+    ; AVX512VL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; AVX512VL: [[COPY:%[0-9]+]] = COPY [[DEF]].sub_xmm
+    ; AVX512VL: [[VEXTRACTF32x4Z256rr:%[0-9]+]] = VEXTRACTF32x4Z256rr [[DEF]], 1
+    ; AVX512VL: %xmm0 = COPY [[COPY]]
+    ; AVX512VL: %xmm1 = COPY [[VEXTRACTF32x4Z256rr]]
+    ; AVX512VL: RET 0, implicit %xmm0, implicit %xmm1
     %0(<8 x s32>) = IMPLICIT_DEF
     %1(<4 x s32>), %2(<4 x s32>) = G_UNMERGE_VALUES %0(<8 x s32>)
     %xmm0 = COPY %1(<4 x s32>)
index d7d64c69a846ab34a4201ce2d9b67432da2f5463..451c3dfd76fb1c8bc5d849e208a34d06ea50ad25 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 --- |
   define void @test_unmerge_v128() {
 ...
 ---
 name:            test_unmerge_v128
-# ALL-LABEL: name:  test_unmerge_v128
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 3, class: vr128x, preferred-register: '' }
-# ALL-NEXT:   - { id: 4, class: vr128x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
   - { id: 3, class: vecr }
   - { id: 4, class: vecr }
-# ALL:          %0 = IMPLICIT_DEF
-# ALL-NEXT:     %1 = COPY %0.sub_xmm
-# ALL-NEXT:     %2 = VEXTRACTF32x4Zrr %0, 1
-# ALL-NEXT:     %3 = VEXTRACTF32x4Zrr %0, 2
-# ALL-NEXT:     %4 = VEXTRACTF32x4Zrr %0, 3
-# ALL-NEXT:     %xmm0 = COPY %1
-# ALL-NEXT:     RET 0, implicit %xmm0
 body:             |
   bb.1 (%ir-block.0):
 
+    ; ALL-LABEL: name: test_unmerge_v128
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr128x
+    ; ALL-NEXT: id: 2, class: vr128x
+    ; ALL-NEXT: id: 3, class: vr128x
+    ; ALL-NEXT: id: 4, class: vr128x
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: [[COPY:%[0-9]+]] = COPY [[DEF]].sub_xmm
+    ; ALL: [[VEXTRACTF32x4Zrr:%[0-9]+]] = VEXTRACTF32x4Zrr [[DEF]], 1
+    ; ALL: [[VEXTRACTF32x4Zrr1:%[0-9]+]] = VEXTRACTF32x4Zrr [[DEF]], 2
+    ; ALL: [[VEXTRACTF32x4Zrr2:%[0-9]+]] = VEXTRACTF32x4Zrr [[DEF]], 3
+    ; ALL: %xmm0 = COPY [[COPY]]
+    ; ALL: RET 0, implicit %xmm0
     %0(<16 x s32>) = IMPLICIT_DEF
     %1(<4 x s32>), %2(<4 x s32>), %3(<4 x s32>), %4(<4 x s32>) = G_UNMERGE_VALUES %0(<16 x s32>)
     %xmm0 = COPY %1(<4 x s32>)
@@ -45,26 +46,26 @@ body:             |
 ...
 ---
 name:            test_unmerge_v256
-# ALL-LABEL: name:  test_unmerge_v256
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: vr512, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: vr256x, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: vr256x, preferred-register: '' }
 registers:
   - { id: 0, class: vecr }
   - { id: 1, class: vecr }
   - { id: 2, class: vecr }
-# ALL:          %0 = IMPLICIT_DEF
-# ALL-NEXT:     %1 = COPY %0.sub_ymm
-# ALL-NEXT:     %2 = VEXTRACTF64x4Zrr %0, 1
-# ALL-NEXT:     %ymm0 = COPY %1
-# ALL-NEXT:     RET 0, implicit %ymm0
 body:             |
   bb.1 (%ir-block.0):
 
+    ; ALL-LABEL: name: test_unmerge_v256
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: vr512
+    ; ALL-NEXT: id: 1, class: vr256x
+    ; ALL-NEXT: id: 2, class: vr256x
+    ; ALL: [[DEF:%[0-9]+]] = IMPLICIT_DEF
+    ; ALL: [[COPY:%[0-9]+]] = COPY [[DEF]].sub_ymm
+    ; ALL: [[VEXTRACTF64x4Zrr:%[0-9]+]] = VEXTRACTF64x4Zrr [[DEF]], 1
+    ; ALL: %ymm0 = COPY [[COPY]]
+    ; ALL: RET 0, implicit %ymm0
     %0(<16 x s32>) = IMPLICIT_DEF
     %1(<8 x s32>), %2(<8 x s32>) = G_UNMERGE_VALUES %0(<16 x s32>)
     %ymm0 = COPY %1(<8 x s32>)
index aef9b7419bc450aea9388f0cdb7ac39fa61f1ee5..07079eb001cd7b9abc6206a8ed59b65f3edef964 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -mtriple=x86_64-linux-gnu                                  -global-isel -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
 
 --- |
 ...
 ---
 name:            test_xor_i8
-# ALL-LABEL: name:  test_xor_i8
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr8, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr8, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -40,15 +36,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %dil
-# ALL-NEXT:     %1 = COPY %sil
-# ALL-NEXT:     %2 = XOR8rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %al = COPY %2
-# ALL-NEXT:     RET 0, implicit %al
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_xor_i8
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr8
+    ; ALL-NEXT: id: 1, class: gr8
+    ; ALL-NEXT: id: 2, class: gr8
+    ; ALL: [[COPY:%[0-9]+]] = COPY %dil
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %sil
+    ; ALL: [[XOR8rr:%[0-9]+]] = XOR8rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %al = COPY [[XOR8rr]]
+    ; ALL: RET 0, implicit %al
     %0(s8) = COPY %dil
     %1(s8) = COPY %sil
     %2(s8) = G_XOR %0, %1
@@ -58,14 +59,9 @@ body:             |
 ...
 ---
 name:            test_xor_i16
-# ALL-LABEL: name:  test_xor_i16
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr16, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr16, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -74,15 +70,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %di
-# ALL-NEXT:     %1 = COPY %si
-# ALL-NEXT:     %2 = XOR16rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %ax = COPY %2
-# ALL-NEXT:     RET 0, implicit %ax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_xor_i16
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr16
+    ; ALL-NEXT: id: 1, class: gr16
+    ; ALL-NEXT: id: 2, class: gr16
+    ; ALL: [[COPY:%[0-9]+]] = COPY %di
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %si
+    ; ALL: [[XOR16rr:%[0-9]+]] = XOR16rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %ax = COPY [[XOR16rr]]
+    ; ALL: RET 0, implicit %ax
     %0(s16) = COPY %di
     %1(s16) = COPY %si
     %2(s16) = G_XOR %0, %1
@@ -92,14 +93,9 @@ body:             |
 ...
 ---
 name:            test_xor_i32
-# ALL-LABEL: name:  test_xor_i32
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr32, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr32, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -108,15 +104,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %edi
-# ALL-NEXT:     %1 = COPY %esi
-# ALL-NEXT:     %2 = XOR32rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %eax = COPY %2
-# ALL-NEXT:     RET 0, implicit %eax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %edi, %esi
 
+    ; ALL-LABEL: name: test_xor_i32
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr32
+    ; ALL-NEXT: id: 1, class: gr32
+    ; ALL-NEXT: id: 2, class: gr32
+    ; ALL: [[COPY:%[0-9]+]] = COPY %edi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %esi
+    ; ALL: [[XOR32rr:%[0-9]+]] = XOR32rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %eax = COPY [[XOR32rr]]
+    ; ALL: RET 0, implicit %eax
     %0(s32) = COPY %edi
     %1(s32) = COPY %esi
     %2(s32) = G_XOR %0, %1
@@ -126,14 +127,9 @@ body:             |
 ...
 ---
 name:            test_xor_i64
-# ALL-LABEL: name:  test_xor_i64
 alignment:       4
 legalized:       true
 regBankSelected: true
-# ALL:      registers:
-# ALL-NEXT:   - { id: 0, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 1, class: gr64, preferred-register: '' }
-# ALL-NEXT:   - { id: 2, class: gr64, preferred-register: '' }
 registers:
   - { id: 0, class: gpr, preferred-register: '' }
   - { id: 1, class: gpr, preferred-register: '' }
@@ -142,15 +138,20 @@ liveins:
 fixedStack:
 stack:
 constants:
-# ALL:          %0 = COPY %rdi
-# ALL-NEXT:     %1 = COPY %rsi
-# ALL-NEXT:     %2 = XOR64rr %0, %1, implicit-def %eflags
-# ALL-NEXT:     %rax = COPY %2
-# ALL-NEXT:     RET 0, implicit %rax
 body:             |
   bb.1 (%ir-block.0):
     liveins: %rdi, %rsi
 
+    ; ALL-LABEL: name: test_xor_i64
+    ; ALL: registers:
+    ; ALL-NEXT: id: 0, class: gr64
+    ; ALL-NEXT: id: 1, class: gr64
+    ; ALL-NEXT: id: 2, class: gr64
+    ; ALL: [[COPY:%[0-9]+]] = COPY %rdi
+    ; ALL: [[COPY1:%[0-9]+]] = COPY %rsi
+    ; ALL: [[XOR64rr:%[0-9]+]] = XOR64rr [[COPY]], [[COPY1]], implicit-def %eflags
+    ; ALL: %rax = COPY [[XOR64rr]]
+    ; ALL: RET 0, implicit %rax
     %0(s64) = COPY %rdi
     %1(s64) = COPY %rsi
     %2(s64) = G_XOR %0, %1