Add some AArch64 dag combines to optimize some simple TBZ/TBNZ cases:
(tbz (and x, m), b) -> (tbz x, b)
 (tbz (shl x, c), b) -> (tbz x, b-c)
 (tbz (shr x, c), b) -> (tbz x, b+c)
 (tbz (xor x, -1), b) -> (tbnz x, b)
|  Differential  D15702  
[AArch64] Optimize some simple TBZ/TBNZ cases. Authored by gberry on Dec 21 2015, 1:57 PM. 
Details Add some AArch64 dag combines to optimize some simple TBZ/TBNZ cases: (tbz (and x, m), b) -> (tbz x, b) 
Diff Detail Event TimelineComment Actions Hi Geoff, looks good. :-) I have some potentially silly questions inline, just curiosities. 
 Comment Actions Chad, Charlie, Thanks for the review. I believe I have addressed all of your concerns. Charlie, as to your question about folding opportunities, I don't think those should occur (they should have already been optimized). I did a test run to detect if any of these cases show up and was unable to find a single occurrence. I did however hit a few instances of a missing case of a tbz of an ashr that was essentially testing the carried-in sign bit (see the test case test18 for an example). I added some new code to handle that case in the latest version of the change. | |||||||||
Please remove the extra curly brackets.