29 lines
885 B
LLVM
29 lines
885 B
LLVM
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
||
|
; RUN: llc --verify-machineinstrs -mtriple powerpc-unknown-freebsd \
|
||
|
; RUN: -mcpu=pwr4 < %s | FileCheck %s
|
||
|
|
||
|
define double @postinctodbl(i64* nocapture %llp) #0 {
|
||
|
; CHECK-LABEL: postinctodbl:
|
||
|
; CHECK: # %bb.0: # %entry
|
||
|
; CHECK-NEXT: stwu 1, -16(1)
|
||
|
; CHECK-NEXT: .cfi_def_cfa_offset 16
|
||
|
; CHECK-NEXT: lwz 4, 4(3)
|
||
|
; CHECK-NEXT: stw 4, 12(1)
|
||
|
; CHECK-NEXT: addic 4, 4, 1
|
||
|
; CHECK-NEXT: lwz 5, 0(3)
|
||
|
; CHECK-NEXT: stw 5, 8(1)
|
||
|
; CHECK-NEXT: addze 5, 5
|
||
|
; CHECK-NEXT: lfd 0, 8(1)
|
||
|
; CHECK-NEXT: stw 5, 0(3)
|
||
|
; CHECK-NEXT: fcfid 1, 0
|
||
|
; CHECK-NEXT: stw 4, 4(3)
|
||
|
; CHECK-NEXT: addi 1, 1, 16
|
||
|
; CHECK-NEXT: blr
|
||
|
entry:
|
||
|
%0 = load i64, i64* %llp, align 8
|
||
|
%inc = add nsw i64 %0, 1
|
||
|
store i64 %inc, i64* %llp, align 8
|
||
|
%conv = sitofp i64 %0 to double
|
||
|
ret double %conv
|
||
|
}
|