summaryrefslogtreecommitdiffhomepage
path: root/dev/libSystem/src/SystemCalls+IO.asm
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal@nekernel.org>2025-05-29 10:51:53 +0200
committerGitHub <noreply@github.com>2025-05-29 10:51:53 +0200
commit5c0bb7ee7b1b0fee02cc179fb21f4c57a61d6c2d (patch)
treecb17577bcdc9714c97a84ce417a075117097f146 /dev/libSystem/src/SystemCalls+IO.asm
parentd608230b1350b064ceb01e6572519b108f6139b0 (diff)
parent3167f59dbb401d6a79b1524537e04218baf49ee3 (diff)
Merge pull request #32 from nekernel-org/dev
0.0.2e3
Diffstat (limited to 'dev/libSystem/src/SystemCalls+IO.asm')
-rw-r--r--dev/libSystem/src/SystemCalls+IO.asm66
1 files changed, 66 insertions, 0 deletions
diff --git a/dev/libSystem/src/SystemCalls+IO.asm b/dev/libSystem/src/SystemCalls+IO.asm
new file mode 100644
index 00000000..097046af
--- /dev/null
+++ b/dev/libSystem/src/SystemCalls+IO.asm
@@ -0,0 +1,66 @@
+;; /*
+;; * ========================================================
+;; *
+;; * libSystem/src/SystemCalls+IO.asm
+;; * Copyright (C) 2024-2025, Amlal El Mahrouss, all rights reserved.
+;; *
+;; * ========================================================
+;; */
+
+[bits 64]
+
+section .text
+
+global sci_syscall_arg_1
+global sci_syscall_arg_2
+global sci_syscall_arg_3
+global sci_syscall_arg_4
+
+sci_syscall_arg_1:
+ push rbp
+ mov rbp, rsp
+
+ mov r8, rcx
+ syscall
+
+ pop rbp
+
+ ret
+
+sci_syscall_arg_2:
+ push rbp
+ mov rbp, rsp
+
+ mov r8, rcx
+ mov r9, rdx
+ syscall
+ pop rbp
+
+ ret
+
+sci_syscall_arg_3:
+ push rbp
+ mov rbp, rsp
+
+ mov r8, rcx
+ mov r9, rdx
+ mov r10, rbx
+
+ syscall
+ pop rbp
+
+ ret
+
+sci_syscall_arg_4:
+ push rbp
+ mov rbp, rsp
+
+ mov r8, rcx
+ mov r9, rdx
+ mov r10, rbx
+ mov r11, rax
+
+ syscall
+ pop rbp
+
+ ret