aboutsummaryrefslogtreecommitdiffhomepage
path: root/amd64
Commit message (Collapse)AuthorAgeFilesLines
...
* isel: fix 3-address add when used for flags in branchlemon2025-11-021-0/+3
|
* isel fixeslemon2025-10-302-4/+11
|
* isel: fix address sel for absolute int addrlemon2025-10-261-0/+7
|
* emit: remove unnecessary REX.W prfix for TEST r8lemon2025-10-261-1/+1
|
* amd64: add/sub operands less restrictivelemon2025-10-251-2/+2
|
* c: avoid generating relocations in .rodata (putting such objects in .data ↵lemon2025-10-251-1/+3
| | | | instead for now)
* emit: PU8, PU16lemon2025-10-251-0/+6
|
* amd64 rbpofflemon2025-10-241-1/+1
|
* amd64 missing stufflemon2025-10-232-3/+12
|
* isel: fix -fpic factoring out non-symbolic address operandslemon2025-10-231-1/+1
|
* amd64: load/store from abs address constants; movabslemon2025-10-232-21/+51
|
* amd64/emit PI8 fix int overflow edgecaselemon2025-10-231-1/+1
|
* fix edge case codegen bugs (w/ stack offsets, spilling)lemon2025-10-221-0/+2
|
* amd64/emit erratalemon2025-10-201-1/+1
|
* Organize source files into directorieslemon2025-10-192-2/+2
|
* amd64: float conversion insntrslemon2025-10-182-2/+43
|
* small thignslemon2025-10-181-1/+1
|
* codegen bugfixlemon2025-10-171-5/+13
|
* amd64: not, udivlemon2025-10-141-0/+13
|
* amd64: mul -> imullemon2025-10-131-8/+9
|
* bugfixeslemon2025-10-101-0/+1
|
* initial implementation of run-time array/aggregate initializerslemon2025-10-081-0/+4
|
* fix some more codegen bugs for symbol constantslemon2025-09-162-4/+6
|
* codegen: fix 3-address sub reg,imm codegenlemon2025-09-151-1/+1
|
* start implementing bitfieldslemon2025-09-141-0/+6
|
* codegen: float cmp, ior; frontend: fix cond expr buglemon2025-09-142-5/+21
|
* preliminary pie and piclemon2025-09-142-19/+62
|
* regalloc: basic spilling supportlemon2025-09-132-0/+7
|
* amd64: improve codegen for ADDlemon2025-09-111-0/+3
|
* amd64: bugfix for stack args with no RBP, also reuse epilogue code?lemon2025-09-111-26/+48
|
* amd64/emit: fix order of stack restore operations with regs+stklemon2025-09-091-6/+11
|
* ioperlemon2025-09-091-12/+21
|
* fixes, delnopslemon2025-09-091-2/+2
|
* amd64: swap, sarlemon2025-09-081-1/+21
|
* amd64: bugfixlemon2025-09-082-5/+9
|
* amd64: fix isel for numeric conversion opslemon2023-08-071-4/+4
|
* amd64: add mulf and divf codegenlemon2023-08-071-3/+18
|
* amd64/emit bugfixlemon2023-07-091-3/+3
|
* amd64 codegen fixeslemon2023-07-072-13/+20
|
* fix emit() setcc and copylemon2023-07-061-1/+2
|
* misc bugfixslemon2023-06-302-23/+92
|
* add initializers (only static for initialier list rn)lemon2023-06-292-34/+91
| | | | and other fixes
* fix some warningslemon2023-06-251-9/+1
|
* fix regalloc thinking some ins are dead by adding ins.keeplemon2023-06-241-1/+5
|
* amd64/emit: more float fixeslemon2023-06-241-21/+24
| | | | | optimize loading 0.0 in phis as well as regular copies and also don't use inc or addr for float addition
* backend: don't mixup float and int tempslemon2023-06-241-3/+3
| | | | | | copy propagation only happens when dataclasses match, register allocator ignores hints if hint register class and instruction class differ, also add mov between int and float regs in amd64/emit
* backend: fix regalloc to work with more complex dataflowlemon2023-06-243-7/+25
| | | | | | | | 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 undeflemon2023-06-222-26/+26
|
* explicitly store predecessors in each blocklemon2023-06-211-4/+4
|
* amd64: fix aggregate return in regslemon2023-06-201-3/+3
|