ir/tests/x86/ra_012.irt

26 lines
430 B
Plaintext

--TEST--
012: Register Allocation (ADD + 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 = ADD(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
movl 8(%esp), %ecx
addl %ecx, %eax
xorl %edx, %edx
divl 0xc(%esp)
movl %edx, %eax
retl