/* 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;
}