summaryrefslogtreecommitdiff
path: root/Kernel/Syscall.cpp
diff options
context:
space:
mode:
authorSergey Bugaev <bugaevc@gmail.com>2019-08-05 15:29:05 +0300
committerAndreas Kling <awesomekling@gmail.com>2019-08-05 16:04:31 +0200
commit9c3b1ca0c62fc329bdc1fb86bc7b11fc7b8791b9 (patch)
tree420c9929b556d608b8404004d487dcbb679a990d /Kernel/Syscall.cpp
parent55d7810fab79efbc9fad62566fe1f12be80856e8 (diff)
downloadserenity-9c3b1ca0c62fc329bdc1fb86bc7b11fc7b8791b9.zip
Kernel+LibC: Support passing O_CLOEXEC to pipe()
In the userspace, this mimics the Linux pipe2() syscall; in the kernel, the Process::sys$pipe() now always accepts a flags argument, the no-argument pipe() syscall is now a userspace wrapper over pipe2().
Diffstat (limited to 'Kernel/Syscall.cpp')
-rw-r--r--Kernel/Syscall.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/Kernel/Syscall.cpp b/Kernel/Syscall.cpp
index b378367ea2..48b9313a92 100644
--- a/Kernel/Syscall.cpp
+++ b/Kernel/Syscall.cpp
@@ -189,7 +189,7 @@ static u32 handle(RegisterDump& regs, u32 function, u32 arg1, u32 arg2, u32 arg3
case Syscall::SC_sigprocmask:
return current->process().sys$sigprocmask((int)arg1, (const sigset_t*)arg2, (sigset_t*)arg3);
case Syscall::SC_pipe:
- return current->process().sys$pipe((int*)arg1);
+ return current->process().sys$pipe((int*)arg1, (int) arg2);
case Syscall::SC_killpg:
return current->process().sys$killpg((int)arg1, (int)arg2);
case Syscall::SC_setuid: