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

Subversion Repositories or1k

[/] [or1k/] [trunk/] [newlib/] [newlib/] [libc/] [sys/] [m88kbug/] [syscalls.c] - Diff between revs 40 and 1765

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

Rev 40 Rev 1765
/* Operating system  and traps for mvme187bug, the motorolola BUG
/* Operating system  and traps for mvme187bug, the motorolola BUG
   monitor for m88k */
   monitor for m88k */
 
 
#include <sys/types.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/stat.h>
#include <sys/times.h>
#include <sys/times.h>
#include <errno.h>
#include <errno.h>
 
 
#include "sys/systraps.h"
#include "sys/systraps.h"
 
 
static void writechar(int c) {
static void writechar(int c) {
  register int n asm ("r2");
  register int n asm ("r2");
  n = c;
  n = c;
  SYSTRAP(OUTCHR);
  SYSTRAP(OUTCHR);
  return;
  return;
}
}
 
 
static int readchar(void) {
static int readchar(void) {
  register int n asm ("r2");
  register int n asm ("r2");
  SYSTRAP(INCHR);
  SYSTRAP(INCHR);
  return(n);
  return(n);
}
}
 
 
int read(int file, char *ptr, int len) {
int read(int file, char *ptr, int len) {
  int todo;
  int todo;
 
 
  for (todo = len; todo; --todo) {
  for (todo = len; todo; --todo) {
    *ptr++ = readchar();
    *ptr++ = readchar();
  }
  }
 
 
  return(len);
  return(len);
}
}
 
 
int lseek(int file, int ptr, int dir) {
int lseek(int file, int ptr, int dir) {
  return 0;
  return 0;
}
}
 
 
int write(int file, char *ptr, int len) {
int write(int file, char *ptr, int len) {
  int todo;
  int todo;
 
 
  for (todo = len; todo; --todo) {
  for (todo = len; todo; --todo) {
    writechar(*ptr++);
    writechar(*ptr++);
  }
  }
  return(len);
  return(len);
}
}
 
 
int close(int file) {
int close(int file) {
  return(-1);
  return(-1);
}
}
 
 
caddr_t sbrk(int incr) {
caddr_t sbrk(int incr) {
  extern char end;              /* Defined by the linker */
  extern char end;              /* Defined by the linker */
  static char *heap_end;
  static char *heap_end;
  char *prev_heap_end;
  char *prev_heap_end;
 
 
  if (heap_end == 0)
  if (heap_end == 0)
  {
  {
    heap_end = &end;
    heap_end = &end;
  }
  }
  prev_heap_end = heap_end;
  prev_heap_end = heap_end;
  if (heap_end + incr > stack_ptr)
  if (heap_end + incr > stack_ptr)
    {
    {
      _write (1, "Heap and stack collision\n", 25);
      _write (1, "Heap and stack collision\n", 25);
      abort ();
      abort ();
    }
    }
  heap_end += incr;
  heap_end += incr;
  return((caddr_t) prev_heap_end);
  return((caddr_t) prev_heap_end);
}
}
 
 
int isatty(int file) {
int isatty(int file) {
  return(1);
  return(1);
}
}
 
 
int fstat(int file, struct stat *st) {
int fstat(int file, struct stat *st) {
  st->st_mode = S_IFCHR;
  st->st_mode = S_IFCHR;
  return(0);
  return(0);
}
}
 
 
int stat(char *filename, struct stat *st) {
int stat(char *filename, struct stat *st) {
  st->st_mode = S_IFCHR;
  st->st_mode = S_IFCHR;
  return(0);
  return(0);
}
}
 
 
int open(const char *path, int flags) {
int open(const char *path, int flags) {
  return(0);
  return(0);
}
}
 
 
 
 
int _exit() {
int _exit() {
  SYSTRAP(RETURN);
  SYSTRAP(RETURN);
}
}
 
 
int execve(char *name, char **argv, char **env) {
int execve(char *name, char **argv, char **env) {
  errno = ENOMEM;
  errno = ENOMEM;
  return(-1);
  return(-1);
}
}
 
 
int fork() {
int fork() {
  errno = EAGAIN;
  errno = EAGAIN;
  return(-1);
  return(-1);
}
}
 
 
int getpid() {
int getpid() {
  return(1);
  return(1);
}
}
 
 
int kill(int pid, int sig) {
int kill(int pid, int sig) {
  errno = EINVAL;
  errno = EINVAL;
  return(-1);
  return(-1);
}
}
 
 
int link(char *old, char *new) {
int link(char *old, char *new) {
  errno = EMLINK;
  errno = EMLINK;
  return(-1);
  return(-1);
}
}
 
 
clock_t times(struct tms *buf) {
clock_t times(struct tms *buf) {
  return(-1);
  return(-1);
}
}
 
 
int unlink(char *name) {
int unlink(char *name) {
  errno = ENOENT;
  errno = ENOENT;
  return(-1);
  return(-1);
}
}
 
 
int wait(int *status) {
int wait(int *status) {
  errno = ECHILD;
  errno = ECHILD;
  return(-1);
  return(-1);
}
}
 
 
/* end of syscalls.c */
/* end of syscalls.c */
 
 

powered by: WebSVN 2.1.0

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