forked from OSchip/llvm-project
Revert "[ARM] Enable shrink-wrapping by default."
This reverts commit r252825, as it broke ASAN on ARM. Investigating... llvm-svn: 252889
This commit is contained in:
parent
9f6ad49740
commit
93064025bd
|
@ -57,11 +57,6 @@ public:
|
||||||
void adjustForSegmentedStacks(MachineFunction &MF,
|
void adjustForSegmentedStacks(MachineFunction &MF,
|
||||||
MachineBasicBlock &MBB) const override;
|
MachineBasicBlock &MBB) const override;
|
||||||
|
|
||||||
/// Returns true if the target will correctly handle shrink wrapping.
|
|
||||||
bool enableShrinkWrapping(const MachineFunction &MF) const override {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void emitPushInst(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI,
|
void emitPushInst(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI,
|
||||||
const std::vector<CalleeSavedInfo> &CSI, unsigned StmOpc,
|
const std::vector<CalleeSavedInfo> &CSI, unsigned StmOpc,
|
||||||
|
|
|
@ -83,11 +83,9 @@ declare void @foo() nounwind
|
||||||
define void @t7() nounwind {
|
define void @t7() nounwind {
|
||||||
entry:
|
entry:
|
||||||
; CHECKT2D-LABEL: t7:
|
; CHECKT2D-LABEL: t7:
|
||||||
; CHECKT2D: it ne
|
; CHECKT2D: blxeq _foo
|
||||||
; CHECKT2D-NEXT: bne.w _foo
|
; CHECKT2D-NEXT: pop.w
|
||||||
; CHECKT2D-NEXT: push
|
; CHECKT2D-NEXT: b.w _foo
|
||||||
; CHECKT2D-NEXT: mov r7, sp
|
|
||||||
; CHECKT2D-NEXT: blx _foo
|
|
||||||
br i1 undef, label %bb, label %bb1.lr.ph
|
br i1 undef, label %bb, label %bb1.lr.ph
|
||||||
|
|
||||||
bb1.lr.ph:
|
bb1.lr.ph:
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
; Disable shrink-wrapping on the first test otherwise we wouldn't
|
; RUN: llc -mtriple=thumbv7-apple-none-macho < %s | FileCheck %s
|
||||||
; exerce the path for PR18136.
|
|
||||||
; RUN: llc -mtriple=thumbv7-apple-none-macho < %s -enable-shrink-wrap=false | FileCheck %s
|
|
||||||
; RUN: llc -mtriple=thumbv6m-apple-none-macho -disable-fp-elim < %s | FileCheck %s --check-prefix=CHECK-T1
|
; RUN: llc -mtriple=thumbv6m-apple-none-macho -disable-fp-elim < %s | FileCheck %s --check-prefix=CHECK-T1
|
||||||
; RUN: llc -mtriple=thumbv7-apple-darwin-ios -disable-fp-elim < %s | FileCheck %s --check-prefix=CHECK-IOS
|
; RUN: llc -mtriple=thumbv7-apple-darwin-ios -disable-fp-elim < %s | FileCheck %s --check-prefix=CHECK-IOS
|
||||||
; RUN: llc -mtriple=thumbv7--linux-gnueabi -disable-fp-elim < %s | FileCheck %s --check-prefix=CHECK-LINUX
|
; RUN: llc -mtriple=thumbv7--linux-gnueabi -disable-fp-elim < %s | FileCheck %s --check-prefix=CHECK-LINUX
|
||||||
|
|
|
@ -13,10 +13,10 @@ entry:
|
||||||
|
|
||||||
define i32 @t1(i32 %a, i32 %b) {
|
define i32 @t1(i32 %a, i32 %b) {
|
||||||
; A8-LABEL: t1:
|
; A8-LABEL: t1:
|
||||||
; A8: bxlt lr
|
; A8: poplt {r7, pc}
|
||||||
|
|
||||||
; SWIFT-LABEL: t1:
|
; SWIFT-LABEL: t1:
|
||||||
; SWIFT: bxlt lr
|
; SWIFT: pop {r7, pc}
|
||||||
; SWIFT: pop {r7, pc}
|
; SWIFT: pop {r7, pc}
|
||||||
entry:
|
entry:
|
||||||
%tmp1 = icmp sgt i32 %a, 10 ; <i1> [#uses=1]
|
%tmp1 = icmp sgt i32 %a, 10 ; <i1> [#uses=1]
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
define void @foo(i32 %X, i32 %Y) {
|
define void @foo(i32 %X, i32 %Y) {
|
||||||
entry:
|
entry:
|
||||||
; CHECK: cmpne
|
; CHECK: cmpne
|
||||||
; CHECK: bxhi lr
|
; CHECK: pophi
|
||||||
%tmp1 = icmp ult i32 %X, 4 ; <i1> [#uses=1]
|
%tmp1 = icmp ult i32 %X, 4 ; <i1> [#uses=1]
|
||||||
%tmp4 = icmp eq i32 %Y, 0 ; <i1> [#uses=1]
|
%tmp4 = icmp eq i32 %Y, 0 ; <i1> [#uses=1]
|
||||||
%tmp7 = or i1 %tmp4, %tmp1 ; <i1> [#uses=1]
|
%tmp7 = or i1 %tmp4, %tmp1 ; <i1> [#uses=1]
|
||||||
|
|
|
@ -5,9 +5,7 @@
|
||||||
declare void @abort()
|
declare void @abort()
|
||||||
|
|
||||||
define fastcc void @t(%struct.SString* %word, i8 signext %c) {
|
define fastcc void @t(%struct.SString* %word, i8 signext %c) {
|
||||||
; CHECK-NOT: pop
|
; CHECK: popne
|
||||||
; CHECK: bxne
|
|
||||||
; CHECK-NOT: pop
|
|
||||||
entry:
|
entry:
|
||||||
%tmp1 = icmp eq %struct.SString* %word, null ; <i1> [#uses=1]
|
%tmp1 = icmp eq %struct.SString* %word, null ; <i1> [#uses=1]
|
||||||
br i1 %tmp1, label %cond_true, label %cond_false
|
br i1 %tmp1, label %cond_true, label %cond_false
|
||||||
|
|
|
@ -27,7 +27,7 @@ define void @f2() nounwind ssp {
|
||||||
entry:
|
entry:
|
||||||
; CHECK-LABEL: f2:
|
; CHECK-LABEL: f2:
|
||||||
; CHECK: cmp
|
; CHECK: cmp
|
||||||
; CHECK: bxlt
|
; CHECK: poplt
|
||||||
; CHECK-NOT: cmp
|
; CHECK-NOT: cmp
|
||||||
; CHECK: movle
|
; CHECK: movle
|
||||||
%0 = load i32, i32* @foo, align 4
|
%0 = load i32, i32* @foo, align 4
|
||||||
|
|
|
@ -23,7 +23,7 @@ define i32* @bar() {
|
||||||
|
|
||||||
; CHECK: .globl baz
|
; CHECK: .globl baz
|
||||||
; CHECK-NEXT: .align 2
|
; CHECK-NEXT: .align 2
|
||||||
; CHECK: tbb
|
; CHECK: adr.w
|
||||||
define i32 @baz() {
|
define i32 @baz() {
|
||||||
%1 = load i32, i32* @c, align 4
|
%1 = load i32, i32* @c, align 4
|
||||||
switch i32 %1, label %7 [
|
switch i32 %1, label %7 [
|
||||||
|
|
|
@ -19,8 +19,7 @@ f:
|
||||||
define void @f1(i32 %x) optsize {
|
define void @f1(i32 %x) optsize {
|
||||||
; CHECK-LABEL: f1:
|
; CHECK-LABEL: f1:
|
||||||
; CHECK: cmp r0, #1
|
; CHECK: cmp r0, #1
|
||||||
; CHECK: it ne
|
; CHECK: it eq
|
||||||
; CHECK-NEXT: bxne lr
|
|
||||||
%p = icmp eq i32 %x, 1
|
%p = icmp eq i32 %x, 1
|
||||||
br i1 %p, label %t, label %f
|
br i1 %p, label %t, label %f
|
||||||
|
|
||||||
|
@ -35,8 +34,7 @@ f:
|
||||||
define void @f2(i32 %x) {
|
define void @f2(i32 %x) {
|
||||||
; CHECK-LABEL: f2:
|
; CHECK-LABEL: f2:
|
||||||
; CHECK: cmp r0, #0
|
; CHECK: cmp r0, #0
|
||||||
; CHECK: it ne
|
; CHECK: it eq
|
||||||
; CHECK-NEXT: bxne lr
|
|
||||||
%p = icmp eq i32 %x, 0
|
%p = icmp eq i32 %x, 0
|
||||||
br i1 %p, label %t, label %f
|
br i1 %p, label %t, label %f
|
||||||
|
|
||||||
|
|
|
@ -72,10 +72,9 @@ entry:
|
||||||
define void @t3(i32 %a, i32 %b) nounwind {
|
define void @t3(i32 %a, i32 %b) nounwind {
|
||||||
entry:
|
entry:
|
||||||
; CHECK-LABEL: t3:
|
; CHECK-LABEL: t3:
|
||||||
; CHECK: it lt
|
; CHECK: itt ge
|
||||||
; CHECK-NEXT: bxlt lr
|
; CHECK: movge r0, r1
|
||||||
; CHECK: mov r0, r1
|
; CHECK: blge {{_?}}foo
|
||||||
; CHECK: bl {{_?}}foo
|
|
||||||
%tmp1 = icmp sgt i32 %a, 10 ; <i1> [#uses=1]
|
%tmp1 = icmp sgt i32 %a, 10 ; <i1> [#uses=1]
|
||||||
br i1 %tmp1, label %cond_true, label %UnifiedReturnBlock
|
br i1 %tmp1, label %cond_true, label %UnifiedReturnBlock
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@ entry:
|
||||||
; CHECK: it ne
|
; CHECK: it ne
|
||||||
; CHECK: cmpne
|
; CHECK: cmpne
|
||||||
; CHECK: it hi
|
; CHECK: it hi
|
||||||
; CHECK: bxhi lr
|
; CHECK: pophi {r7, pc}
|
||||||
%tmp1 = icmp ult i32 %X, 4 ; <i1> [#uses=1]
|
%tmp1 = icmp ult i32 %X, 4 ; <i1> [#uses=1]
|
||||||
%tmp4 = icmp eq i32 %Y, 0 ; <i1> [#uses=1]
|
%tmp4 = icmp eq i32 %Y, 0 ; <i1> [#uses=1]
|
||||||
%tmp7 = or i1 %tmp4, %tmp1 ; <i1> [#uses=1]
|
%tmp7 = or i1 %tmp4, %tmp1 ; <i1> [#uses=1]
|
||||||
|
@ -69,7 +69,7 @@ define fastcc void @t1(%struct.SString* %word, i8 signext %c) {
|
||||||
entry:
|
entry:
|
||||||
; CHECK-LABEL: t1:
|
; CHECK-LABEL: t1:
|
||||||
; CHECK: it ne
|
; CHECK: it ne
|
||||||
; CHECK: bxne lr
|
; CHECK: popne {r7, pc}
|
||||||
%tmp1 = icmp eq %struct.SString* %word, null ; <i1> [#uses=1]
|
%tmp1 = icmp eq %struct.SString* %word, null ; <i1> [#uses=1]
|
||||||
br i1 %tmp1, label %cond_true, label %cond_false
|
br i1 %tmp1, label %cond_true, label %cond_false
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
; CHECK-NEXT: b
|
; CHECK-NEXT: b
|
||||||
; CHECK: [[JUMPTARGET]]:{{.*}}%if.else173
|
; CHECK: [[JUMPTARGET]]:{{.*}}%if.else173
|
||||||
; CHECK-NEXT: mov.w
|
; CHECK-NEXT: mov.w
|
||||||
; CHECK-NEXT: bx lr
|
; CHECK-NEXT: pop
|
||||||
; CHECK-NEXT: %if.else145
|
; CHECK-NEXT: %if.else145
|
||||||
; CHECK-NEXT: mov.w
|
; CHECK-NEXT: mov.w
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue