llvm-capstone/polly/test/Simplify/pr33323___%for.body98---%for.cond87.loopexit.jscop
Michael Kruse ad7a1805be [Simplify] Use execution order of memory accesses.
Iterate through memory accesses in execution order (first all implicit reads,
then explicit accesses, then implicit writes).

In the test case this caused an implicit load to be handled as if it was loaded
after the write. That is, the value being written before it is available.

This fixes llvm.org/PR33323

llvm-svn: 304810
2017-06-06 17:46:42 +00:00

40 lines
1.1 KiB
Plaintext

{
"arrays" : [
{
"name" : "MemRef_symmat",
"sizes" : [ "*", "1000" ],
"type" : "double"
}
],
"context" : "{ : }",
"name" : "%for.body98---%for.cond87.loopexit",
"statements" : [
{
"accesses" : [
{
"kind" : "write",
"relation" : "{ Stmt_for_body105[i0, i1] -> MemRef_add119[] }"
}
],
"domain" : "{ Stmt_for_body105[i0, i1] : 0 <= i0 <= 998 and 0 <= i1 <= 999 }",
"name" : "Stmt_for_body105",
"schedule" : "{ Stmt_for_body105[i0, i1] -> [i0, 0, i1] }"
},
{
"accesses" : [
{
"kind" : "write",
"relation" : "{ Stmt_for_end122[i0] -> MemRef_symmat[1 + i0, 0] }"
},
{
"kind" : "read",
"relation" : "{ Stmt_for_end122[i0] -> MemRef_add119[] }"
}
],
"domain" : "{ Stmt_for_end122[i0] : 0 <= i0 <= 998 }",
"name" : "Stmt_for_end122",
"schedule" : "{ Stmt_for_end122[i0] -> [i0, 1, 0] }"
}
]
}