Projet_SETI_RISC-V/riscv-gnu-toolchain/newlib/libgloss/sparc/syscalls.c
2023-03-06 14:48:14 +01:00

85 lines
1.8 KiB
C

/* Copyright (c) 1995 Cygnus Support
*
* The authors hereby grant permission to use, copy, modify, distribute,
* and license this software and its documentation for any purpose, provided
* that existing copyright notices are retained in all copies and that this
* notice is included verbatim in any distributions. No written agreement,
* license, or royalty fee is required for any of the authorized uses.
* Modifications to this software may be copyrighted by their authors
* and need not follow the licensing terms described here, provided that
* the new terms are clearly indicated on the first page of each file where
* they apply.
*
* fake unix routines for sparclite and remote debugger
* Many of these routines just substitute an appropriate error status,
* if you want some kind of file system access, you'll have to fill them in...
* sbrk on the other hand is functional (malloc uses it) but it doesn't do
* any checking for lack of memory.
* kill and _exit could get more real implementations, as well.
*/
#include <sys/stat.h>
int
fstat(int _fd, struct stat* _sbuf)
{
/* this is used in a few places in stdio... */
/* just error, so they assume a pipe */
return -1;
}
int
isatty(int _fd)
{
return 1;
}
int
close(int _fd)
{
/* return value usually ignored anyhow */
return 0;
}
int
open(char *filename)
{
/* always fail */
return -1;
}
int
getpid() {
return 1;
}
int
kill(int pid) {
/* if we knew how to nuke the board, we would... */
return 0;
}
void
_exit(int status) {
/* likewise... */
return;
}
int
lseek(int _fd, off_t offset, int whence)
{
/* nothing is ever seekable */
return -1;
}
extern char end;
char*
sbrk(int incr)
{
static char* base;
char *b;
if(!base) base = &end;
b = base;
base += incr;
return b;
}