|
1 | 1 | func0000000000000015: |
2 | 2 | li a0, 6 |
3 | 3 | vsetivli zero, 4, e32, m1, ta, ma |
4 | | - vmul.vx v8, v8, a0 |
5 | | - vsetvli zero, zero, e64, m2, ta, ma |
6 | | - vsext.vf2 v10, v8 |
7 | | - vsll.vi v8, v10, 2 |
| 4 | + vmul.vx v10, v8, a0 |
8 | 5 | li a0, 24 |
9 | | - vadd.vx v8, v8, a0 |
| 6 | + vsetvli zero, zero, e64, m2, ta, ma |
| 7 | + vmv.v.x v8, a0 |
| 8 | + li a0, 4 |
| 9 | + vsetvli zero, zero, e32, m1, ta, ma |
| 10 | + vwmaccus.vx v8, a0, v10 |
10 | 11 | ret |
11 | 12 |
|
12 | 13 | func000000000000001d: |
13 | 14 | li a0, 94 |
14 | | - vsetivli zero, 4, e32, m1, ta, ma |
| 15 | + vsetivli zero, 4, e64, m2, ta, ma |
| 16 | + vmv.v.i v10, -4 |
| 17 | + vsetvli zero, zero, e32, m1, ta, ma |
15 | 18 | vmul.vx v8, v8, a0 |
16 | | - vsetvli zero, zero, e64, m2, ta, ma |
17 | | - vsext.vf2 v10, v8 |
18 | | - vsll.vi v8, v10, 2 |
19 | | - vadd.vi v8, v8, -4 |
| 19 | + li a0, 4 |
| 20 | + vwmaccus.vx v10, a0, v8 |
| 21 | + vmv2r.v v8, v10 |
20 | 22 | ret |
21 | 23 |
|
22 | 24 | func000000000000000d: |
23 | 25 | li a0, 3 |
24 | | - vsetivli zero, 4, e32, m1, ta, ma |
| 26 | + vsetivli zero, 4, e64, m2, ta, ma |
| 27 | + vmv.v.i v10, -4 |
| 28 | + vsetvli zero, zero, e32, m1, ta, ma |
25 | 29 | vmul.vx v8, v8, a0 |
26 | | - vsetvli zero, zero, e64, m2, ta, ma |
27 | | - vsext.vf2 v10, v8 |
28 | | - vsll.vi v8, v10, 2 |
29 | | - vadd.vi v8, v8, -4 |
| 30 | + li a0, 4 |
| 31 | + vwmaccus.vx v10, a0, v8 |
| 32 | + vmv2r.v v8, v10 |
30 | 33 | ret |
31 | 34 |
|
32 | 35 | func0000000000000005: |
33 | 36 | li a0, 3 |
34 | 37 | vsetivli zero, 4, e32, m1, ta, ma |
35 | | - vmul.vx v8, v8, a0 |
36 | | - vsetvli zero, zero, e64, m2, ta, ma |
37 | | - vsext.vf2 v10, v8 |
38 | | - vsll.vi v8, v10, 3 |
| 38 | + vmul.vx v10, v8, a0 |
39 | 39 | li a0, 88 |
40 | | - vadd.vx v8, v8, a0 |
| 40 | + vsetvli zero, zero, e64, m2, ta, ma |
| 41 | + vmv.v.x v8, a0 |
| 42 | + li a0, 8 |
| 43 | + vsetvli zero, zero, e32, m1, ta, ma |
| 44 | + vwmaccus.vx v8, a0, v10 |
41 | 45 | ret |
42 | 46 |
|
0 commit comments