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

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [newlib-1.18.0/] [newlib-1.18.0-or32-1.0rc2/] [newlib/] [libc/] [sys/] [mmixware/] [_exit.c] - Diff between revs 207 and 520

Only display areas with differences | Details | Blame | View Log

Rev 207 Rev 520
/* _exit for MMIXware.
/* _exit for MMIXware.
 
 
   Copyright (C) 2001 Hans-Peter Nilsson
   Copyright (C) 2001 Hans-Peter Nilsson
 
 
   Permission to use, copy, modify, and distribute this software is
   Permission to use, copy, modify, and distribute this software is
   freely granted, provided that the above copyright notice, this notice
   freely granted, provided that the above copyright notice, this notice
   and the following disclaimer are preserved with no changes.
   and the following disclaimer are preserved with no changes.
 
 
   THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
   THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
   IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
   IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
   WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
   WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
   PURPOSE.  */
   PURPOSE.  */
 
 
#include <_ansi.h>
#include <_ansi.h>
#include <sys/types.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/stat.h>
#include "sys/syscall.h"
#include "sys/syscall.h"
 
 
void _exit (int n)
void _exit (int n)
{
{
  /* The return status is passed on at exit from the simulator by all
  /* The return status is passed on at exit from the simulator by all
     but the oldest versions of Knuth's mmixware simulator.  Beware,
     but the oldest versions of Knuth's mmixware simulator.  Beware,
     "TRAP 0,0,0" is the instruction corresponding to (int32_t) 0 and
     "TRAP 0,0,0" is the instruction corresponding to (int32_t) 0 and
     the value 0 in $255 is common enough that a program crash jumping
     the value 0 in $255 is common enough that a program crash jumping
     to e.g. uninitialized memory will look like "exit (0)".  */
     to e.g. uninitialized memory will look like "exit (0)".  */
  __asm__ ("SET $255,%0\n\tTRAP 0,0,0"
  __asm__ ("SET $255,%0\n\tTRAP 0,0,0"
           : /* No outputs.  */
           : /* No outputs.  */
           : "r" (n)
           : "r" (n)
           : "memory");
           : "memory");
}
}
 
 

powered by: WebSVN 2.1.0

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