Commit graph

246 commits

Author SHA1 Message Date
615c66f304 Add remaining arithmetic comparisons (and test program) to USC 2025-07-07 15:51:11 +02:00
4a52ff534f Remove now unused and useless functions from compiler backend 2025-07-07 14:37:45 +02:00
92f2b02675 Add COMPILE-IR methods for remaining arithmetic tests 2025-07-06 22:37:37 +02:00
ccd06bc8cb Fix typo that makes a comment confusing 2025-07-06 22:30:03 +02:00
016d7ededd Various additions and changes to compiler backend for IFs and calls
Branching now exists in a general way (work for tests requiring
multiple branch instructions still needed) that works for both storing
test results and taking branches in code.

De-duplicated arguments to calls now load correctly.
2025-07-06 22:26:34 +02:00
9685f00e10 Make value allocator aware of normal values used in branching
This way we avoid allocating and using a temporary variable when
branching based on the contents of a variable.
2025-07-06 22:22:18 +02:00
b1b7d863b5 Fix parser for "if <variable name> then" 2025-07-06 22:21:59 +02:00
5d9932637d Fix parser for empty argument lists 2025-07-06 22:21:40 +02:00
156edc2f09 Rethink how data works at the assembly code generation level 2025-07-06 19:04:36 +02:00
99d1156e7d Add PRINT-OBJECT method to ASM-FUNCTION 2025-07-06 18:55:27 +02:00
fa4458e2d7 Add example-3.c6l 2025-07-04 11:21:29 +02:00
76cd607bab Add COMPILE-IR method for IR-MINUS 2025-07-03 20:12:59 +02:00
f814f9fbb9 Some horrible flailing for the sake of correctness 2025-07-03 20:11:08 +02:00
c668f4fc78 Some cleanup after deleted code 2025-07-03 19:54:15 +02:00
hugova
590d7533d9 Remove bodge macro in circledraw and use jmp in other addressing mode 2025-07-03 17:50:52 +02:00
f54ecb75b9 Make linking and final compile to byte sequence work 2025-07-03 16:58:29 +02:00
f9a69e2da9 Add macro for iterating over ASM-OBJECTs 2025-07-03 16:57:33 +02:00
0117df02f8 Indentation correction 2025-07-03 16:57:20 +02:00
771748d2c2 Compute addresses for all ASM-OBJECTs 2025-07-03 16:56:49 +02:00
a24c5353a5 Add compilation method for IR-IF 2025-07-03 16:56:32 +02:00
3876801960 Add compilation method for IR-JUMP 2025-07-03 16:56:10 +02:00
f9d8ad13d0 Add compilation method for IR-TEST-EQUAL 2025-07-03 16:55:39 +02:00
dda08e6fe7 Make all ASM-OBJECTs hold an address, not just labels 2025-07-03 16:54:49 +02:00
f38d74db4f Correct byte length of a JSR 2025-07-03 16:54:40 +02:00
d88107a209 Add functions for handling bools during code generation 2025-07-03 16:54:22 +02:00
f54e064fda Make ASM-FUNCTION hold an address to be called 2025-07-03 16:53:00 +02:00
3b8c906d75 Store ASM-FUNCTIONs in a hash table keyed on name
TODO: Populate the table based on the asm source code declaration
comments and signal an error when a named function is missing.
2025-07-03 16:51:47 +02:00
094f01d258 Ensure IBLOCK names are unique 2025-07-03 15:59:41 +02:00
7171398c07 Fix broken IR graph flow with merge iblocks 2025-07-03 15:58:56 +02:00
235ca8c07e Rename EMIT-STORE-RESULT's parameter to match similar functions 2025-07-03 10:54:21 +02:00
54d2341ce3 Add code-generator.lisp to ASD 2025-07-03 10:30:14 +02:00
f1cf8ad488 Add alexandria dependency 2025-07-03 10:30:14 +02:00
4899d888aa Add COMPILE-IR method for IR-RETURN 2025-07-03 10:30:14 +02:00
c41fb46457 Make assembly program representation smarter
Storing assembly instructions in a list felt nice since that lets me
just fire and forget, but if we want to properly optimize short
branches (i.e. branches that do not require a full JMP) we'll need to
be able to rewrite assembly after linking, and I feel that's best done
by making assembly instructions hold a NEXT rather than poking at a
list clumsily.

The first linking pass was also moved out to a separate function since
we may want to run the first pass twice, first after the initial
assembling and second after expanding optimistic short branches (those
that turned out to be longer branches than 127/128 bytes) into a long
branch snippet (branch with inverted condition skipping over a JMP).
2025-07-03 10:30:14 +02:00
hugova
0ceb455031 Add more more minute optimisations of circle draw 2025-07-02 02:15:06 +02:00
hugova
0ed8359f66 more minute optimisations of circle draw 2025-07-02 01:17:08 +02:00
hugova
913a6ba072 optimize circle draw (more code cleanup) 2025-07-02 00:45:41 +02:00
hugova
5bb62aed88 optimise circle using lookup table 2025-07-01 23:49:35 +02:00
7d55bc9ed8 Add extremely unfinished 6502 code generator to user-side compiler 2025-07-01 23:12:20 +02:00
f8f5892d98 Somewhat clunky optimization for reusing temporary variable slots 2025-07-01 20:39:09 +02:00
hugova
3f470688a4 make line drawing slightly faster, and make it a bit smaller 2025-07-01 20:11:18 +02:00
hugova
e0314e8530 added more extensive testing on circle draw and found a bug that depends on the circle x-pos 2025-07-01 15:16:59 +02:00
hugova
5f1558ce22 fix circle issues by adding propper offsets to circle half quarters. 2025-07-01 14:47:30 +02:00
a18c13a86e Add value allocator (typically called register allocator)
It's unfinished and doesn't optimize space used by temporary
variables. Every temporary gets its own memory slot right now.
2025-07-01 13:38:31 +02:00
bdb2a901ca Add more optimization passes to a test snippet 2025-07-01 13:27:24 +02:00
7aff9db800 Add compiler optimization to get rid of IR-FETCHVARs when unneeded
It replaces the IR-FETCHVAR's result with the variable being
fetched. This only works when the only use is in an operation that
does not require a separate fetch be performed, such as those
implemented as CPU instructions.
2025-07-01 13:25:42 +02:00
b7c4a37483 Make data keep track of their last use 2025-07-01 13:22:24 +02:00
hugova
c1846e35bd add more circle testing and remove none working offsets 2025-07-01 01:19:21 +02:00
hugova
7196992043 Add last part to circle, still a bit buggy 2025-07-01 00:06:04 +02:00
hugova
6c962befa2 optimise circle draw by redusing instructions 2025-06-30 23:41:55 +02:00