73 lines
2.7 KiB
Factor
73 lines
2.7 KiB
Factor
USING: compiler.cfg.write-barrier compiler.cfg.instructions
|
|
compiler.cfg.registers cpu.architecture arrays tools.test ;
|
|
IN: compiler.cfg.write-barrier.tests
|
|
|
|
[
|
|
{
|
|
T{ ##peek f V int-regs 4 D 0 f }
|
|
T{ ##copy f V int-regs 6 V int-regs 4 f }
|
|
T{ ##allot f V int-regs 7 24 array V int-regs 8 f }
|
|
T{ ##load-immediate f V int-regs 9 8 f }
|
|
T{ ##set-slot-imm f V int-regs 9 V int-regs 7 1 3 f }
|
|
T{ ##set-slot-imm f V int-regs 6 V int-regs 7 2 3 f }
|
|
T{ ##replace f V int-regs 7 D 0 f }
|
|
}
|
|
] [
|
|
{
|
|
T{ ##peek f V int-regs 4 D 0 }
|
|
T{ ##copy f V int-regs 6 V int-regs 4 }
|
|
T{ ##allot f V int-regs 7 24 array V int-regs 8 }
|
|
T{ ##load-immediate f V int-regs 9 8 }
|
|
T{ ##set-slot-imm f V int-regs 9 V int-regs 7 1 3 }
|
|
T{ ##write-barrier f V int-regs 7 V int-regs 10 V int-regs 11 }
|
|
T{ ##set-slot-imm f V int-regs 6 V int-regs 7 2 3 }
|
|
T{ ##write-barrier f V int-regs 7 V int-regs 12 V int-regs 13 }
|
|
T{ ##replace f V int-regs 7 D 0 }
|
|
} eliminate-write-barriers
|
|
] unit-test
|
|
|
|
[
|
|
{
|
|
T{ ##load-immediate f V int-regs 4 24 }
|
|
T{ ##peek f V int-regs 5 D -1 }
|
|
T{ ##peek f V int-regs 6 D -2 }
|
|
T{ ##set-slot-imm f V int-regs 5 V int-regs 6 3 2 }
|
|
T{ ##write-barrier f V int-regs 6 V int-regs 7 V int-regs 8 }
|
|
}
|
|
] [
|
|
{
|
|
T{ ##load-immediate f V int-regs 4 24 }
|
|
T{ ##peek f V int-regs 5 D -1 }
|
|
T{ ##peek f V int-regs 6 D -2 }
|
|
T{ ##set-slot-imm f V int-regs 5 V int-regs 6 3 2 }
|
|
T{ ##write-barrier f V int-regs 6 V int-regs 7 V int-regs 8 }
|
|
} eliminate-write-barriers
|
|
] unit-test
|
|
|
|
[
|
|
{
|
|
T{ ##peek f V int-regs 19 D -3 }
|
|
T{ ##peek f V int-regs 22 D -2 }
|
|
T{ ##copy f V int-regs 23 V int-regs 19 }
|
|
T{ ##set-slot-imm f V int-regs 22 V int-regs 23 3 2 }
|
|
T{ ##write-barrier f V int-regs 23 V int-regs 24 V int-regs 25 }
|
|
T{ ##copy f V int-regs 26 V int-regs 19 }
|
|
T{ ##peek f V int-regs 28 D -1 }
|
|
T{ ##copy f V int-regs 29 V int-regs 19 }
|
|
T{ ##set-slot-imm f V int-regs 28 V int-regs 29 4 2 }
|
|
}
|
|
] [
|
|
{
|
|
T{ ##peek f V int-regs 19 D -3 }
|
|
T{ ##peek f V int-regs 22 D -2 }
|
|
T{ ##copy f V int-regs 23 V int-regs 19 }
|
|
T{ ##set-slot-imm f V int-regs 22 V int-regs 23 3 2 }
|
|
T{ ##write-barrier f V int-regs 23 V int-regs 24 V int-regs 25 }
|
|
T{ ##copy f V int-regs 26 V int-regs 19 }
|
|
T{ ##peek f V int-regs 28 D -1 }
|
|
T{ ##copy f V int-regs 29 V int-regs 19 }
|
|
T{ ##set-slot-imm f V int-regs 28 V int-regs 29 4 2 }
|
|
T{ ##write-barrier f V int-regs 29 V int-regs 30 V int-regs 3 }
|
|
} eliminate-write-barriers
|
|
] unit-test
|