mirror of
https://github.com/Fennix-Project/Kernel.git
synced 2025-07-08 22:09:21 +00:00
.github
.vscode
arch
core
exec
files
include
include_std
kshell
library
modules
network
profiling
storage
syscalls
linux
native
close.cpp
execve.cpp
exit.cpp
fork.cpp
lseek.cpp
mmap.cpp
mprotect.cpp
munmap.cpp
open.cpp
read.cpp
write.cpp
linux.cpp
linux_syscalls.hpp
native.cpp
syscalls.cpp
tasking
tests
virtualization
.gitignore
CREDITS.md
Doxyfile
Fex.hpp
ISSUES.md
LICENSE.md
LICENSES.md
Makefile
README.md
TODO.md
boot_logo.cpp
dump.sh
ipc.h
kernel.cpp
kernel.h
kernel_config.cpp
kernel_thread.cpp
mapi.hpp
syscalls.h
66 lines
1.7 KiB
C++
66 lines
1.7 KiB
C++
/*
|
|
This file is part of Fennix Kernel.
|
|
|
|
Fennix Kernel 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.
|
|
|
|
Fennix Kernel 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 Fennix Kernel. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include <syscalls.hpp>
|
|
|
|
#include <memory.hpp>
|
|
#include <lock.hpp>
|
|
#include <exec.hpp>
|
|
#include <errno.h>
|
|
#include <debug.h>
|
|
|
|
#include "../../syscalls.h"
|
|
#include "../../kernel.h"
|
|
#include "../../ipc.h"
|
|
|
|
using InterProcessCommunication::IPC;
|
|
using InterProcessCommunication::IPCID;
|
|
using Tasking::PCB;
|
|
using Tasking::TCB;
|
|
using Tasking::TaskState::Ready;
|
|
using Tasking::TaskState::Terminated;
|
|
using namespace Memory;
|
|
|
|
#define SysFrm SyscallsFrame
|
|
|
|
#if defined(a64)
|
|
typedef long arch_t;
|
|
#elif defined(a32)
|
|
typedef int arch_t;
|
|
#endif
|
|
|
|
/* https://pubs.opengroup.org/onlinepubs/009604499/functions/write.html */
|
|
ssize_t sys_write(SysFrm *, int fildes,
|
|
const void *buf, size_t nbyte)
|
|
{
|
|
const void *safe_buf = nullptr;
|
|
Tasking::PCB *pcb = thisProcess;
|
|
Memory::SmartHeap sh(nbyte, pcb->vma);
|
|
safe_buf = sh.Get();
|
|
{
|
|
Memory::SwapPT swap(pcb->PageTable);
|
|
memcpy((void *)safe_buf, buf, nbyte);
|
|
}
|
|
|
|
function("%d, %p, %d", fildes, buf, nbyte);
|
|
vfs::FileDescriptorTable *fdt = pcb->FileDescriptors;
|
|
ssize_t ret = fdt->_write(fildes, safe_buf, nbyte);
|
|
if (ret)
|
|
fdt->_lseek(fildes, ret, SEEK_CUR);
|
|
return ret;
|
|
}
|