blob: ebd783dd05d80bf0e8d553140894d75263f8e250 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
/* { dg-do compile { target "sh-*-*" } } */
/* { dg-options "-O0 -m4 -ml -fira" } */
/* { dg-final { scan-assembler-not "add\tr0,r0" } } */
/* This test checks that chain reloads conflict. I they don't
conflict, the same hard register R0 is used for the both reloads
but in this case the second reload needs an intermediate register
(which is the reload register). As the result we have the
following code
mov #4,r0 -- first reload
mov r14,r0 -- second reload
add r0,r0 -- second reload
The right code should be
mov #4,r0 -- first reload
mov r14,r1 -- second reload
add r0,r1 -- second reload
*/
_Complex float foo_float ();
void bar_float ()
{
__real foo_float ();
}
|