Files
clang-p2996/polly/test/Isl/CodeGen/scev_looking_through_bitcasts.ll
Roman Lebedev 78b8ce40ef Reland [SCEV] Improve modelling for (null) pointer constants
This reverts commit 329aeb5db4,
and relands commit 61f006ac65.

This is a continuation of D89456.

As it was suggested there, now that SCEV models `PtrToInt`,
we can try to improve SCEV's pointer handling.
In particular, i believe, i will need this in the future
to further fix `SCEVAddExpr`operation type handling.

This removes special handling of `ConstantPointerNull`
from `ScalarEvolution::createSCEV()`, and add constant folding
into `ScalarEvolution::getPtrToIntExpr()`.
This way, `null` constants stay as such in SCEV's,
but gracefully become zero integers when asked.

Reviewed By: Meinersbur

Differential Revision: https://reviews.llvm.org/D98147
2021-03-13 16:05:34 +03:00

40 lines
1.1 KiB
LLVM

; RUN: opt %loadPolly -polly-codegen -S < %s | FileCheck %s
;
; Scalar write of bitcasted value. Instead of writing %b of type
; %structty, the SCEV expression looks through the bitcast such that
; SCEVExpander returns %add.ptr81.i of type i8* to be the new value
; of %b.
;
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
%structty = type { %structty*, %structty*, i32, [2 x i64] }
define void @bitmap_set_range() {
entry:
%a = ptrtoint i8* undef to i64
br label %cond.end32.i
cond.end32.i:
br i1 false, label %cond.true67.i, label %cond.end73.i
cond.true67.i:
br label %cond.end73.i
cond.end73.i:
%add.ptr81.i = getelementptr inbounds i8, i8* null, i64 %a
%b = bitcast i8* %add.ptr81.i to %structty*
br label %bitmap_element_allocate.exit
bitmap_element_allocate.exit:
%tobool43 = icmp eq %structty* %b, null
ret void
}
; CHECK: polly.stmt.cond.end73.i:
; CHECK-NEXT: %scevgep = getelementptr i8, i8* null, i64 %a
; CHECK-NEXT: %scevgep1 = bitcast i8* %scevgep to %structty*
; CHECK-NEXT: store %structty* %scevgep1, %structty** %b.s2a, align 8
; CHECK-NEXT: br label %polly.exiting