<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Jun 13, 2016 at 8:03 AM, Yichao Yu <span dir="ltr"><<a href="mailto:yyc1992@gmail.com" target="_blank">yyc1992@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">On Mon, Jun 13, 2016 at 10:35 AM, Daniel Berlin <<a href="mailto:dberlin@dberlin.org">dberlin@dberlin.org</a>> wrote:<br>
><br>
><br>
> On Sun, Jun 12, 2016 at 10:12 PM, Eli Friedman <<a href="mailto:eli.friedman@gmail.com">eli.friedman@gmail.com</a>><br>
> wrote:<br>
>><br>
>> On Sun, Jun 12, 2016 at 9:31 PM, Yichao Yu <<a href="mailto:yyc1992@gmail.com">yyc1992@gmail.com</a>> wrote:<br>
>>><br>
>>> > Alias analysis results should not be confused with value equivalence<br>
>>> > (though<br>
>>> > it is common).  MustAlias or NoAlias implies nothing about the actual<br>
>>> > pointer value, only the abstract memory location it represents.<br>
>>><br>
>>> I can understand they are not equivalent but shouldn't not being the<br>
>>> same pointer value be a necessary condition for NoAlias? In another<br>
>>> word, are the following valid?<br>
>>><br>
>>> ```<br>
>>> define i64 @f1(i64 *%p0, i64 *%p1) {<br>
>>>   store i64 0, i64 *%p0, !tbaa !0<br>
>>>   %v2 = load i64, i64 *%p1, !tbaa !1<br>
>>>   ret %v2<br>
>>> }<br>
>>><br>
>>> define i64 @f2(i64 *%p1) {<br>
>>>   store i64 0, i64 *%p1, !tbaa !0<br>
>>>   %v2 = load i64, i64 *%p1, !tbaa !1<br>
>>>   ret %v2<br>
>>> }<br>
>>><br>
>><br>
>> It depends on what you mean by "valid"... @f1 passed two identical<br>
>> pointers is basically equivalent to "ret i64 undef".<br>
><br>
><br>
> So, i can't see anything in the langref that says this.<br>
><br>
> For f1, the valid things i see you can do are (and have an argument you can)<br>
><br>
> 1. move the load before the store, return value of load (IE reorder them)<br>
> 2. eliminate both the load and store and return 0 (IE forward the store)<br>
><br>
> I don't see a valid path to ret undef. I'm eminently curious what i've<br>
> missed :)<br>
><br>
<br>
</div></div>So my understanding now is that this the load in question can arise<br>
when optimizing (pseudo code, C with llvm annotation)<br>
<br>
<br>
if (some_condition)<br>
    v = *p; !dereferencable, !tbaa !0<br>
else<br>
    v = *p; !dereferencable, !tbaa !1<br>
<br>
And when LLVM move both of the load out of the branch and merge them,<br>
the tbaa should be merged (and not intersect)<br></blockquote><div><br></div><div>Yes, use combineMetadata, it will do the right thing.</div><div> </div><div><br></div><div> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
<br>
So my original understanding of TBAA (or other metadata that can be<br>
used in alias analysis) is that if two memory operations on the same<br>
runtime path have non intersecting tbaa metadata, they should not<br>
alias. </blockquote><div><br></div><div>depends on what you mean by "non-intersecting".  TBAA is a set hierarchy, so it's possible, given !1 and !2 as tbaa tags, that they do alias, if !2 is a child of !1 in the tbaa tree.</div><div> <br></div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">So maybe a more precise definition is that if two **used**<br>
memory operations on the same runtime path have non intersecting tbaa<br>
metadata, they should not alias. Or in another word, if a load is<br>
never used, then the TBAA on it doesn't count, i.e. LLVM can transform<br>
the code above into<br>
<br></blockquote><div><br></div><div>This is a question of whether they are safe to speculatively execute (which i believe they are).   <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
v0 = *p; !dereferencable, !tbaa !0<br>
v1 = *p; !dereferencable, !tbaa !1<br>
if (some_condition)<br>
    v = v0;<br>
else<br>
    v = v1;<br>
<br>
Even though the two loads are on the same runtime path, only one of<br>
them will ever be used so the conflicting tbaa metadata is fine?<br></blockquote><div><br></div><div>It doesn't conflict in the first place.</div><div>You need to stop thinking about this as "a given pointer representing some bits can only ever be thought of as referring to one place in memory", and "TBAA matters at the llvm level".  TBAA is metadata. You can choose to ignore it or not ignore it. It has no effect on semantics of the loads themselves.</div><div><br></div><div>TBAA, instead,  is about language level aliasing semantics.  It is saying "even though these loads/stores look the same, they are not to the same memory location" or "even though these loads/stores  look not the same, they are the same memory location".</div><div><br></div><div>It is metadata. You can choose to ignore it or not ignore it, at your leisure. It changes *no semantics*.</div><div><br></div></div></div></div>