Commit f52550a
[AArch64] Combine vector add(trunc(shift)) (llvm#169523)
This adds a combine for
add(trunc(ashr(A, C)), trunc(lshr(A, BW-1))), with C >= BW
->
X = trunc(ashr(A, C)); add(x, lshr(X, BW-1)
The original converts into ashr+lshr+xtn+xtn+add. The second becomes
ashr+xtn+usra. The first form has less total latency due to more
parallelism,
but more micro-ops and seems to be slower in practice.1 parent 836a319 commit f52550a
File tree
2 files changed
+79
-27
lines changed- llvm
- lib/Target/AArch64
- test/CodeGen/AArch64
2 files changed
+79
-27
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
22586 | 22586 | | |
22587 | 22587 | | |
22588 | 22588 | | |
| 22589 | + | |
| 22590 | + | |
| 22591 | + | |
| 22592 | + | |
| 22593 | + | |
| 22594 | + | |
| 22595 | + | |
| 22596 | + | |
| 22597 | + | |
| 22598 | + | |
| 22599 | + | |
| 22600 | + | |
| 22601 | + | |
| 22602 | + | |
| 22603 | + | |
| 22604 | + | |
| 22605 | + | |
| 22606 | + | |
| 22607 | + | |
| 22608 | + | |
| 22609 | + | |
| 22610 | + | |
| 22611 | + | |
| 22612 | + | |
| 22613 | + | |
| 22614 | + | |
| 22615 | + | |
| 22616 | + | |
| 22617 | + | |
| 22618 | + | |
| 22619 | + | |
| 22620 | + | |
22589 | 22621 | | |
22590 | 22622 | | |
22591 | 22623 | | |
| |||
22609 | 22641 | | |
22610 | 22642 | | |
22611 | 22643 | | |
| 22644 | + | |
| 22645 | + | |
22612 | 22646 | | |
22613 | 22647 | | |
22614 | 22648 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
6 | | - | |
7 | | - | |
8 | | - | |
9 | | - | |
10 | | - | |
11 | | - | |
12 | | - | |
13 | | - | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
14 | 21 | | |
15 | 22 | | |
16 | 23 | | |
| |||
21 | 28 | | |
22 | 29 | | |
23 | 30 | | |
24 | | - | |
25 | | - | |
26 | | - | |
27 | | - | |
28 | | - | |
29 | | - | |
30 | | - | |
31 | | - | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
32 | 46 | | |
33 | 47 | | |
34 | 48 | | |
| |||
39 | 53 | | |
40 | 54 | | |
41 | 55 | | |
42 | | - | |
43 | | - | |
44 | | - | |
45 | | - | |
46 | | - | |
47 | | - | |
48 | | - | |
49 | | - | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
50 | 71 | | |
51 | 72 | | |
52 | 73 | | |
| |||
91 | 112 | | |
92 | 113 | | |
93 | 114 | | |
94 | | - | |
95 | | - | |
96 | | - | |
| |||
0 commit comments