[PATCH] D84589: [CodeMoverUtils] Add optional data dependence checks using Alias Analysis

rithik sharma via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Aug 18 10:53:20 PDT 2020


RithikSharma marked 2 inline comments as done.
RithikSharma added inline comments.


================
Comment at: llvm/lib/Transforms/Utils/CodeMoverUtils.cpp:287
+      // RAR dependency is safe
+      if (isRefSet(Result) && isRefSet(DestResult))
+        return false;
----------------
bmahjour wrote:
> Two comments here:
> 1. As I mentioned before, `isRefSet` may be true when `isModSet` is also true, so if you want to check for RAR you'd have to make sure that `isModSet` is false.
> 2. Why do we need two results (`Result` and `DestResult`)? I'm not sure we need to query `AA.getModRefInfo` twice, once for each direction. Alias queries normally refer to a value in a symmetric bit matrix. Do you have a test where the result of `AA.getModRefInfo` is different depending on the order in which you pass the two memory location arguments? 
1. I have added checks for `isModSet ` .
2. We don't require two (Result and DestResult), I have checked the values of Result and DestResult, they are different. 
I have made the required changes.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D84589/new/

https://reviews.llvm.org/D84589



More information about the llvm-commits mailing list