mirror of
https://gitlab.os-k.eu/os-k-team/os-k.git
synced 2023-08-25 14:03:10 +02:00
Add syscall.c|h|asm in kernel/ke (2)
This commit is contained in:
parent
281ec9c5f5
commit
bc3e8323bd
40
include/kernel/ke/syscall.h
Normal file
40
include/kernel/ke/syscall.h
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
// OS on Kaleid //
|
||||||
|
// //
|
||||||
|
// Desc: System call & userspace related functions //
|
||||||
|
// //
|
||||||
|
// //
|
||||||
|
// Copyright © 2018-2021 The OS/K Team //
|
||||||
|
// //
|
||||||
|
// This file is part of OS/K. //
|
||||||
|
// //
|
||||||
|
// OS/K is free software: you can redistribute it and/or modify //
|
||||||
|
// it under the terms of the GNU General Public License as published by //
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or //
|
||||||
|
// any later version. //
|
||||||
|
// //
|
||||||
|
// OS/K is distributed in the hope that it will be useful, //
|
||||||
|
// but WITHOUT ANY WARRANTY//without even the implied warranty of //
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
|
||||||
|
// GNU General Public License for more details. //
|
||||||
|
// //
|
||||||
|
// You should have received a copy of the GNU General Public License //
|
||||||
|
// along with OS/K. If not, see <https://www.gnu.org/licenses/>. //
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
#ifndef _KERNEL_H
|
||||||
|
#include <kernel.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef _KALKERN_SYSCALL_H
|
||||||
|
#define _KALKERN_SYSCALL_H
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
extern void KeJumpToUserspace(ulong args, void *entryPoint, void *stackAddr);
|
||||||
|
|
||||||
|
void KeEnableSystemCalls();
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
#endif
|
50
kaleid/kernel/ke/syscall.asm
Normal file
50
kaleid/kernel/ke/syscall.asm
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
;=----------------------------------------------------------------------------=;
|
||||||
|
; OS on Kaleid ;
|
||||||
|
; ;
|
||||||
|
; Desc: System call & userspace related functions ;
|
||||||
|
; ;
|
||||||
|
; ;
|
||||||
|
; Copyright © 2018-2021 The OS/K Team ;
|
||||||
|
; ;
|
||||||
|
; This file is part of OS/K. ;
|
||||||
|
; ;
|
||||||
|
; OS/K is free software: you can redistribute it and/or modify ;
|
||||||
|
; it under the terms of the GNU General Public License as published by ;
|
||||||
|
; the Free Software Foundation, either version 3 of the License, or ;
|
||||||
|
; (at your option) any later version. ;
|
||||||
|
; ;
|
||||||
|
; OS/K is distributed in the hope that it will be useful, ;
|
||||||
|
; but WITHOUT ANY WARRANTY; without even the implied warranty of ;
|
||||||
|
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;
|
||||||
|
; GNU General Public License for more details. ;
|
||||||
|
; ;
|
||||||
|
; You should have received a copy of the GNU General Public License ;
|
||||||
|
; along with OS/K. If not, see <https://www.gnu.org/licenses/>. ;
|
||||||
|
;=----------------------------------------------------------------------------=;
|
||||||
|
|
||||||
|
[BITS 64]
|
||||||
|
|
||||||
|
%include "kaleid/kernel/ke/cpuf.inc"
|
||||||
|
|
||||||
|
global KeJumpToUserspace
|
||||||
|
|
||||||
|
KeJumpToUserspace:
|
||||||
|
|
||||||
|
# rdi = user args
|
||||||
|
# rsi = entry point in user space
|
||||||
|
# rdx = user space stack
|
||||||
|
|
||||||
|
mov rax, 0x1b ; Selector 0x18 (User Data) + RPL 3
|
||||||
|
mov ds, ax
|
||||||
|
mov es, ax
|
||||||
|
|
||||||
|
# Build a fake iret frame
|
||||||
|
push rax # Selector 0x18 (User Data) + RPL 3
|
||||||
|
push rdx # User space stack
|
||||||
|
push 0x202 # rflags = interrupt enable + reserved bit
|
||||||
|
push 0x23 # Selector 0x20 (User Code) + RPL 3
|
||||||
|
push rsi # Entry point in user space
|
||||||
|
|
||||||
|
xor rax, rax
|
||||||
|
|
||||||
|
iretq
|
43
kaleid/kernel/ke/syscall.c
Normal file
43
kaleid/kernel/ke/syscall.c
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
// OS on Kaleid //
|
||||||
|
// //
|
||||||
|
// Desc: System call & userspace related functions //
|
||||||
|
// //
|
||||||
|
// //
|
||||||
|
// Copyright © 2018-2021 The OS/K Team //
|
||||||
|
// //
|
||||||
|
// This file is part of OS/K. //
|
||||||
|
// //
|
||||||
|
// OS/K is free software: you can redistribute it and/or modify //
|
||||||
|
// it under the terms of the GNU General Public License as published by //
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or //
|
||||||
|
// any later version. //
|
||||||
|
// //
|
||||||
|
// OS/K is distributed in the hope that it will be useful, //
|
||||||
|
// but WITHOUT ANY WARRANTY//without even the implied warranty of //
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
|
||||||
|
// GNU General Public License for more details. //
|
||||||
|
// //
|
||||||
|
// You should have received a copy of the GNU General Public License //
|
||||||
|
// along with OS/K. If not, see <https://www.gnu.org/licenses/>. //
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
#include <libbuf.h>
|
||||||
|
#include <init/boot.h>
|
||||||
|
#include <ke/idt.h>
|
||||||
|
#include <io/vga.h>
|
||||||
|
|
||||||
|
static uchar SyscallHandler(ISRFrame_t *regs)
|
||||||
|
{
|
||||||
|
DebugLog("Got a system call code %d !\n", regs->rdi);
|
||||||
|
|
||||||
|
return EOK;
|
||||||
|
}
|
||||||
|
|
||||||
|
void KeEnableSystemCalls()
|
||||||
|
{
|
||||||
|
ulong flags = KePauseIRQs();
|
||||||
|
KeRegisterISR(SyscallHandler, 0x80);
|
||||||
|
KeRestoreIRQs(flags);
|
||||||
|
KeEnableNMI();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user