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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
//printf needs following syscalls: sbrk write close fstat isatty lseek read
//
#include <sys/stat.h>
#include <string.h>
#include <stdint.h>
#include "../fs/fs.h"
static int preread;
static int alloc;
easywrite(char *c);
// init syscalls
void syscalls_init()
{
// TODO dynamic!
alloc=0x300000;
}
// generic syscall interface!
int syscall(int call, int p1, int p2, int p3)
{
int ebx; // will hold return value;
asm("pusha");
// select syscall
asm("mov %0, %%eax"::"m"(call));
// pass params
asm("mov %0,%%edx"::"m"(p1));
asm("mov %0,%%ecx"::"m"(p2));
asm("mov %0,%%ebx"::"m"(p3));
// interrrupt
asm("int $0x80");
// get return value
asm("mov %%ebx, %0": "=b" (ebx));
asm("popa");
return ebx;
}
//
int close(int file)
{
return -1;
}
int fstat(int file, struct stat *st)
{
st->st_mode = S_IFCHR;
return 0;
}
int isatty(int file)
{
return 1;
}
int lseek(int file, int ptr, int dir)
{
if(dir==0)preread=ptr;
else{ puts("other modes unsupported sorry"); while(1);}
return preread;
}
int read(int file, char *ptr, int len)
{
return syscall(62,file,ptr,len);
}
int readdir(const char *name,fs_dirent *dirs,int max)
{
return syscall(63,name,dirs,max);
}
int open(const char *name, int flags, int mode)
{
return name;
}
int write(int file, char *ptr, int len)
{
return syscall(61,file,ptr,len);
}
int execve(char *name, char **argv, char **env)
{
return syscall(64,name,argv,env);
}
caddr_t sbrk(int incr)
{
// easywrite("syscall: sbrk!!\n");
int oldalloc=alloc;
alloc+=incr;
return oldalloc;
/*
extern char end;
// char _end;
static char *heap_end;
char *prev_heap_end;
if (heap_end == 0) {
heap_end = &end;
}
prev_heap_end = heap_end;
if (heap_end + incr > stack_ptr) {
write (1, "Heap and stack collision\n", 25);
abort ();
}
heap_end += incr;
return (caddr_t) prev_heap_end;
*/
}
//
|