florian
|
9d94ccdc38
* set types of start value calculation correctly when doing strength reduction, resolves #41054
|
10 luni în urmă |
Rika Ichinose
|
11d16be702
Add a bound parameter to node_count(_weighted).
|
3 ani în urmă |
florian
|
3206b2e0cd
* clean up
|
11 luni în urmă |
florian
|
ac4b089e14
* avoid that types of limits of reverted loops are widened
|
11 luni în urmă |
florian
|
c236ac5e97
* revert for loops also if the upper limit is non-constant
|
11 luni în urmă |
J. Gareth "Curious Kit" Moreton
|
2b7df4237b
* nf_pass1_done, nf_error, nf_processing and nf_do_not_execute
|
1 an în urmă |
Yuriy Sydorov
|
7388735b11
* Strength reduction optimization: - Use a temp for complex loop start values to prevent double evaluation.
|
4 ani în urmă |
Yuriy Sydorov
|
6bf4c7a68d
* Optimized evaluation of the condition.
|
4 ani în urmă |
Yuriy Sydorov
|
b2165570de
* Fixed missing assignments with the strength reduction optimization.
|
4 ani în urmă |
Yuriy Sydorov
|
bd4c206472
* Fixed the strength reduction optimization for loops containing 'continue'.
|
4 ani în urmă |
Yuriy Sydorov
|
abe3002b5b
* Fixed lack of the calculation code for the strength reduction optimization.
|
4 ani în urmă |
yury
|
64c586b86d
* Removed/ifdefed lots of unused variables.
|
4 ani în urmă |
florian
|
1ba8255af0
* do not try to unroll a loop if previously an error was thrown, resolves #37475
|
5 ani în urmă |
florian
|
aca9727418
+ OptimizeForLoop: convert for-loops into zero-based backward for-loops if possible, for most architectures, this results in simpler code
|
5 ani în urmă |
florian
|
ac974c9ab7
* improve is_loop_invariant for load nodes
|
5 ani în urmă |
florian
|
507fc9c1ff
+ take care of addn and subn in is_loop_invariant
|
5 ani în urmă |
florian
|
aabd7c7217
* more fixes for loop strength reduction
|
5 ani în urmă |
florian
|
a9a711763f
* some fixes to loop strength reduction
|
5 ani în urmă |
Jonas Maebe
|
281b3ad276
* fix case completeness and unreachable code warnings in compiler that would
|
6 ani în urmă |
florian
|
21d785e41b
* do not unroll loops if the counter variable is accessed outside the current scope
|
7 ani în urmă |
florian
|
8f472d5212
* check for more controll flow statements before doing loop unrolling
|
7 ani în urmă |
florian
|
bd27b7635b
* also in case of constref make_not_regable with ra_addr_taken must be called, later on in pass_1 this happens anyways
|
7 ani în urmă |
florian
|
c59bd8c29a
+ calculate loop unrolling using node_count_weighted which takes care of nodes generating no code
|
7 ani în urmă |
florian
|
512328deee
* include loop unrolling in -O3, as it is done carefully, it is beneficial on average
|
7 ani în urmă |
florian
|
fff6e0ecdb
* unroll more aggressively
|
7 ani în urmă |
nickysn
|
efc5e339d0
* use an enum instead of integer constants to represent inline numbers
|
8 ani în urmă |
florian
|
4731ebeb50
* reset initcode after adding it to the statements list, so further iterations of loop optimization create a new one
|
9 ani în urmă |
florian
|
b59219b8e0
* when getting rid of a for loop by unrolling, simplify the block afterwards,
|
9 ani în urmă |
florian
|
f813703cf3
* fixes several issues with loop unrolling
|
10 ani în urmă |
Jonas Maebe
|
b57c95043f
+ support overriding tdef/tsym methods with target-specific functionality:
|
11 ani în urmă |