mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-28 04:33:05 +00:00
261f0df185
In rare cases the dead definition elimination pass code can cause illegal cmn instructions when it replaces dead registers on instructions that use unmaterialized frame indexes. This patch disables the dead definition optimization for instructions which include frame index operands. rdar://16438284 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@206208 91177308-0d34-0410-b5e6-96231b3b80d8
19 lines
455 B
LLVM
19 lines
455 B
LLVM
; RUN: llc -march=arm64 < %s | FileCheck %s
|
|
|
|
target datalayout = "e-m:o-i64:64-i128:128-n32:64-S128"
|
|
target triple = "arm64-apple-ios7.0.0"
|
|
|
|
; Function Attrs: nounwind ssp uwtable
|
|
define i32 @test1() #0 {
|
|
%tmp1 = alloca i8
|
|
%tmp2 = alloca i32, i32 4096
|
|
%tmp3 = icmp eq i8* %tmp1, null
|
|
%tmp4 = zext i1 %tmp3 to i32
|
|
|
|
ret i32 %tmp4
|
|
|
|
; CHECK-LABEL: test1
|
|
; CHECK: adds [[TEMP:[a-z0-9]+]], sp, #16384
|
|
; CHECK: adds [[TEMP]], [[TEMP]], #15
|
|
}
|