URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 298 |
Rev 384 |
/* PR middle-end/23848 */
|
/* PR middle-end/23848 */
|
/* { dg-do compile } */
|
/* { dg-do compile } */
|
/* { dg-options "-O2 -fdump-tree-optimized" } */
|
/* { dg-options "-O2 -fdump-tree-optimized" } */
|
|
|
void bar (char *, char *, char *, char *, int);
|
void bar (char *, char *, char *, char *, int);
|
void foo (int size)
|
void foo (int size)
|
{
|
{
|
char temp[size];
|
char temp[size];
|
temp[size-1] = '\0';
|
temp[size-1] = '\0';
|
{
|
{
|
char temp2[size];
|
char temp2[size];
|
{
|
{
|
char temp3[size];
|
char temp3[size];
|
{
|
{
|
char temp4[size];
|
char temp4[size];
|
bar (temp, temp2, temp3, temp4, size);
|
bar (temp, temp2, temp3, temp4, size);
|
}
|
}
|
}
|
}
|
__asm __volatile ("" : : "r" (&temp[0]), "r" (&temp2[0]) : "memory");
|
__asm __volatile ("" : : "r" (&temp[0]), "r" (&temp2[0]) : "memory");
|
}
|
}
|
}
|
}
|
|
|
/* { dg-final { scan-tree-dump-times "__builtin_stack_save" 1 "optimized"} } */
|
/* { dg-final { scan-tree-dump-times "__builtin_stack_save" 1 "optimized"} } */
|
/* { dg-final { scan-tree-dump-times "__builtin_stack_restore" 1 "optimized"} } */
|
/* { dg-final { scan-tree-dump-times "__builtin_stack_restore" 1 "optimized"} } */
|
/* { dg-final { cleanup-tree-dump "optimized" } } */
|
/* { dg-final { cleanup-tree-dump "optimized" } } */
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.