URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 323 |
Rev 384 |
/* { dg-do compile } */
|
/* { dg-do compile } */
|
/* { dg-options "-mint-register=3 -msave-acc-in-interrupts" } */
|
/* { dg-options "-mint-register=3 -msave-acc-in-interrupts" } */
|
|
|
/* Verify that the RX specific function attributes work. */
|
/* Verify that the RX specific function attributes work. */
|
|
|
void fast_interrupt (void) __attribute__((__fast_interrupt__));
|
void fast_interrupt (void) __attribute__((__fast_interrupt__));
|
void interrupt (void) __attribute__((__interrupt__));
|
void interrupt (void) __attribute__((__interrupt__));
|
int naked (int) __attribute__((__naked__));
|
int naked (int) __attribute__((__naked__));
|
|
|
int flag = 0;
|
int flag = 0;
|
|
|
/* Fast interrupt handler. Only uses registers marked as fixed
|
/* Fast interrupt handler. Only uses registers marked as fixed
|
by the -fixed-xxx gcc command line option. Returns via RTFI. */
|
by the -fixed-xxx gcc command line option. Returns via RTFI. */
|
|
|
void
|
void
|
fast_interrupt (void)
|
fast_interrupt (void)
|
{
|
{
|
flag = 1;
|
flag = 1;
|
}
|
}
|
|
|
/* Interrupt handler. Must preserve any register it uses, even
|
/* Interrupt handler. Must preserve any register it uses, even
|
call clobbered ones. Returns via RTE. */
|
call clobbered ones. Returns via RTE. */
|
|
|
void
|
void
|
interrupt (void)
|
interrupt (void)
|
{
|
{
|
switch (flag)
|
switch (flag)
|
{
|
{
|
case 0:
|
case 0:
|
flag = -1;
|
flag = -1;
|
break;
|
break;
|
case 1:
|
case 1:
|
case 2:
|
case 2:
|
case 4:
|
case 4:
|
flag = flag - 2;
|
flag = flag - 2;
|
break;
|
break;
|
case 5:
|
case 5:
|
case 7:
|
case 7:
|
case 6:
|
case 6:
|
flag ^= 3;
|
flag ^= 3;
|
break;
|
break;
|
default:
|
default:
|
naked (flag * 2);
|
naked (flag * 2);
|
break;
|
break;
|
}
|
}
|
}
|
}
|
|
|
/* Naked function. The programmer must supply the function's
|
/* Naked function. The programmer must supply the function's
|
prologue and epilogue instructions. */
|
prologue and epilogue instructions. */
|
|
|
int
|
int
|
naked (int arg)
|
naked (int arg)
|
{
|
{
|
flag = arg;
|
flag = arg;
|
}
|
}
|
|
|
/* { dg-final { scan-assembler "rtfi" } } */
|
/* { dg-final { scan-assembler "rtfi" } } */
|
/* { dg-final { scan-assembler "rte" } } */
|
/* { dg-final { scan-assembler "rte" } } */
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.