OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [newlib-1.17.0/] [libgloss/] [iq2000/] [trap.c] - Blame information for rev 310

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 148 jeremybenn
// Perform a system call.
2
// Unused parameters should be set to 0.
3
int __trap0(unsigned long func, unsigned long p1, unsigned long p2, unsigned long p3)
4
{
5
  int ret = 0;
6
  asm volatile ("nop\n\tor %%4,%%0,%0" : : "r"(func));
7
  asm volatile ("nop\n\tor %%5,%%0,%0" : : "r"(p1));
8
  asm volatile ("nop\n\tor %%6,%%0,%0" : : "r"(p2));
9
  asm volatile ("nop\n\tor %%7,%%0,%0" : : "r"(p3));
10
  asm volatile ("nop\n\tor %%11,%%0,%0" : : "r"(func));
11
  asm volatile ("syscall\n\tnop\n\tor %0,%%0,%%2" : "=r"(ret));
12
  return ret;
13
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.