1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
/* 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;
}
|