summaryrefslogtreecommitdiff
path: root/userspace/syscalls.c
blob: b5959eb7cf351d08b6e74f2c73ff68224d682094 (plain)
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;
	    */
}
//