<div dir="ltr">Hi Amara,<div><br></div><div>I was wondering if you have a link to a suggested programming model in mind for SVE and how it'll interact with other vector operations?</div><div><br></div><div>-eric</div></div><br><div class="gmail_quote"><div dir="ltr">On Thu, Jul 6, 2017 at 3:53 PM Amara Emerson via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">On 6 July 2017 at 23:13, Chris Lattner <<a href="mailto:clattner@nondot.org" target="_blank">clattner@nondot.org</a>> wrote:<br>
>> Yes, as an extension to VectorType they can be manipulated and passed<br>
>> around like normal vectors, load/stored directly, phis, put in llvm<br>
>> structs etc. Address computation generates expressions in terms vscale<br>
>> and it seems to work well.<br>
><br>
> Right, that works out through composition, but what does it mean? I can't have a global variable of a scalable vector type, nor does it make sense for a scalable vector to be embeddable in an LLVM IR struct: nothing that measures the size of a struct is prepared to deal with a non-constant answer.<br>
Although the absolute size of the types aren't known at compile time,<br>
there are upper bounds which the compiler can assume and use to allow<br>
allocation of storage for global variables and the like. The issue<br>
with composite type sizes again reduce to the issue of type sizes<br>
being either symbolic expressions or simply unknown in some cases.<br>
<br>
>>> This should probably be an intrinsic, not an llvm::Constant. The design of llvm::Constant is already wrong: it shouldn’t have operations like divide, and it would be better to not contribute to the problem.<br>
>> Could you explain your position more on this? The Constant<br>
>> architecture has been a very natural fit for this concept from our<br>
>> perspective.<br>
><br>
> It is appealing, but it is wrong. Constant should really only model primitive constants (ConstantInt/FP, etc) and we should have one more form for “relocatable” constants. Instead, we have intertwined constant folding and ConstantExpr logic that doesn’t make sense.<br>
><br>
> A better pattern to follow are intrinsics like (e.g.) llvm.coro.size.i32(), which always returns a constant value.<br>
Ok, we'll investigate this issue further.<br>
><br>
>>> Ok, that sounds complicated, but can surely be made to work. The bigger problem is that there are various LLVM IR transformations that want to put registers into memory. All of these will be broken with this sort of type.<br>
>> Could you give an example?<br>
><br>
> The concept of “reg2mem” is to put SSA values into allocas for passes that can’t (or don’t want to) update SSA. Similarly, function body extraction can turn SSA values into parameters, and depending on the implementation can pack them into structs. The coroutine logic similarly needs to store registers if they cross suspend points, there are multiple other examples.<br>
I think this should still work. Allocas of scalable vectors are supported,<br>
and it's only later at codegen that the unknown sizes result in more<br>
work being needed to compute stack offsets correctly. The caveat being<br>
that a direct call to something like getTypeStoreSize() will need to<br>
be aware of expressions/sizeless-types. If however these passes are<br>
exclusively using allocas to put registers into memory, or using<br>
structs with extractvalue etc, then they shouldn't need to care and<br>
codegen deals with the low level details.<br>
<br>
Thanks,<br>
Amara<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</blockquote></div>