[PATCH] D42123: Derive GEP index type from Data Layout

David Chisnall via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Jan 22 06:19:02 PST 2018


theraven added a comment.

In https://reviews.llvm.org/D42123#982063, @delena wrote:

> In https://reviews.llvm.org/D42123#981602, @theraven wrote:
>
> > I don't like this patch as is, for several reasons.
> >
> > 1. It's adding a hack that assumes that the offset should be the width of the widest integer operation.  This is probably true in most cases (it is for us), but if we're going to introduce the idea that an address offset is distinct from the size of the pointer then we should do it properly and add that to the TargetInfo string explicitly (defaulting to the same size, if not specified).
>
>
> So you propose to extend Data Layout string and add index size to it, right? It was one of options that Hal suggested. Ok.


Yes, if we're going to fix this upstream, let's fix it properly.

> 
> 
>> 2. We're computing the correct width every time it's requested, which looks expensive.  TargetInfo should store the width for each address space and, for non-vector types, not have to do any calculation to determine the kind of integer to return.
> 
> We calculated getIntPtrType() anyway, getIndexType() is not more expensive. If I extend TargetInfo, the extension will be optional and all other targets will calculate getIntPtrType() anyway.

If you read it from the DataLayout string, you'll either construct it at that parsing time from the specified version or from the default version.

>> 3. It fixes only around 20% of the places that we've found that assume that the size and range of the pointer are the same.
> 
> I can't derive all places from your code. You can show me them all, one-by-one, or we'll fix more places gradually on top of this patch.

Greping the code for all uses of getPointerBaseSize should show them all, but I can send you a list.


Repository:
  rL LLVM

https://reviews.llvm.org/D42123





More information about the llvm-commits mailing list