| Commit message (Collapse) | Author | Age | Files | Lines | |
|---|---|---|---|---|---|
| * | misc | 2025-10-15 | 1 | -0/+1 | |
| | | |||||
| * | regalloc: start implementing linear scan | 2025-09-08 | 1 | -10/+6 | |
| | | |||||
| * | add initializers (only static for initialier list rn) | 2023-06-29 | 1 | -31/+25 | |
| | | | | | and other fixes | ||||
| * | backend: fix mem2reg & regalloc | 2023-06-26 | 1 | -3/+2 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | they were broken, especially for unstructured control flow. most significant fix is to register allocator for temporaries that are used before the first definition in the source order, e.g.: @1: %x = add %y, 1 b @3 @2 %y = ... b @1 it's legal for %x to use %y there (assuming @2 dominates @1) but from the point of view of the register allocator %y is defined and freed and then used again, which broke things. the fix is to introduce phis for this situation: @1: %y.1 = phi @2 %y %x = add %y.1, 1 b @3 @2 %y = ... b @1 then regalloc phi handling code makes it work | ||||
| * | backend: fix regalloc to work with more complex dataflow | 2023-06-24 | 1 | -5/+6 | |
| | | | | | | | | | basically an allocation map at the beginning (in) and end (out) of each block is kept and after the first allocation pass another pass is ran to resolve allocation conflicts between each edge, plus another pass to finish lowering phi functions. also introduced `regset` and plenty of other miscellaneous fixes | ||||
| * | change RMORE -> RADDR; use RXXX (RNONE) for special args,also undef | 2023-06-22 | 1 | -6/+6 | |
| | | |||||
| * | mem2reg: implement ssa construction; this breaks regalloc right now | 2023-06-21 | 1 | -0/+7 | |
| | | |||||
| * | explicitly store predecessors in each block | 2023-06-21 | 1 | -10/+10 | |
| | | |||||
| * | don't lower params and args to registers in abi0 | 2023-06-20 | 1 | -0/+5 | |
| | | | | | | it's better to do it later, currently in isel(), but perhaps in a pre-isel abi1 pass | ||||
| * | fix cls logic for comparison instrs | 2023-06-20 | 1 | -4/+7 | |
| | | | | | | | | | previously instr.cls always represented the output dataclass. this doesn't work for comparisons because we know the output is always a boolean integer and we care about the actual comparison dataclass. so now .cls represents the operation dataclass, which matches the result class except for comparisons where the result is always KI4V | ||||
| * | backend: compile comparison instrs and branches | 2023-06-19 | 1 | -7/+1 | |
| | | |||||
| * | add %y symbol printing | 2023-06-19 | 1 | -4/+2 | |
| | | |||||
| * | don't try to compile when debugging IR | 2023-06-19 | 1 | -3/+2 | |
| | | |||||
| * | ELF output static data | 2023-06-18 | 1 | -1/+1 | |
| | | |||||
| * | simpler handling of large constants in IR | 2023-06-14 | 1 | -5/+5 | |
| | | |||||
| * | use a hashtable for addr refs | 2023-06-13 | 1 | -2/+1 | |
| | | |||||
| * | lower allocas in isel() instead of emit() and misc fixes | 2023-06-13 | 1 | -3/+3 | |
| | | |||||
| * | remove RPARAM, add Oparam, lower args/rets to abi regs in abi0 | 2023-06-11 | 1 | -7/+4 | |
| | | |||||
| * | isel skeleton | 2023-06-10 | 1 | -14/+37 | |
| | | |||||
| * | codegen skeleton | 2023-06-06 | 1 | -1/+8 | |
| | | |||||
| * | encode calls a different way in the IR | 2023-06-05 | 1 | -34/+39 | |
| | | |||||
| * | style | 2023-06-05 | 1 | -5/+5 | |
| | | |||||
| * | strlits | 2023-06-05 | 1 | -4/+53 | |
| | | |||||
| * | command line switch for debug options | 2023-06-05 | 1 | -2/+2 | |
| | | |||||
| * | bugfix | 2023-06-04 | 1 | -0/+4 | |
| | | |||||
| * | abi lowering pass | 2023-06-04 | 1 | -10/+20 | |
| | | |||||
| * | basic ABI lowering of aggregates | 2023-06-01 | 1 | -17/+29 | |
| | | |||||
| * | struct args and return | 2023-06-01 | 1 | -14/+26 | |
| | | |||||
| * | regalloc skeleton | 2023-05-31 | 1 | -4/+7 | |
| | | |||||
| * | phis? | 2023-05-30 | 1 | -13/+26 | |
| | | |||||
| * | hm | 2023-05-26 | 1 | -2/+2 | |
| | | |||||
| * | initial commit | 2023-05-10 | 1 | -0/+124 | |