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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
#include "uart.h"
#include <sys/stat.h>
#include <sys/times.h>
#include <sys/types.h>
#include <errno.h>
#undef errno
extern int errno;
// defined in crt0.S
void _exit(int c);
int _close(int file) { return -1; }
char *__env[1] = {0};
char **environ = __env;
int _execve(char *name, char **argv, char **env) {
errno = ENOMEM;
return -1;
}
int _fork(void) {
errno = EAGAIN;
return -1;
}
int _fstat(int file, struct stat *st) {
st->st_mode = S_IFCHR;
return 0;
}
int _getpid(void) { return 1; }
int _isatty(int file) { return 1; }
int _link(char *old, char *new) {
errno = EMLINK;
return -1;
}
int _lseek(int file, int ptr, int dir) { return 0; }
int _open(const char *name, int flags, int mode) { return -1; }
int _read(int file, char *buf, int len) {
uint32_t uart_data;
do {
uart_data = UART_RXDATA;
} while (uart_data & UART_RXDATA_EMPTY);
int i;
for (i = 0; i < len; i++) {
buf[i] = (char)uart_data;
uart_data = UART_RXDATA;
if (uart_data & UART_RXDATA_EMPTY) {
break;
}
}
// *(volatile int *)1 = i;
return i + 1;
}
void *_sbrk(int incr) {
extern void _heap_start;
extern void *_heap_end;
void *prev_heap_end = _heap_end;
void *stack_ptr;
__asm__ volatile("mv %0, sp" : "=r"(stack_ptr));
if (_heap_end + incr > stack_ptr) {
uart_puts("Heap and stack collision\n");
_exit(1);
}
_heap_end += incr;
return prev_heap_end;
}
int _stat(const char *__restrict file, struct stat *__restrict st) {
st->st_mode = S_IFCHR;
return 0;
}
clock_t _times(struct tms *buf) { return (clock_t)-1; }
int _unlink(char *name) {
errno = ENOENT;
return -1;
}
int _wait(int *status) {
errno = ECHILD;
return -1;
}
int _write(int file, char *buf, int len) {
// uart_puts("_write called\n");
for (int i = 0; i < len; i++) {
uart_putc(buf[i]);
}
// *(volatile int *)0 = len;
return len;
}
int _kill(int pid, int sig) {
errno = EINVAL;
return -1;
}
|