mirror of
https://github.com/danog/ir.git
synced 2024-11-27 04:45:38 +01:00
181 lines
4.2 KiB
Plaintext
181 lines
4.2 KiB
Plaintext
--TEST--
|
|
Fig -O0
|
|
--ARGS--
|
|
-S -O0
|
|
--CODE--
|
|
{
|
|
uintptr_t c_1 = 0;
|
|
bool c_2 = 0;
|
|
bool c_3 = 1;
|
|
int32_t i_1 = 1;
|
|
int32_t i_4 = 4;
|
|
ll_1 = START(ll_16); # <-
|
|
int32_t a_0 = PARAM(ll_1, "a", 0);
|
|
int32_t b_0 = PARAM(ll_1, "b", 1);
|
|
int32_t c_0 = PARAM(ll_1, "c", 2);
|
|
int32_t d_0 = PARAM(ll_1, "d", 3);
|
|
int32_t l_0 = PARAM(ll_1, "l", 4);
|
|
int32_t m_0 = PARAM(ll_1, "m", 5);
|
|
int32_t s_0 = PARAM(ll_1, "s", 6);
|
|
int32_t t_0 = PARAM(ll_1, "t", 7);
|
|
int32_t cond1 = PARAM(ll_1, "cond1", 8);
|
|
int32_t cond2 = PARAM(ll_1, "cond2", 9);
|
|
ll_2 = END(ll_1);
|
|
ll_3 = LOOP_BEGIN(ll_2, ll_12); # <-
|
|
int32_t a_1 = PHI(ll_3, a_0, a_3);
|
|
int32_t d_1 = PHI(ll_3, d_0, d_3);
|
|
int32_t m_1 = PHI(ll_3, m_0, m_3);
|
|
int32_t s_1 = PHI(ll_3, s_0, s_3);
|
|
int32_t t_1 = PHI(ll_3, t_0, t_3);
|
|
ll_4 = IF(ll_3, cond1);
|
|
ll_5 = IF_TRUE(ll_4);
|
|
int32_t l_1 = MUL(c_0, b_0);
|
|
int32_t m_2 = ADD(l_1, i_4);
|
|
int32_t a_2 = COPY(c_0);
|
|
ll_6 = END(ll_5);
|
|
ll_7 = IF_FALSE(ll_4);
|
|
int32_t d_2 = COPY(c_0);
|
|
int32_t l_2 = MUL(d_2, b_0);
|
|
int32_t s_2 = MUL(a_1, b_0);
|
|
int32_t t_2 = ADD(s_2, i_1);
|
|
ll_8 = END(ll_7);
|
|
ll_9 = MERGE(ll_6, ll_8);
|
|
int32_t a_3 = PHI(ll_9, a_2, a_1);
|
|
int32_t d_3 = PHI(ll_9, d_1, d_2);
|
|
int32_t l_3 = PHI(ll_9, l_1, l_2);
|
|
int32_t m_3 = PHI(ll_9, m_2, m_1);
|
|
int32_t s_3 = PHI(ll_9, s_1, s_2);
|
|
int32_t t_3 = PHI(ll_9, t_1, t_2);
|
|
int32_t x_0 = MUL(a_3, b_0);
|
|
int32_t y_0 = ADD(x_0, i_1);
|
|
ll_10 = IF(ll_9, cond2);
|
|
ll_11 = IF_TRUE(ll_10);
|
|
ll_12 = LOOP_END(ll_11, ll_3);
|
|
ll_13 = IF_FALSE(ll_10);
|
|
ll_14 = LOOP_EXIT(ll_13, ll_3);
|
|
ll_15 = BEGIN(ll_14);
|
|
int32_t ret1 = ADD(a_3, b_0);
|
|
int32_t ret2 = ADD(ret1, c_0);
|
|
int32_t ret3 = ADD(ret2, d_3);
|
|
int32_t ret4 = ADD(ret3, l_3);
|
|
int32_t ret5 = ADD(ret4, m_3);
|
|
int32_t ret6 = ADD(ret5, s_3);
|
|
int32_t ret7 = ADD(ret6, t_3);
|
|
int32_t ret8 = ADD(ret7, y_0);
|
|
ll_16 = RETURN(ll_15, ret8);
|
|
}
|
|
--EXPECT--
|
|
test:
|
|
subq $0x128, %rsp
|
|
movl %edi, (%rsp)
|
|
movl %esi, 8(%rsp)
|
|
movl %edx, 0x10(%rsp)
|
|
movl %ecx, 0x18(%rsp)
|
|
movl %r9d, 0x20(%rsp)
|
|
movl (%rsp), %edx
|
|
movl %edx, 0x48(%rsp)
|
|
movl 0x18(%rsp), %edx
|
|
movl %edx, 0x50(%rsp)
|
|
movl 0x20(%rsp), %edx
|
|
movl %edx, 0x58(%rsp)
|
|
movl 0x28(%rsp), %edx
|
|
movl %edx, 0x60(%rsp)
|
|
movl 0x30(%rsp), %edx
|
|
movl %edx, 0x68(%rsp)
|
|
.L1:
|
|
cmpl $0, 0x38(%rsp)
|
|
je .L2
|
|
movl 0x10(%rsp), %eax
|
|
imull 8(%rsp), %eax
|
|
movl %eax, 0x70(%rsp)
|
|
movl 0x70(%rsp), %eax
|
|
addl $4, %eax
|
|
movl %eax, 0x78(%rsp)
|
|
movl 0x10(%rsp), %eax
|
|
movl %eax, 0x80(%rsp)
|
|
movl 0x80(%rsp), %edx
|
|
movl %edx, 0xa8(%rsp)
|
|
movl 0x50(%rsp), %edx
|
|
movl %edx, 0xb0(%rsp)
|
|
movl 0x70(%rsp), %edx
|
|
movl %edx, 0xb8(%rsp)
|
|
movl 0x78(%rsp), %edx
|
|
movl %edx, 0xc0(%rsp)
|
|
movl 0x60(%rsp), %edx
|
|
movl %edx, 0xc8(%rsp)
|
|
movl 0x68(%rsp), %edx
|
|
movl %edx, 0xd0(%rsp)
|
|
jmp .L3
|
|
.L2:
|
|
movl 0x10(%rsp), %eax
|
|
movl %eax, 0x88(%rsp)
|
|
movl 0x88(%rsp), %eax
|
|
imull 8(%rsp), %eax
|
|
movl %eax, 0x90(%rsp)
|
|
movl 0x48(%rsp), %eax
|
|
imull 8(%rsp), %eax
|
|
movl %eax, 0x98(%rsp)
|
|
movl 0x98(%rsp), %eax
|
|
addl $1, %eax
|
|
movl %eax, 0xa0(%rsp)
|
|
movl 0x48(%rsp), %edx
|
|
movl %edx, 0xa8(%rsp)
|
|
movl 0x88(%rsp), %edx
|
|
movl %edx, 0xb0(%rsp)
|
|
movl 0x90(%rsp), %edx
|
|
movl %edx, 0xb8(%rsp)
|
|
movl 0x58(%rsp), %edx
|
|
movl %edx, 0xc0(%rsp)
|
|
movl 0x98(%rsp), %edx
|
|
movl %edx, 0xc8(%rsp)
|
|
movl 0xa0(%rsp), %edx
|
|
movl %edx, 0xd0(%rsp)
|
|
.L3:
|
|
movl 0xa8(%rsp), %eax
|
|
imull 8(%rsp), %eax
|
|
movl %eax, 0xd8(%rsp)
|
|
movl 0xd8(%rsp), %eax
|
|
addl $1, %eax
|
|
movl %eax, 0xe0(%rsp)
|
|
cmpl $0, 0x40(%rsp)
|
|
je .L4
|
|
movl 0xa8(%rsp), %edx
|
|
movl %edx, 0x48(%rsp)
|
|
movl 0xb0(%rsp), %edx
|
|
movl %edx, 0x50(%rsp)
|
|
movl 0xc0(%rsp), %edx
|
|
movl %edx, 0x58(%rsp)
|
|
movl 0xc8(%rsp), %edx
|
|
movl %edx, 0x60(%rsp)
|
|
movl 0xd0(%rsp), %edx
|
|
movl %edx, 0x68(%rsp)
|
|
jmp .L1
|
|
.L4:
|
|
movl 0xa8(%rsp), %eax
|
|
addl 8(%rsp), %eax
|
|
movl %eax, 0xe8(%rsp)
|
|
movl 0xe8(%rsp), %eax
|
|
addl 0x10(%rsp), %eax
|
|
movl %eax, 0xf0(%rsp)
|
|
movl 0xf0(%rsp), %eax
|
|
addl 0xb0(%rsp), %eax
|
|
movl %eax, 0xf8(%rsp)
|
|
movl 0xf8(%rsp), %eax
|
|
addl 0xb8(%rsp), %eax
|
|
movl %eax, 0x100(%rsp)
|
|
movl 0x100(%rsp), %eax
|
|
addl 0xc0(%rsp), %eax
|
|
movl %eax, 0x108(%rsp)
|
|
movl 0x108(%rsp), %eax
|
|
addl 0xc8(%rsp), %eax
|
|
movl %eax, 0x110(%rsp)
|
|
movl 0x110(%rsp), %eax
|
|
addl 0xd0(%rsp), %eax
|
|
movl %eax, 0x118(%rsp)
|
|
movl 0x118(%rsp), %eax
|
|
addl 0xe0(%rsp), %eax
|
|
movl %eax, 0x120(%rsp)
|
|
movl 0x120(%rsp), %eax
|
|
addq $0x128, %rsp
|
|
retq
|