mirror of
https://github.com/Fennix-Project/Kernel.git
synced 2025-05-28 15:34:33 +00:00
Updated syscalls
This commit is contained in:
parent
ab7f20d5f5
commit
d540462e0a
@ -1,4 +1,5 @@
|
|||||||
#include <syscalls.hpp>
|
#include <syscalls.hpp>
|
||||||
|
#include <memory.hpp>
|
||||||
|
|
||||||
#include <debug.h>
|
#include <debug.h>
|
||||||
|
|
||||||
@ -22,9 +23,23 @@ static int sys_print(SyscallsFrame *Frame, char Char, int Index)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static uint64_t sys_request_pages(SyscallsFrame *Frame, uint64_t Count)
|
||||||
|
{
|
||||||
|
return (uint64_t)TaskManager->GetCurrentThread()->Memory->RequestPages(Count);
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint64_t sys_free_pages(SyscallsFrame *Frame, uint64_t Address, uint64_t Count)
|
||||||
|
{
|
||||||
|
TaskManager->GetCurrentThread()->Memory->FreePages((void *)Address, Count);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void *NativeSyscallsTable[] = {
|
static void *NativeSyscallsTable[] = {
|
||||||
[_exit] = (void *)sys_exit,
|
[_Exit] = (void *)sys_exit,
|
||||||
[_print] = (void *)sys_print,
|
[_Print] = (void *)sys_print,
|
||||||
|
|
||||||
|
[_RequestPages] = (void *)sys_request_pages,
|
||||||
|
[_FreePages] = (void *)sys_free_pages,
|
||||||
};
|
};
|
||||||
|
|
||||||
uint64_t HandleNativeSyscalls(SyscallsFrame *Frame)
|
uint64_t HandleNativeSyscalls(SyscallsFrame *Frame)
|
||||||
|
80
syscalls.h
80
syscalls.h
@ -5,8 +5,84 @@
|
|||||||
|
|
||||||
enum NativeSyscalls
|
enum NativeSyscalls
|
||||||
{
|
{
|
||||||
_exit = 0,
|
_Exit = 0,
|
||||||
_print,
|
_Print,
|
||||||
|
|
||||||
|
_RequestPages,
|
||||||
|
_FreePages,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static inline long syscall0(long syscall)
|
||||||
|
{
|
||||||
|
unsigned long ret;
|
||||||
|
__asm__ __volatile__("syscall"
|
||||||
|
: "=a"(ret)
|
||||||
|
: "a"(syscall)
|
||||||
|
: "rcx", "r11", "memory");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline long syscall1(long syscall, long arg1)
|
||||||
|
{
|
||||||
|
unsigned long ret;
|
||||||
|
__asm__ __volatile__("syscall"
|
||||||
|
: "=a"(ret)
|
||||||
|
: "a"(syscall), "D"(arg1)
|
||||||
|
: "rcx", "r11", "memory");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline long syscall2(long syscall, long arg1, long arg2)
|
||||||
|
{
|
||||||
|
unsigned long ret;
|
||||||
|
__asm__ __volatile__("syscall"
|
||||||
|
: "=a"(ret)
|
||||||
|
: "a"(syscall), "D"(arg1), "S"(arg2)
|
||||||
|
: "rcx", "r11", "memory");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline long syscall3(long syscall, long arg1, long arg2, long arg3)
|
||||||
|
{
|
||||||
|
unsigned long ret;
|
||||||
|
__asm__ __volatile__("syscall"
|
||||||
|
: "=a"(ret)
|
||||||
|
: "a"(syscall), "D"(arg1), "S"(arg2), "d"(arg3)
|
||||||
|
: "rcx", "r11", "memory");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline long syscall4(long syscall, long arg1, long arg2, long arg3, long arg4)
|
||||||
|
{
|
||||||
|
unsigned long ret;
|
||||||
|
/* FIXME: matching constraint references invalid operand number */
|
||||||
|
// __asm__ __volatile__("syscall"
|
||||||
|
// : "=a"(ret)
|
||||||
|
// : "a"(syscall), "D"(arg1), "S"(arg2), "d"(arg3), "r10"(arg4)
|
||||||
|
// : "rcx", "r11", "memory");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline long syscall5(long syscall, long arg1, long arg2, long arg3, long arg4, long arg5)
|
||||||
|
{
|
||||||
|
unsigned long ret;
|
||||||
|
/* FIXME: matching constraint references invalid operand number */
|
||||||
|
// __asm__ __volatile__("syscall"
|
||||||
|
// : "=a"(ret)
|
||||||
|
// : "a"(syscall), "D"(arg1), "S"(arg2), "d"(arg3), "r10"(arg4), "r8"(arg5)
|
||||||
|
// : "rcx", "r11", "memory");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline long syscall6(long syscall, long arg1, long arg2, long arg3, long arg4, long arg5, long arg6)
|
||||||
|
{
|
||||||
|
unsigned long ret;
|
||||||
|
/* FIXME: matching constraint references invalid operand number */
|
||||||
|
// __asm__ __volatile__("syscall"
|
||||||
|
// : "=a"(ret)
|
||||||
|
// : "a"(syscall), "D"(arg1), "S"(arg2), "d"(arg3), "r10"(arg4), "r8"(arg5), "r9"(arg6)
|
||||||
|
// : "rcx", "r11", "memory");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
#endif // !__FENNIX_KERNEL_SYSCALLS_LIST_H__
|
#endif // !__FENNIX_KERNEL_SYSCALLS_LIST_H__
|
||||||
|
Loading…
x
Reference in New Issue
Block a user