]> granicus.if.org Git - llvm/commitdiff
[X86] Autogenerate checks in leaFixup32.mir and leaFixup64.mir. NFC
authorCraig Topper <craig.topper@intel.com>
Mon, 7 Oct 2019 06:50:56 +0000 (06:50 +0000)
committerCraig Topper <craig.topper@intel.com>
Mon, 7 Oct 2019 06:50:56 +0000 (06:50 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@373878 91177308-0d34-0410-b5e6-96231b3b80d8

test/CodeGen/X86/leaFixup32.mir
test/CodeGen/X86/leaFixup64.mir

index ede0df7c77d8e0ea3dc03d20e08231a3b2e1bdbc..23f3d7616966877a188c3c8a6587b9c12dec6694 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -run-pass x86-fixup-LEAs -mtriple=i386 -verify-machineinstrs -mcpu=corei7-avx -o - %s | FileCheck %s
 --- |
   ; ModuleID = 'test/CodeGen/X86/fixup-lea.ll'
   define i32 @test1lea_ebp_32() {
     ret i32 0
   }
+
   ;test2addi32_32: 3 operands LEA32r that can be replaced with 2 add instructions where ADD32ri32
   ; is chosen
   define i32 @test2addi32_32() {
     ret i32 0
   }
+
   ;test1mov1add_ebp_32: 2 operands LEA32r that can be replaced with 1 add 1 mov instructions
   ; where the base is rbp/r13/ebp register
   define i32 @test1mov1add_ebp_32() {
@@ -64,7 +65,7 @@
   define i32 @testleaadd_ebp_index2_32() {
     ret i32 0
   }
-  
+
   ;test_skip_opt_32: 3 operands LEA32r that can not be replaced with 2 instructions
   define i32 @test_skip_opt_32() {
     ret i32 0
@@ -84,10 +85,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -104,9 +105,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp
-    ; CHECK: $eax = ADD32rr $eax, $ebp
-    ; CHECK: $eax = ADD32ri8 $eax, -5
+
+    ; CHECK-LABEL: name: test2add_32
+    ; CHECK: liveins: $eax, $ebp
+    ; CHECK: $eax = ADD32rr $eax, $ebp, implicit-def $eflags
+    ; CHECK: $eax = ADD32ri8 $eax, -5, implicit-def $eflags
+    ; CHECK: RETQ $eax
     $eax = LEA32r killed $eax, 1, killed $ebp, -5, $noreg
     RETQ $eax
 
@@ -119,10 +123,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -139,9 +143,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp
-    ; CHECK: $ebp = ADD32rr $ebp, $eax
-    ; CHECK: $ebp = ADD32ri8 $ebp, -5
+
+    ; CHECK-LABEL: name: test2add_ebp_32
+    ; CHECK: liveins: $eax, $ebp
+    ; CHECK: $ebp = ADD32rr $ebp, $eax, implicit-def $eflags
+    ; CHECK: $ebp = ADD32ri8 $ebp, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebp
     $ebp = LEA32r killed $ebp, 1, killed $eax, -5, $noreg
     RETQ $ebp
 
@@ -154,10 +161,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -174,8 +181,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp
-    ; CHECK: $ebp = ADD32rr $ebp, $eax
+
+    ; CHECK-LABEL: name: test1add_ebp_32
+    ; CHECK: liveins: $eax, $ebp
+    ; CHECK: $ebp = ADD32rr $ebp, $eax, implicit-def $eflags
+    ; CHECK: RETQ $ebp
     $ebp = LEA32r killed $ebp, 1, killed $eax, 0, $noreg
     RETQ $ebp
 
@@ -188,11 +198,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebp' }
   - { reg: '$ebx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -209,9 +219,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp, $esi
-    ; CHECK: $ebx = LEA32r killed $eax, 1, killed $ebp, 0
-    ; CHECK: $ebx = ADD32ri8 $ebx, -5
+
+    ; CHECK-LABEL: name: testleaadd_32
+    ; CHECK: liveins: $eax, $ebp, $esi
+    ; CHECK: $ebx = LEA32r killed $eax, 1, killed $ebp, 0, $noreg
+    ; CHECK: $ebx = ADD32ri8 $ebx, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $ebx = LEA32r killed $eax, 1, killed $ebp, -5, $noreg
     RETQ $ebx
 
@@ -224,11 +237,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebp' }
   - { reg: '$ebx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -245,9 +258,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp
+
+    ; CHECK-LABEL: name: testleaadd_ebp_32
+    ; CHECK: liveins: $eax, $ebp
     ; CHECK: $ebx = LEA32r killed $eax, 1, killed $ebp, 0, $noreg
-    ; CHECK: $ebx = ADD32ri8  $ebx, -5
+    ; CHECK: $ebx = ADD32ri8 $ebx, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $ebx = LEA32r killed $ebp, 1, killed $eax, -5, $noreg
     RETQ $ebx
 
@@ -260,11 +276,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebp' }
   - { reg: '$ebx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -281,8 +297,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp
+
+    ; CHECK-LABEL: name: test1lea_ebp_32
+    ; CHECK: liveins: $eax, $ebp
     ; CHECK: $ebx = LEA32r killed $eax, 1, killed $ebp, 0, $noreg
+    ; CHECK: RETQ $ebx
     $ebx = LEA32r killed $ebp, 1, killed $eax, 0, $noreg
     RETQ $ebx
 
@@ -295,10 +314,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -315,9 +334,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp
-    ; CHECK: $eax = ADD32rr $eax, $ebp
-    ; CHECK: $eax = ADD32ri $eax, 129
+
+    ; CHECK-LABEL: name: test2addi32_32
+    ; CHECK: liveins: $eax, $ebp
+    ; CHECK: $eax = ADD32rr $eax, $ebp, implicit-def $eflags
+    ; CHECK: $eax = ADD32ri $eax, 129, implicit-def $eflags
+    ; CHECK: RETQ $eax
     $eax = LEA32r killed $eax, 1, killed $ebp, 129, $noreg
     RETQ $eax
 
@@ -330,11 +352,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$eax' }
   - { reg: '$ebx' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -351,9 +373,13 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp, $ebx
-    ; CHECK: $ebx = MOV32rr  $ebp
-    ; CHECK: $ebx = ADD32rr $ebx, $ebp
+
+    ; CHECK-LABEL: name: test1mov1add_ebp_32
+    ; CHECK: liveins: $eax, $ebp, $ebx
+    ; CHECK: $ebx = MOV32rr $ebp
+    ; CHECK: $ebx = ADD32rr $ebx, $ebp, implicit-def $eflags
+    ; CHECK: $ebx = LEA32r killed $ebp, 1, $ebp, 0, $noreg
+    ; CHECK: RETQ $ebx
     $ebx = LEA32r killed $ebp, 1, $ebp, 0, $noreg
     RETQ $ebx
 
@@ -366,10 +392,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$ebx' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -386,9 +412,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp, $ebx
+
+    ; CHECK-LABEL: name: testleaadd_ebp_index_32
+    ; CHECK: liveins: $eax, $ebp, $ebx
     ; CHECK: $ebx = LEA32r $noreg, 1, $ebp, 5, $noreg
-    ; CHECK: $ebx = ADD32rr $ebx, $ebp
+    ; CHECK: $ebx = ADD32rr $ebx, $ebp, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $ebx = LEA32r $ebp, 1, $ebp, 5, $noreg
     RETQ $ebx
 
@@ -401,10 +430,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$ebx' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -421,9 +450,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp, $ebx
+
+    ; CHECK-LABEL: name: testleaadd_ebp_index2_32
+    ; CHECK: liveins: $eax, $ebp, $ebx
     ; CHECK: $ebx = LEA32r $noreg, 4, $ebp, 5, $noreg
-    ; CHECK: $ebx = ADD32rr $ebx, $ebp
+    ; CHECK: $ebx = ADD32rr $ebx, $ebp, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $ebx = LEA32r $ebp, 4, $ebp, 5, $noreg
     RETQ $ebx
 
@@ -436,10 +468,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$ebx' }
   - { reg: '$ebp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -456,8 +488,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp, $ebx
+
+    ; CHECK-LABEL: name: test_skip_opt_32
+    ; CHECK: liveins: $eax, $ebp, $ebx
     ; CHECK: $ebp = LEA32r killed $ebp, 4, killed $ebp, 0, $noreg
+    ; CHECK: RETQ $ebp
     $ebp = LEA32r killed $ebp, 4, killed $ebp, 0, $noreg
     RETQ $ebp
 
@@ -470,10 +505,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$ebp' }
   - { reg: '$eax' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -488,12 +523,22 @@ frameInfo:
   hasVAStart:      false
   hasMustTailInVarArgFunc: false
 body:             |
+  ; CHECK-LABEL: name: test_skip_eflags_32
+  ; CHECK: bb.0 (%ir-block.0):
+  ; CHECK:   successors: %bb.1(0x80000000)
+  ; CHECK:   liveins: $eax, $ebp, $ebx
+  ; CHECK:   CMP32rr $eax, killed $ebx, implicit-def $eflags
+  ; CHECK:   $ebx = LEA32r killed $eax, 4, killed $eax, 5, $noreg
+  ; CHECK:   JCC_1 %bb.1, 4, implicit $eflags
+  ; CHECK:   RETQ $ebx
+  ; CHECK: bb.1:
+  ; CHECK:   liveins: $eax, $ebp, $ebx
+  ; CHECK:   $ebp = LEA32r killed $ebx, 4, killed $ebx, 0, $noreg
+  ; CHECK:   $ebp = ADD32ri8 $ebp, 5, implicit-def $eflags
+  ; CHECK:   RETQ $ebp
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp, $ebx
-    ; CHECK: $ebx = LEA32r killed $eax, 4, killed $eax, 5, $noreg
-    ; CHECK: $ebp = LEA32r killed $ebx, 4, killed $ebx, 0, $noreg
-    ; CHECK: $ebp = ADD32ri8 $ebp, 5
-   
+
     CMP32rr   $eax, killed $ebx, implicit-def $eflags
     $ebx = LEA32r killed $eax, 4, killed $eax, 5, $noreg
     JCC_1 %bb.1, 4, implicit $eflags
index 4e9c47b11fc49d785570be49bfc0456a0098f4d1..77be582225694e691b3b9bc03fa3b44cd7f4d519 100644 (file)
@@ -1,3 +1,4 @@
+# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
 # RUN: llc -run-pass x86-fixup-LEAs -mtriple=x86_64-gnu-unknown -verify-machineinstrs -mcpu=corei7-avx -o - %s | FileCheck %s
 --- |
   ; ModuleID = 'lea-2.ll'
   define i32 @test8() {
       ret i32 0
   }
+
   ;testleaaddi32_64_32: 3 operands LEA64_32r that can be replaced with 1 lea + 1 add instructions where
   ; ADD64ri32 is chosen
   define i32 @testleaaddi32_64_32() {
     ret i32 0
   }
+
   ;test1mov1add_rbp_64_32: 2 operands LEA64_32r cannot be replaced with 1 add 1 mov instructions
   ; where the base is rbp/r13/ebp register
   define i32 @test1mov1add_rbp_64_32() {
   define i32 @testleaadd_rbp_index2_64_32() {
     ret i32 0
   }
+
   ;test2addi32_64: 3 operands LEA64r that can be replaced with 2 add instructions where ADD64ri32
   ; is chosen
   define i32 @test2addi32_64() {
     ret i32 0
   }
+
   ;test1mov1add_rbp_64: 2 operands LEA64r that can be replaced with 1 add 1 mov instructions
   ; where the base is rbp/r13/ebp register
   define i32 @test1mov1add_rbp_64() {
@@ -157,10 +158,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -177,9 +178,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: testleaadd_64_32_1
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $eax = ADD32rr $eax, $ebp, implicit-def $eflags, implicit $rax, implicit $rbp
     ; CHECK: $eax = ADD32ri8 $eax, -5, implicit-def $eflags
+    ; CHECK: RETQ $eax
     $eax = LEA64_32r killed $rax, 1, killed $rbp, -5, $noreg
     RETQ $eax
 
@@ -192,10 +196,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -212,9 +216,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: testleaadd_rbp_64_32_1
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $ebp = ADD32rr $ebp, $eax, implicit-def $eflags, implicit $rbp, implicit $rax
     ; CHECK: $ebp = ADD32ri8 $ebp, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebp
     $ebp = LEA64_32r killed $rbp, 1, killed $rax, -5, $noreg
     RETQ $ebp
 
@@ -227,10 +234,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -247,8 +254,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: test1lea_rbp_64_32_1
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $ebp = ADD32rr $ebp, $eax, implicit-def $eflags, implicit $rbp, implicit $rax
+    ; CHECK: RETQ $ebp
     $ebp = LEA64_32r killed $rbp, 1, killed $rax, 0, $noreg
     RETQ $ebp
 
@@ -261,10 +271,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -281,9 +291,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
-    ; CHECK: $rax = ADD64rr $rax, $rbp
-    ; CHECK: $rax = ADD64ri8 $rax, -5
+
+    ; CHECK-LABEL: name: test2add_64
+    ; CHECK: liveins: $rax, $rbp
+    ; CHECK: $rax = ADD64rr $rax, $rbp, implicit-def $eflags
+    ; CHECK: $rax = ADD64ri8 $rax, -5, implicit-def $eflags
+    ; CHECK: RETQ $eax
     $rax = LEA64r killed $rax, 1, killed $rbp, -5, $noreg
     RETQ $eax
 
@@ -296,10 +309,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -316,9 +329,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
-    ; CHECK: $rbp = ADD64rr $rbp, $rax
-    ; CHECK: $rbp = ADD64ri8 $rbp, -5
+
+    ; CHECK-LABEL: name: test2add_rbp_64
+    ; CHECK: liveins: $rax, $rbp
+    ; CHECK: $rbp = ADD64rr $rbp, $rax, implicit-def $eflags
+    ; CHECK: $rbp = ADD64ri8 $rbp, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebp
     $rbp = LEA64r killed $rbp, 1, killed $rax, -5, $noreg
     RETQ $ebp
 
@@ -331,10 +347,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -351,8 +367,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
-    ; CHECK: $rbp = ADD64rr $rbp, $rax
+
+    ; CHECK-LABEL: name: test1add_rbp_64
+    ; CHECK: liveins: $rax, $rbp
+    ; CHECK: $rbp = ADD64rr $rbp, $rax, implicit-def $eflags
+    ; CHECK: RETQ $ebp
     $rbp = LEA64r killed $rbp, 1, killed $rax, 0, $noreg
     RETQ $ebp
 
@@ -365,11 +384,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
   - { reg: '$rbx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -386,9 +405,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: testleaadd_64_32
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $ebx = LEA64_32r killed $rax, 1, killed $rbp, 0, $noreg
-    ; CHECK: $ebx = ADD32ri8 $ebx, -5
+    ; CHECK: $ebx = ADD32ri8 $ebx, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $ebx = LEA64_32r killed $rax, 1, killed $rbp, -5, $noreg
     RETQ $ebx
 
@@ -401,11 +423,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
   - { reg: '$rbx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -422,9 +444,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: testleaadd_rbp_64_32
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $ebx = LEA64_32r killed $rax, 1, killed $rbp, 0, $noreg
-    ; CHECK: $ebx = ADD32ri8 $ebx, -5
+    ; CHECK: $ebx = ADD32ri8 $ebx, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $ebx = LEA64_32r killed $rbp, 1, killed $rax, -5, $noreg
     RETQ $ebx
 
@@ -437,11 +462,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
   - { reg: '$rbx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -458,8 +483,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: test1lea_rbp_64_32
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $ebx = LEA64_32r killed $rax, 1, killed $rbp, 0, $noreg
+    ; CHECK: RETQ $ebx
     $ebx = LEA64_32r killed $rbp, 1, killed $rax, 0, $noreg
     RETQ $ebx
 
@@ -472,11 +500,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
   - { reg: '$rbx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -493,9 +521,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: testleaadd_64
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $rbx = LEA64r killed $rax, 1, killed $rbp, 0, $noreg
-    ; CHECK: $rbx = ADD64ri8 $rbx, -5
+    ; CHECK: $rbx = ADD64ri8 $rbx, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $rbx = LEA64r killed $rax, 1, killed $rbp, -5, $noreg
     RETQ $ebx
 
@@ -508,11 +539,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
   - { reg: '$rbx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -529,9 +560,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: testleaadd_rbp_64
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $rbx = LEA64r killed $rax, 1, killed $rbp, 0, $noreg
-    ; CHECK: $rbx = ADD64ri8 $rbx, -5
+    ; CHECK: $rbx = ADD64ri8 $rbx, -5, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $rbx = LEA64r killed $rbp, 1, killed $rax, -5, $noreg
     RETQ $ebx
 
@@ -544,11 +578,11 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
   - { reg: '$rbx' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -565,8 +599,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: test1lea_rbp_64
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $rbx = LEA64r killed $rax, 1, killed $rbp, 0, $noreg
+    ; CHECK: RETQ $ebx
     $rbx = LEA64r killed $rbp, 1, killed $rax, 0, $noreg
     RETQ $ebx
 
@@ -579,10 +616,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rdi' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -599,8 +636,13 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rdi, $rbp
-    ; CHECK:  $r12 = LEA64r $noreg, 2, killed $r13, 5, $noreg
-    ; CHECK:  $r12 = ADD64rr $r12, killed $rbp
+    ; CHECK-LABEL: name: test8
+    ; CHECK: liveins: $rdi, $rbp
+    ; CHECK: $rbp = KILL $rbp, implicit-def $rbp
+    ; CHECK: $r13 = KILL $rdi, implicit-def $r13
+    ; CHECK: $r12 = LEA64r $noreg, 2, killed $r13, 5, $noreg
+    ; CHECK: $r12 = ADD64rr $r12, killed $rbp, implicit-def $eflags
+    ; CHECK: RETQ $r12
     $rbp = KILL $rbp, implicit-def $rbp
     $r13 = KILL $rdi, implicit-def $r13
     $r12 = LEA64r killed $rbp, 2, killed $r13, 5, $noreg
@@ -615,10 +657,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -635,9 +677,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
-    ; CHECK: $eax = ADD32rr $eax, $ebp, implicit-def $eflags
+
+    ; CHECK-LABEL: name: testleaaddi32_64_32
+    ; CHECK: liveins: $rax, $rbp
+    ; CHECK: $eax = ADD32rr $eax, $ebp, implicit-def $eflags, implicit $rax, implicit $rbp
     ; CHECK: $eax = ADD32ri $eax, 129, implicit-def $eflags
+    ; CHECK: RETQ $eax
     $eax = LEA64_32r killed $rax, 1, killed $rbp, 129, $noreg
     RETQ $eax
 
@@ -650,10 +695,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -670,8 +715,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
-    ; CHECK: $ebx = LEA64_32r killed $rbp, 1, killed $rbp, 0, $noreg
 
+    ; CHECK-LABEL: name: test1mov1add_rbp_64_32
+    ; CHECK: liveins: $rax, $rbp, $rbx
+    ; CHECK: $ebx = LEA64_32r killed $rbp, 1, killed $rbp, 0, $noreg
+    ; CHECK: RETQ $ebx
     $ebx = LEA64_32r killed $rbp, 1, killed $rbp, 0, $noreg
     RETQ $ebx
 
@@ -684,10 +732,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbx' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -704,8 +752,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
+
+    ; CHECK-LABEL: name: testleaadd_rbp_index_64_32
+    ; CHECK: liveins: $rax, $rbp, $rbx
     ; CHECK: $ebx = LEA64_32r killed $rbp, 1, killed $rbp, 5, $noreg
+    ; CHECK: RETQ $ebx
     $ebx = LEA64_32r killed $rbp, 1, killed $rbp, 5, $noreg
     RETQ $ebx
 
@@ -718,10 +769,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbx' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -738,8 +789,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $eax, $ebp, $ebx
+
+    ; CHECK-LABEL: name: testleaadd_rbp_index2_64_32
+    ; CHECK: liveins: $eax, $ebp, $ebx
     ; CHECK: $ebx = LEA64_32r killed $rbp, 4, killed $rbp, 5, $noreg
+    ; CHECK: RETQ $ebx
     $ebx = LEA64_32r killed $rbp, 4, killed $rbp, 5, $noreg
     RETQ $ebx
 
@@ -752,10 +806,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -772,9 +826,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp
+
+    ; CHECK-LABEL: name: test2addi32_64
+    ; CHECK: liveins: $rax, $rbp
     ; CHECK: $rax = ADD64rr $rax, $rbp, implicit-def $eflags
     ; CHECK: $rax = ADD64ri32 $rax, 129, implicit-def $eflags
+    ; CHECK: RETQ $eax
     $rax = LEA64r killed $rax, 1, killed $rbp, 129, $noreg
     RETQ $eax
 
@@ -787,10 +844,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rax' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -807,9 +864,13 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
+
+    ; CHECK-LABEL: name: test1mov1add_rbp_64
+    ; CHECK: liveins: $rax, $rbp, $rbx
     ; CHECK: $rbx = MOV64rr $rbp
-    ; CHECK: $rbx = ADD64rr $rbx, $rbp
+    ; CHECK: $rbx = ADD64rr $rbx, $rbp, implicit-def $eflags
+    ; CHECK: $rbx = LEA64r killed $rbp, 1, $rbp, 0, $noreg
+    ; CHECK: RETQ $ebx
     $rbx = LEA64r killed $rbp, 1, $rbp, 0, $noreg
     RETQ $ebx
 
@@ -822,10 +883,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbx' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -842,9 +903,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
-    ; CHECK: $rbx = LEA64r $noreg, 1,  $rbp, 5, $noreg
-    ; CHECK: $rbx = ADD64rr $rbx, $rbp
+
+    ; CHECK-LABEL: name: testleaadd_rbp_index_64
+    ; CHECK: liveins: $rax, $rbp, $rbx
+    ; CHECK: $rbx = LEA64r $noreg, 1, $rbp, 5, $noreg
+    ; CHECK: $rbx = ADD64rr $rbx, $rbp, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $rbx = LEA64r $rbp, 1, $rbp, 5, $noreg
     RETQ $ebx
 
@@ -857,10 +921,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbx' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -877,9 +941,12 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
+
+    ; CHECK-LABEL: name: testleaadd_rbp_index2_64
+    ; CHECK: liveins: $rax, $rbp, $rbx
     ; CHECK: $rbx = LEA64r $noreg, 4, $rbp, 5, $noreg
-    ; CHECK: $rbx = ADD64rr $rbx,  $rbp
+    ; CHECK: $rbx = ADD64rr $rbx, $rbp, implicit-def $eflags
+    ; CHECK: RETQ $ebx
     $rbx = LEA64r $rbp, 4,  $rbp, 5, $noreg
     RETQ $ebx
 
@@ -892,10 +959,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbx' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -912,8 +979,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
+
+    ; CHECK-LABEL: name: test_skip_opt_64
+    ; CHECK: liveins: $rax, $rbp, $rbx
     ; CHECK: $rbp = LEA64r killed $rbp, 4, killed $rbp, 0, $noreg
+    ; CHECK: RETQ $ebp
     $rbp = LEA64r killed $rbp, 4, killed $rbp, 0, $noreg
     RETQ $ebp
 
@@ -926,10 +996,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbp' }
   - { reg: '$rax' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -944,12 +1014,22 @@ frameInfo:
   hasVAStart:      false
   hasMustTailInVarArgFunc: false
 body:             |
+  ; CHECK-LABEL: name: test_skip_eflags_64
+  ; CHECK: bb.0 (%ir-block.0):
+  ; CHECK:   successors: %bb.1(0x80000000)
+  ; CHECK:   liveins: $rax, $rbp, $rbx
+  ; CHECK:   CMP64rr $rax, killed $rbx, implicit-def $eflags
+  ; CHECK:   $rbx = LEA64r killed $rax, 4, killed $rax, 5, $noreg
+  ; CHECK:   JCC_1 %bb.1, 4, implicit $eflags
+  ; CHECK:   RETQ $ebx
+  ; CHECK: bb.1:
+  ; CHECK:   liveins: $rax, $rbp, $rbx
+  ; CHECK:   $rbp = LEA64r killed $rbx, 4, killed $rbx, 0, $noreg
+  ; CHECK:   $rbp = ADD64ri8 $rbp, 5, implicit-def $eflags
+  ; CHECK:   RETQ $ebp
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
-    ; CHECK: $rbx = LEA64r killed $rax, 4, killed $rax, 5, $noreg
-    ; CHECK: $rbp = LEA64r killed $rbx, 4, killed $rbx, 0, $noreg
-    ; CHECK: $rbp = ADD64ri8 $rbp, 5
-   
+
     CMP64rr   $rax, killed $rbx, implicit-def $eflags
     $rbx = LEA64r killed $rax, 4, killed $rax, 5, $noreg
     JCC_1 %bb.1, 4, implicit $eflags
@@ -968,10 +1048,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbx' }
   - { reg: '$rbp' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -988,8 +1068,11 @@ frameInfo:
 body:             |
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
+
+    ; CHECK-LABEL: name: test_skip_opt_64_32
+    ; CHECK: liveins: $rax, $rbp, $rbx
     ; CHECK: $ebp = LEA64_32r killed $rbp, 4, killed $rbp, 0, $noreg
+    ; CHECK: RETQ $ebp
     $ebp = LEA64_32r killed $rbp, 4, killed $rbp, 0, $noreg
     RETQ $ebp
 
@@ -1002,10 +1085,10 @@ legalized:       false
 regBankSelected: false
 selected:        false
 tracksRegLiveness: true
-liveins:         
+liveins:
   - { reg: '$rbp' }
   - { reg: '$rax' }
-frameInfo:       
+frameInfo:
   isFrameAddressTaken: false
   isReturnAddressTaken: false
   hasStackMap:     false
@@ -1020,12 +1103,22 @@ frameInfo:
   hasVAStart:      false
   hasMustTailInVarArgFunc: false
 body:             |
+  ; CHECK-LABEL: name: test_skip_eflags_64_32
+  ; CHECK: bb.0 (%ir-block.0):
+  ; CHECK:   successors: %bb.1(0x80000000)
+  ; CHECK:   liveins: $rax, $rbp, $rbx
+  ; CHECK:   CMP64rr $rax, killed $rbx, implicit-def $eflags
+  ; CHECK:   $ebx = LEA64_32r killed $rax, 4, killed $rax, 5, $noreg
+  ; CHECK:   JCC_1 %bb.1, 4, implicit $eflags
+  ; CHECK:   RETQ $ebx
+  ; CHECK: bb.1:
+  ; CHECK:   liveins: $rax, $rbp, $rbx
+  ; CHECK:   $ebp = LEA64_32r killed $rbx, 4, killed $rbx, 0, $noreg
+  ; CHECK:   $ebp = ADD32ri8 $ebp, 5, implicit-def $eflags
+  ; CHECK:   RETQ $ebp
   bb.0 (%ir-block.0):
     liveins: $rax, $rbp, $rbx
-    ; CHECK: $ebx = LEA64_32r killed $rax, 4, killed $rax, 5, $noreg
-    ; CHECK: $ebp = LEA64_32r killed $rbx, 4, killed $rbx, 0, $noreg
-    ; CHECK: $ebp = ADD32ri8 $ebp, 5
-   
+
     CMP64rr   $rax, killed $rbx, implicit-def $eflags
     $ebx = LEA64_32r killed $rax, 4, killed $rax, 5, $noreg
     JCC_1 %bb.1, 4, implicit $eflags