1
0
mirror of https://github.com/KarolS/millfork.git synced 2025-01-23 15:31:31 +00:00

599 Commits

Author SHA1 Message Date
Karol Stasiak
807a9df8ac Fixed org option 2018-03-09 00:07:05 +01:00
Karol Stasiak
34b827df38 Small optimization bugfix 2018-03-07 16:22:28 +01:00
Karol Stasiak
1d865302ca Indexing fixes; 16-bit indexing 2018-03-07 12:36:21 +01:00
Karol Stasiak
11337f4975 Optimizing predictable reads from local variables 2018-03-06 23:43:09 +01:00
Karol Stasiak
d4d9dafbbe Inlining improvements 2018-03-06 23:28:03 +01:00
Karol Stasiak
9d1159e923 Documentation improvements 2018-03-06 16:59:18 +01:00
Karol Stasiak
af812fe348 else if 2018-03-06 16:46:50 +01:00
Karol Stasiak
791f910cc4 Optimize away impossible odd/even equalities 2018-03-06 16:44:57 +01:00
Karol Stasiak
9e66a0d252 Optimization performance improvements 2018-03-06 15:49:28 +01:00
Karol Stasiak
53245eb1e2 Single threaded mode 2018-03-06 01:01:22 +01:00
Karol Stasiak
1909fd7154 Initialize constant registers outside loops 2018-03-06 00:22:39 +01:00
Karol Stasiak
addfde48ec Better addition of words on stack on 65816 2018-03-06 00:21:43 +01:00
Karol Stasiak
9634ea9516 Don't emit warnings if an unused variable was assigned a simple expression 2018-03-06 00:20:50 +01:00
Karol Stasiak
92dd5d6913 Flow analysis improvements 2018-03-05 19:14:42 +01:00
Karol Stasiak
0f6bf6e63e HuC6280's SAX and SAY depend on A 2018-03-05 19:13:44 +01:00
Karol Stasiak
3cd6540f13 Slightly faster variable to register optimization 2018-03-05 19:13:20 +01:00
Karol Stasiak
56e4b1fb70 Fixed miscompiled loops 2018-03-05 18:21:20 +01:00
Karol Stasiak
05e147b880 Removal of detailed flow analysis; it was slow and not worth it 2018-03-05 12:41:43 +01:00
Karol Stasiak
15dbaad6d1 Use zero page locations as as pseudo-registers; 8-bit multiplication and 16-bit shifts 2018-03-05 12:05:37 +01:00
Karol Stasiak
656dbef184 Optimize pulling a known constant from the stack in more cases 2018-03-05 11:32:31 +01:00
Karol Stasiak
38efdcc979 Allow inlinging variables to registers if there is a non-conflicting SEP/REP instruction 2018-03-05 11:31:02 +01:00
Karol Stasiak
606011ea38 New target: C64 with SuperCPU in native mode 2018-03-03 21:41:49 +01:00
Karol Stasiak
839c52204f 65816 native mode optimization improvements 2018-03-03 21:36:26 +01:00
Karol Stasiak
50ddd52786 Added break and continue statements 2018-03-03 21:34:12 +01:00
Karol Stasiak
ccb6e35a29 Fixed PHD/PHB-related optimizations 2018-03-03 15:06:49 +01:00
Karol Stasiak
2024c33ef2 Fixed suboptimal selection of variables for register inlining 2018-03-03 15:04:39 +01:00
Karol Stasiak
77797af564 65816 and 65CE02 optimization improvements 2018-03-03 14:33:07 +01:00
Karol Stasiak
33ee5115e0 Better stack- and interrupt handling for 65816 and 65CE02 2018-03-03 14:32:11 +01:00
Karol Stasiak
35f06d5486 Optimizer shouldn't remove LDA's before TSR and TRB 2018-03-03 14:31:06 +01:00
Karol Stasiak
6ed5d51260 Preliminary support for 65816, 65CE02 and HuC6280 2018-03-03 01:21:57 +01:00
Karol Stasiak
b3e96a0c6e Using (zp,X) addressing mode when appropriate 2018-03-01 15:58:28 +01:00
Karol Stasiak
50b93db337 Constant pointer optimization 2018-03-01 15:57:54 +01:00
Karol Stasiak
f8bd496b6b Important bugfixes; removing empty stores to larger variables 2018-03-01 15:57:18 +01:00
Karol Stasiak
3dc526bcb7 hi()/lo() builtins; identity table for using index registers as operands 2018-02-28 01:13:05 +01:00
Karol Stasiak
f31086e686 Inlining improvements and bugfixes 2018-02-28 01:11:14 +01:00
Karol Stasiak
828cef58dd Small optimization fix 2018-02-28 01:09:22 +01:00
Karol Stasiak
608958c1ed Documentation improvements 2018-02-27 13:26:56 +01:00
Karol Stasiak
3d056a7eee Optimization improvements 2018-02-27 12:02:15 +01:00
Karol Stasiak
f9835ebf7e Removed invalid optimization, added bit shifting optimization 2018-02-27 12:01:53 +01:00
Karol Stasiak
51a4fe5859 More pointer space for C64/C128 2018-02-27 11:58:18 +01:00
Karol Stasiak
ee18fecedf Optimize variables only written once 2018-02-27 01:20:42 +01:00
Karol Stasiak
747925f8fd Added new -O1 optimization preset 2018-02-26 17:57:16 +01:00
Karol Stasiak
a2b6a392a5 Lazy flow analysis 2018-02-26 17:12:12 +01:00
Karol Stasiak
b9eb59ad51 Replace pointless LAX and ANC with their legal equivalents 2018-02-26 16:45:01 +01:00
Karol Stasiak
0f354d2f14 Fix for a bug in the variable-to-register optimization 2018-02-26 16:44:28 +01:00
Karol Stasiak
3c3ac9d70e Simple loop unrolling; --blast-processing command line option 2018-02-26 12:22:10 +01:00
Karol Stasiak
6f9ee33514 Added -Of and -Os command line options 2018-02-26 02:41:18 +01:00
Karol Stasiak
42818df340 Updated changelog 2018-02-26 01:20:50 +01:00
Karol Stasiak
7b480ea876 Even more optimizations 2018-02-26 01:07:23 +01:00
Karol Stasiak
03c400a356 More diagnostic messages after compilation 2018-02-26 01:06:09 +01:00