Commit 1faa946
committed
[AArch64] Combine vector add(trunc(shift))
This adds a combine for
add(trunc(ashr(A, C)), trunc(lshr(B, 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 c826466 commit 1faa946
File tree
2 files changed
+79
-28
lines changed- llvm
- lib/Target/AArch64
- test/CodeGen/AArch64
2 files changed
+79
-28
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
105 | 105 | | |
106 | 106 | | |
107 | 107 | | |
| 108 | + | |
108 | 109 | | |
109 | 110 | | |
110 | 111 | | |
| |||
22595 | 22596 | | |
22596 | 22597 | | |
22597 | 22598 | | |
| 22599 | + | |
| 22600 | + | |
| 22601 | + | |
| 22602 | + | |
| 22603 | + | |
| 22604 | + | |
| 22605 | + | |
| 22606 | + | |
| 22607 | + | |
| 22608 | + | |
| 22609 | + | |
| 22610 | + | |
| 22611 | + | |
| 22612 | + | |
| 22613 | + | |
| 22614 | + | |
| 22615 | + | |
| 22616 | + | |
| 22617 | + | |
| 22618 | + | |
| 22619 | + | |
| 22620 | + | |
| 22621 | + | |
| 22622 | + | |
| 22623 | + | |
| 22624 | + | |
| 22625 | + | |
| 22626 | + | |
| 22627 | + | |
| 22628 | + | |
| 22629 | + | |
22598 | 22630 | | |
22599 | 22631 | | |
22600 | 22632 | | |
| |||
22618 | 22650 | | |
22619 | 22651 | | |
22620 | 22652 | | |
| 22653 | + | |
| 22654 | + | |
22621 | 22655 | | |
22622 | 22656 | | |
22623 | 22657 | | |
| |||
28125 | 28159 | | |
28126 | 28160 | | |
28127 | 28161 | | |
28128 | | - | |
28129 | 28162 | | |
28130 | 28163 | | |
28131 | 28164 | | |
| |||
| 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