ir/tests/aarch64/mul_ov_001.irt

24 lines
329 B
Plaintext
Raw Normal View History

--TEST--
001: mul_ov function
--TARGET--
aarch64
--ARGS--
-S
--CODE--
{
int32_t c = 2;
l_1 = START(l_2);
int32_t x = PARAM(l_1, "x", 1);
int32_t ret = MUL_OV(x, c);
bool ov = OVERFLOW(ret);
l_2 = RETURN(l_1, ov);
}
--EXPECT--
test:
movz w2, #0x2
smull x0, w0, w2
asr x1, x0, #0x20
cmp x1, x0, asr #31
cset w0, ne
ret