mirror of
https://github.com/danog/ir.git
synced 2024-12-12 09:19:47 +01:00
25 lines
414 B
Plaintext
25 lines
414 B
Plaintext
|
--TEST--
|
||
|
004: Register Allocation (DIV + MUL)
|
||
|
--TARGET--
|
||
|
Windows-x86_64
|
||
|
--ARGS--
|
||
|
-S
|
||
|
--CODE--
|
||
|
{
|
||
|
l_1 = START(l_4);
|
||
|
uint32_t x_1 = PARAM(l_1, "x", 1);
|
||
|
uint32_t y_1 = PARAM(l_1, "y", 2);
|
||
|
uint32_t z_1 = PARAM(l_1, "z", 3);
|
||
|
uint32_t x_2 = DIV(x_1, y_1);
|
||
|
uint32_t x_3 = MUL(x_2, z_1);
|
||
|
l_4 = RETURN(l_1, x_3);
|
||
|
}
|
||
|
--EXPECT--
|
||
|
test:
|
||
|
movl %edx, %r9d
|
||
|
movl %ecx, %eax
|
||
|
xorl %edx, %edx
|
||
|
divl %r9d
|
||
|
imull %r8d, %eax
|
||
|
retq
|