This class allows to store information about the arrays in the SCoP. For each base pointer in the SCoP one object is created storing the type and dimension sizes of the array. The objects can be obtained via the SCoP, a MemoryAccess or the isl_id associated with the output dimension of a MemoryAccess (the description of what is accessed). So far we use the information in the IslExprBuilder to create the right base type before indexing into the base array. This fixes the bug http://llvm.org/bugs/show_bug.cgi?id=21113 (both test cases are included). On top of that we can now build runtime alias checks for delinearized arrays as the dimension sizes are also part of the ScopArrayInfo objects.
Details
Diff Detail
Event Timeline
Very nice. Besides fixing two important bugs in the run-time alias checks, this is also conceptually a big step forward. Thanks for working on this last night!
The patch looks great, with just some test-case changes that I unfortunately do not understand.
I also added a couple (3-4) of minor comments on your code. None of them has correctness implications and the original code is already very nice, so just include them as you like.
include/polly/CodeGen/IslExprBuilder.h | ||
---|---|---|
84 ↗ | (On Diff #14419) | It is unclear to me why the IslExpr Builder would need a SCoP now. |
lib/Analysis/ScopInfo.cpp | ||
294 | A similar function that takes an isl_id and returns the ScopArrayInfo might be handy too. (See later comment on how to obtain the BasePtr/ElementType of an isl_ast_op_access). | |
490 | Conceptually it probably makes sense to allocate one isl_id in the ScopArrayInfo class and then give users the option to obtain copies of this id. This makes clear that all these isl_ids are identical. (The current code also works at the moment AFAIK, as isl assumes two ids are identical if their name and the user pointer are identical). | |
lib/CodeGen/IslCodeGeneration.cpp | ||
61 | I am surprised we need the Scop here. | |
lib/CodeGen/IslExprBuilder.cpp | ||
120 | Instead of passing the scop to this place and use the base ptr to look up the ScopArrayInfo, you could possibly also obtain the isl_id from the isl_ast_expr_get_op_arg(Expr, 0) and then use a "static ScopArrayInfo::getFromid(Id)" function. Also, instead of obtaining the Base pointer by calling create(), we could obtain | |
137 | Nice cleanup! | |
test/Isl/CodeGen/MemAccess/codegen_simple.ll | ||
43 | It is unclear to me why this test case needs to be modified and especially why the generated IR now can be have one of two forms. Is the IR we generate not supposed to be predictable? |
Responses. I would try to change the code according to the comments but I still like the changes to the tests ({{(i32}i64)}} instread of i32)
include/polly/CodeGen/IslExprBuilder.h | ||
---|---|---|
84 ↗ | (On Diff #14419) | To access the ScopInfoArray for a base pointer. |
lib/Analysis/ScopInfo.cpp | ||
490 | I'll change that. Good point. | |
lib/CodeGen/IslCodeGeneration.cpp | ||
61 | Just to pass it on to the IslExprBuilder. | |
lib/CodeGen/IslExprBuilder.cpp | ||
120 | True, I'll try that and keep it if it works | |
test/Isl/CodeGen/MemAccess/codegen_simple.ll | ||
43 | It has a different form now because for A[100] CreateBitcast(A[0]) == yields ==> getelemenptr inbounds [100 x i32]* @A, i32 0, i32 0 where the indices are of type i32. Before the patch we added the indices and used the typ of the only real index op to create "zeros" (thus they were i64). Now I don't want to hardcode i32 because a change in the bitcast function or in our code could revert this or mix the indice types without a semantical change, thus I don't see the reason to fix one type here. |
A similar function that takes an isl_id and returns the ScopArrayInfo might be handy too. (See later comment on how to obtain the BasePtr/ElementType of an isl_ast_op_access).