1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 12:12:47 +01:00
llvm-mirror/test/Transforms/SROA/ppcf128-no-fold.ll
Roman Lebedev 034e32765e [SROA] rewritePartition()/findCommonType(): if uses have conflicting type, try getTypePartition() before falling back to largest integral use type (PR47592)
And another step towards transformss not introducing inttoptr and/or
ptrtoint casts that weren't there already.

In this case, when load/store uses have conflicting types,
instead of falling back to the iN, we can try to use allocated sub-type.
As disscussed, this isn't the best idea overall (we shouldn't rely on
allocated type), but it works fine as a temporary measure.

I've measured, and @ `-O3` as of vanilla llvm test-suite + RawSpeed,
this results in +0.05% more bitcasts, -5.51% less inttoptr
and -1.05% less ptrtoint (at the end of middle-end opt pipeline)

See https://bugs.llvm.org/show_bug.cgi?id=47592

Reviewed By: efriedma

Differential Revision: https://reviews.llvm.org/D88788
2020-10-07 09:20:19 +03:00

37 lines
1.4 KiB
LLVM

; RUN: opt < %s -sroa -S | FileCheck %s
target datalayout = "E-m:e-i64:64-n32:64"
target triple = "powerpc64-unknown-linux-gnu"
%struct.ld2 = type { [2 x ppc_fp128] }
declare void @bar(i8*, [2 x i128])
define void @foo(i8* %v) #0 {
entry:
%v.addr = alloca i8*, align 8
%z = alloca %struct.ld2, align 16
store i8* %v, i8** %v.addr, align 8
%dat = getelementptr inbounds %struct.ld2, %struct.ld2* %z, i32 0, i32 0
%arrayidx = getelementptr inbounds [2 x ppc_fp128], [2 x ppc_fp128]* %dat, i32 0, i64 0
store ppc_fp128 0xM403B0000000000000000000000000000, ppc_fp128* %arrayidx, align 16
%dat1 = getelementptr inbounds %struct.ld2, %struct.ld2* %z, i32 0, i32 0
%arrayidx2 = getelementptr inbounds [2 x ppc_fp128], [2 x ppc_fp128]* %dat1, i32 0, i64 1
store ppc_fp128 0xM4093B400000000000000000000000000, ppc_fp128* %arrayidx2, align 16
%0 = load i8*, i8** %v.addr, align 8
%coerce.dive = getelementptr %struct.ld2, %struct.ld2* %z, i32 0, i32 0
%1 = bitcast [2 x ppc_fp128]* %coerce.dive to [2 x i128]*
%2 = load [2 x i128], [2 x i128]* %1, align 1
call void @bar(i8* %0, [2 x i128] %2)
ret void
}
; CHECK-LABEL: @foo
; CHECK-NOT: i128 4628293042053316608
; CHECK-NOT: i128 4653260752096854016
; CHECK-DAG: bitcast ppc_fp128 0xM403B0000000000000000000000000000 to i128
; CHECK-DAG: bitcast ppc_fp128 0xM4093B400000000000000000000000000 to i128
; CHECK: call void @bar(i8* %v, [2 x i128]
; CHECK: ret void
attributes #0 = { nounwind }