When the operand to an (s/u)int_to_fp node is an illegally typed load we cannot reuse the load address since we can't build a proper dependancy chain. The legalized loads will use a different chain output then the illegal load. If we reuse the load address then we will build a conversion node that uses the chain of the illegal load and operations which modify the memory address in the other dependancy chain can be scheduled before the floating point load which feeds the conversion.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
The patch LGTM, but I really think the test case should change to more clearly convey the behaviour you desire to test.
llvm/test/CodeGen/PowerPC/cvt_i64_to_fp.ll | ||
---|---|---|
16 | Am I misreading this? It looks like the test is actually testing for the undesired behaviour. Namely, we load the value from the parameter pointer (presumably increment it there), store it to stack - 8, then load it from stack - 8 into an FPR and convert. Of course, this comment is tongue-in-cheek and I assume that the stores to the stack are before the increment and there are a pair of stores to the parameter pointer of the incremented value - but there is nothing in this test case to show that. Namely, this would equivalently match this wrong sequence: lwz 5, 4(3) addic 5, 5, 1 stw 5, -4(1) stw 5, 4(3) lwz 5, 0(3) addze 5, 5 stw 5, -8(1) stw 5, 0(3) lfd 1, -8(1) fcfid 1, 1 So my advice is to use the script to produce the checks as it is more maintainable and easy to prevent issues such as this. However, if you prefer not to use it, you should at least show the increment and the other stores to show that we are storing the incremented value to the parameter pointer and the non-incremented value to the stack. |
Out of curiousity, is there a reason for specifying freebsd vs linux?