[PATCH] D20319: [InstCombine] Fix assertion when bitcast is converted to gep

Gerolf Hoflehner via llvm-commits llvm-commits at lists.llvm.org
Mon May 23 12:30:00 PDT 2016



Committed revision 270479

Thanks, David!

> On May 16, 2016, at 11:37 PM, Gerolf Hoflehner <ghoflehner at apple.com> wrote:
> 
> Gerolf created this revision.
> Gerolf added a reviewer: llvm-commits.
> 
> When an aggregate contains an opaque type its size cannot be
> determined. This triggers an "Invalid GetElementPtrInst indices for type" assert
> in function checkGEPType. The patch suppresses the conversion in this case.
> 
> http://reviews.llvm.org/D20319
> 
> Files:
>  lib/Transforms/InstCombine/InstCombineCasts.cpp
>  test/Transforms/InstCombine/opaque.ll
> 
> Index: test/Transforms/InstCombine/opaque.ll
> ===================================================================
> --- /dev/null
> +++ test/Transforms/InstCombine/opaque.ll
> @@ -0,0 +1,32 @@
> +; RUN: opt < %s -instcombine -disable-output
> +; Checks that bitcasts are not converted into GEP when
> +; when the size of an aggregate cannot be determined.
> +%swift.opaque = type opaque
> +%SQ = type <{ [8 x i8] }>
> +%Si = type <{ i64 }>
> +
> +%V = type <{ <{ %Vs4Int8, %Vs4Int8, %Vs4Int8, %Vs4Int8, %Vs4Int8, %Vs4Int8, %Vs4Int8, %Vs4Int8 }>, %Si, %SQ, %SQ, %Si, %swift.opaque }>
> +%Vs4Int8 = type <{ i8 }>
> +%swift.type = type { i64 }
> +
> +declare void @llvm.memcpy.p0i8.p0i8.i64(i8* nocapture, i8* nocapture readonly,
> +i64, i32, i1) #8
> +
> + at _swift_slowAlloc = external global i8* (i64, i64)*
> +
> +declare i8* @rt_swift_slowAlloc(i64, i64)
> +
> +define  %swift.opaque* @_TwTkV([24 x i8]* %dest, %swift.opaque* %src,
> +%swift.type* %bios_boot_params) #0 {
> +entry:
> +  %0 = bitcast %swift.opaque* %src to %V*
> +  %1 = call noalias i8* @rt_swift_slowAlloc(i64 40, i64 0) #11
> +  %2 = bitcast [24 x i8]* %dest to i8**
> +  store i8* %1, i8** %2, align 8
> +  %3 = bitcast i8* %1 to %V*
> +  %4 = bitcast %V* %3 to i8*
> +  %5 = bitcast %V* %0 to i8*
> +  call void @llvm.memcpy.p0i8.p0i8.i64(i8* %4, i8* %5, i64 40, i32 1, i1 false)
> +  %6 = bitcast %V* %3 to %swift.opaque*
> +  ret %swift.opaque* %6
> +}
> Index: lib/Transforms/InstCombine/InstCombineCasts.cpp
> ===================================================================
> --- lib/Transforms/InstCombine/InstCombineCasts.cpp
> +++ lib/Transforms/InstCombine/InstCombineCasts.cpp
> @@ -1915,6 +1915,11 @@
>       if (Instruction *V = PromoteCastOfAllocation(CI, *AI))
>         return V;
> 
> +    Type *PointeeType =
> +        cast<PointerType>(Src->getType()->getScalarType())->getElementType();
> +    if (!PointeeType->isSized())
> +      return nullptr;
> +
>     // If the source and destination are pointers, and this cast is equivalent
>     // to a getelementptr X, 0, 0, 0...  turn it into the appropriate gep.
>     // This can enhance SROA and other transforms that want type-safe pointers.
> 
> 
> <D20319.57435.patch>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160523/a83a3a05/attachment.html>


More information about the llvm-commits mailing list