mirror of
https://github.com/danog/ir.git
synced 2025-01-07 13:30:02 +01:00
26 lines
424 B
Plaintext
26 lines
424 B
Plaintext
|
--TEST--
|
||
|
006: Register Allocation (DIV + MOD)
|
||
|
--TARGET--
|
||
|
x86
|
||
|
--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 = MOD(x_2, z_1);
|
||
|
l_4 = RETURN(l_1, x_3);
|
||
|
}
|
||
|
--EXPECT--
|
||
|
test:
|
||
|
movl 4(%esp), %eax
|
||
|
xorl %edx, %edx
|
||
|
divl 8(%esp)
|
||
|
xorl %edx, %edx
|
||
|
divl 0xc(%esp)
|
||
|
movl %edx, %eax
|
||
|
retl
|