mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 22:32:38 +00:00
6c2be4ff95
For many Thumb-1 register register instructions, setting the CPSR is not permitted inside an IT block. We would not correctly flag those instructions. The previous change to identify this scenario was insufficient as it did not actually catch all the instances. The current list is formed by manual inspection of the ARMv6M ARM. The change to the Thumb2 IT block test is due to the fact that the new more stringent checking of the MIs results in the If Conversion pass being prevented from executing (since not all the instructions in the BB are predicable). This results in code gen changes. Thanks to Tim Northover for pointing out that the previous patch was insufficient and hinting that the use of the v6M ARM would be much easier to use than the v7 or v8! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@215382 91177308-0d34-0410-b5e6-96231b3b80d8
31 lines
779 B
LLVM
31 lines
779 B
LLVM
; RUN: llc -mtriple=thumb-eabi -mcpu=arm1156t2-s -mattr=+thumb2 %s -o - | FileCheck -check-prefix CHECK-V7 %s
|
|
; RUN: llc -mtriple=thumbv8 %s -o - | FileCheck %s -check-prefix CHECK-V8
|
|
; PR11107
|
|
|
|
define i32 @test(i32 %a, i32 %b) {
|
|
entry:
|
|
%cmp1 = icmp slt i32 %a, 0
|
|
%sub1 = sub nsw i32 0, %a
|
|
%abs1 = select i1 %cmp1, i32 %sub1, i32 %a
|
|
%cmp2 = icmp slt i32 %b, 0
|
|
%sub2 = sub nsw i32 0, %b
|
|
%abs2 = select i1 %cmp2, i32 %sub2, i32 %b
|
|
%add = add nsw i32 %abs1, %abs2
|
|
ret i32 %add
|
|
}
|
|
|
|
; CHECK-V7: cmp
|
|
; CHECK-V7-NEXT: it mi
|
|
; CHECK-V7-NEXT: rsbmi
|
|
; CHECK-V7-NEXT: cmp
|
|
; CHECK-V7-NEXT: it mi
|
|
; CHECK-V7-NEXT: rsbmi
|
|
|
|
; CHECK-V8: cmp
|
|
; CHECK-V8-NEXT: bpl
|
|
; CHECK-V8: rsbs
|
|
; CHECK-V8: cmp
|
|
; CHECK-V8-NEXT: bpl
|
|
; CHECK-V8: rsbs
|
|
|