Implemente patterns to extract W vector elements and convert to QP
Details
Diff Detail
Event Timeline
I think we should review the code sequences for signed conversions and make more consistent use of loops.
lib/Target/PowerPC/PPCInstrVSX.td | ||
---|---|---|
3164–3165 | This probably needs let Predicates = [IsBigEndian, HasP9Vector] right? | |
3167 | Is this sequence actually correct? We convert a vector of 4 4-byte integers into a vector of 2 8-byte double precision floating point values. Then we treat it as a signed 8-byte integer and convert it to a 16-byte floating point value. Shouldn't the outer instruction be xscvdpqp? In any case, vextsw2d -> xscvsdqp is a much lower latency sequence than this. Why not use that? | |
3175 | Is there no mul function in TableGen? i.e. can't we just write !mul(Idx, 4)? | |
3194–3216 | Same note regarding the predicate. | |
3196 | To be consistent, I think you should write these as a neat for-loop as you did above. The element would be Idx and the splat index would be !sub(3, Idx). Wouldn't that work? | |
3207 | Same thing here, a for-loop would be nicer and more consistent. |
lib/Target/PowerPC/PPCInstrVSX.td | ||
---|---|---|
3164–3165 | This is within a Predicates = [HasP9Vector] section so is not needed here. | |
3167 | I guess there is no need for us to convert to double precision here. Will update. | |
3175 | There is only !add(a,b,...) | |
3194–3216 | this is within a Predicates = [HasP9Vector] code section. | |
3196 | Unfortunately there is no !sub() operator. | |
3207 | I agree. I just couldn't find a way to do it with just !add() |
lib/Target/PowerPC/PPCInstrVSX.td | ||
---|---|---|
3167 | It is actually word 1 that doesn't need the splat. Word 0 does need a splat. | |
3196 | This should actually be foreach Idx = [[0,3],[1,2],[3,0]] shouldn't it? For LE word element 2, VEXTSW2D will sign extend it into LE doubleword element 1 which is where XSCVSDQP needs it to be - so a splat is not needed. LE word element 3 on the other hand will need a splat since the input is in the left half of LE doubleword 1 and it needs to be in the right half. |
LGTM. Feel free to address the minor nit on the commit.
lib/Target/PowerPC/PPCInstrVSX.td | ||
---|---|---|
3202 | Nit: For consistency, move this up before the loop since that's the order of definitions in the big-endian block above. |
This probably needs let Predicates = [IsBigEndian, HasP9Vector] right?