ir/tests/debug.aarch64/memop_003.irt

30 lines
492 B
Plaintext
Raw Permalink Normal View History

--TEST--
003: Memory update (binary op with reg + swap)
--TARGET--
aarch64
--ARGS--
-S
--CODE--
{
int32_t c = 0x80;
l_1 = START(l_5);
int32_t y = PARAM(l_1, "y", 1);
int32_t v = VAR(l_1, "_spill_");
l_2 = VSTORE(l_1, v, y);
int32_t z, l_3 = VLOAD(l_2, v);
int32_t y2 = ADD(y, y);
int32_t ret = AND(y2, z);
l_4 = VSTORE(l_3, v, ret);
l_5 = RETURN(l_4);
}
--EXPECT--
test:
sub sp, sp, #8
str w0, [sp]
ldr w1, [sp]
add w0, w0, w0
and w0, w0, w1
str w0, [sp]
add sp, sp, #8
ret