mirror of
https://gitlab.os-k.eu/os-k-team/os-k.git
synced 2023-08-25 14:03:10 +02:00
62 lines
2.5 KiB
NASM
62 lines
2.5 KiB
NASM
;=----------------------------------------------------------------------------=;
|
|
; 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
|
|
global KeSyscall
|
|
extern KernLog
|
|
|
|
;;
|
|
;; To get ring3 code running
|
|
;;
|
|
KeJumpToUserspace:
|
|
|
|
; rdi = user args
|
|
; rsi = entry point in user space
|
|
; rdx = user space stack
|
|
|
|
mov rax, 0x18 ; Selector 0x18 (User Data) + RPL 3
|
|
mov ds, rax
|
|
mov es, rax
|
|
|
|
; Build a fake iret frame
|
|
push rax ; Selector 0x18 (User Data) + RPL 3
|
|
push rdx ; User space stack
|
|
push QWORD 0x202 ; rflags = interrupt enable + reserved bit
|
|
push QWORD 0x20 ; Selector 0x20 (User Code) + RPL 3
|
|
push rsi ; Entry point in user space
|
|
|
|
iretq
|
|
|
|
|
|
;;
|
|
;; Syscall trigger
|
|
;;
|
|
KeSyscall:
|
|
int 0x80
|
|
ret
|