This patch causes compile times for some patterns to explode. I have a (large, unreduced) test case that slows down by more than 20x and several test cases slow down by 2x. I'm sending some of the test cases directly to Nirav and following up with more details in the review log, but this should unblock anyone else hitting this. llvm-svn: 296862
23 lines
673 B
LLVM
23 lines
673 B
LLVM
; RUN: llc -mtriple=thumbv7-apple-ios %s -o - | FileCheck %s
|
|
|
|
define void @multiple_store() {
|
|
; CHECK-LABEL: multiple_store:
|
|
; CHECK: movw r[[BASE1:[0-9]+]], #16960
|
|
; CHECK: movs [[VAL:r[0-9]+]], #42
|
|
; CHECK: movt r[[BASE1]], #15
|
|
|
|
; CHECK: str [[VAL]], [r[[BASE1]]]
|
|
; CHECK: str [[VAL]], [r[[BASE1]], #24]
|
|
; CHECK: str.w [[VAL]], [r[[BASE1]], #42]
|
|
|
|
; CHECK: movw r[[BASE2:[0-9]+]], #20394
|
|
; CHECK: movt r[[BASE2]], #18
|
|
|
|
; CHECK: str [[VAL]], [r[[BASE2]]]
|
|
store i32 42, i32* inttoptr(i32 1000000 to i32*)
|
|
store i32 42, i32* inttoptr(i32 1000024 to i32*)
|
|
store i32 42, i32* inttoptr(i32 1000042 to i32*)
|
|
store i32 42, i32* inttoptr(i32 1200042 to i32*)
|
|
ret void
|
|
}
|