2022-04-08 16:40:28 +03:00
|
|
|
- type casting nodes
|
|
|
|
- overflow detection nodes
|
|
|
|
- va_arg nodes
|
2022-04-20 12:00:36 +03:00
|
|
|
+ VADDR to pass VAR by address
|
2022-04-08 16:40:28 +03:00
|
|
|
- BSTART, BEND nodes (to free data allocated by ALLOCA)
|
|
|
|
- ENTRY node for multy-entry units
|
|
|
|
- IJMP
|
|
|
|
- guards
|
|
|
|
- variable name binding
|
|
|
|
|
|
|
|
- VLOAD, VSTORE -> SSA
|
|
|
|
|
|
|
|
? reassociation folding rules
|
|
|
|
- folding engine improvement (one rule for few patterns)
|
|
|
|
|
|
|
|
- irreducable loops detection
|
|
|
|
- irreducable loops support
|
|
|
|
|
|
|
|
- range inference and PI node
|
|
|
|
- SCCP edge cases
|
2022-04-08 19:02:11 +03:00
|
|
|
- Folding after SCCP (see combo4.ir)
|
2022-04-08 16:40:28 +03:00
|
|
|
|
|
|
|
- local scheduling according to data dependencies, register presure and pipeline stalls
|
|
|
|
- basic block trace scheduling
|
|
|
|
|
|
|
|
? instruction selection
|
|
|
|
- xor, btsl=INCL, btrl=EXCL, btl=IN, bsr, maxss, maxsd, minss, minsd
|
|
|
|
- MOVZX to avoid a SHIFT and AND instruction
|
2022-04-21 10:20:41 +03:00
|
|
|
- Use CMOVcc to remove branches
|
2022-04-08 16:40:28 +03:00
|
|
|
|
|
|
|
? register allocation
|
|
|
|
+ linear scan
|
2022-04-15 14:22:35 +03:00
|
|
|
+ allocate scratch registers first
|
2022-04-08 16:40:28 +03:00
|
|
|
- separate INT and FP allocation phases
|
|
|
|
+ use positions
|
2022-04-21 10:20:41 +03:00
|
|
|
+ fixed registers constraints
|
2022-04-08 16:40:28 +03:00
|
|
|
+ fixed input
|
|
|
|
+ fixed output
|
|
|
|
+ fixed tmp
|
|
|
|
+ fixed intervals for parameters
|
2022-04-21 10:20:41 +03:00
|
|
|
+ accurate fixed interval construction
|
2022-04-08 16:40:28 +03:00
|
|
|
- constraints
|
2022-04-21 10:20:41 +03:00
|
|
|
+ result reuses op1
|
2022-04-08 16:40:28 +03:00
|
|
|
- kill
|
|
|
|
- restricted regset
|
2022-04-21 10:20:41 +03:00
|
|
|
- must be in register
|
2022-04-08 16:40:28 +03:00
|
|
|
- temporary registers
|
|
|
|
? spills
|
2022-04-19 22:35:29 +03:00
|
|
|
+ spill slot allocation (uniqe for each VREG)
|
|
|
|
- spill slot allocation (packed/aligned according to SpillRange)
|
2022-04-15 14:22:35 +03:00
|
|
|
? splitting
|
2022-04-08 16:40:28 +03:00
|
|
|
- splinting
|
|
|
|
- spill only at cold path if possible
|
|
|
|
? hints
|
|
|
|
+ hints for fixed input/outpu registers
|
|
|
|
+ hints for parameter nodes
|
2022-04-15 14:22:35 +03:00
|
|
|
+ hints for call arguments
|
2022-04-21 10:20:41 +03:00
|
|
|
+ hints for nodes that reuse input (result reuses op1)
|
2022-04-08 16:40:28 +03:00
|
|
|
- hints propagation
|
|
|
|
- hints and low priority
|
|
|
|
|
|
|
|
? code generation
|
2022-04-21 00:31:28 +03:00
|
|
|
+ NEG (fp), ABS
|
2022-04-20 10:03:00 +03:00
|
|
|
- OVERFLOW
|
|
|
|
- MIN, MAX, COND
|
|
|
|
- CAST
|
2022-04-15 16:44:12 +03:00
|
|
|
+ TAILCALL
|
2022-04-20 12:00:36 +03:00
|
|
|
+ VLOAD, VSTORE, VADDR
|
2022-04-22 12:55:38 +03:00
|
|
|
+ ALLOCA, LOAD, STORE
|
2022-04-12 10:37:20 +03:00
|
|
|
+ SWITCH
|
2022-04-21 21:47:00 +03:00
|
|
|
? ir_last_use
|
2022-04-22 12:11:30 +03:00
|
|
|
+ binop_int $imm, mem
|
2022-04-21 21:47:00 +03:00
|
|
|
? commutative insns and swap (binop_int, mul, binop_sse, binop_avx, cmp_int, cmp_fp, cmp_br_int)
|
2022-04-19 14:11:07 +03:00
|
|
|
- temporary register (e.g. for unsupported immediate operand in mul, div, and 64-bit constants)
|
|
|
|
? temporary register for swap (dessa3.ir)
|
2022-04-12 10:37:20 +03:00
|
|
|
- temporary register for spill loads and stores
|
2022-04-12 15:08:17 +03:00
|
|
|
+ parallel argument passing
|
2022-04-21 10:20:41 +03:00
|
|
|
- stack arguments and parameters
|
2022-04-08 16:40:28 +03:00
|
|
|
- return merge/split
|
|
|
|
? binary code emission
|
|
|
|
+ DynAsm
|
|
|
|
- BinAsm
|
2022-04-12 10:37:20 +03:00
|
|
|
- 32-bit x86 code
|
2022-04-08 16:40:28 +03:00
|
|
|
|
|
|
|
? disassembler
|
|
|
|
- .rodata section and relative data labels
|
|
|
|
|
|
|
|
- modules (functions, data objecs, import, export, prototypes, forward declarations, memory segments, ref data, expr data)
|
|
|
|
- C compiler
|
|
|
|
- interpreter
|
|
|
|
- alias analyzes
|
|
|
|
|
|
|
|
- PHP support
|
|
|
|
|