mirror of
https://github.com/RGBCube/serenity
synced 2025-05-18 17:45:08 +00:00
UserspaceEmulator: Add the getcwd syscall
This commit is contained in:
parent
b187a42e53
commit
c497603177
2 changed files with 13 additions and 0 deletions
|
@ -250,6 +250,8 @@ u32 Emulator::virt_syscall(u32 function, u32 arg1, u32 arg2, u32 arg3)
|
||||||
dbgprintf("Syscall: %s (%x)\n", Syscall::to_string((Syscall::Function)function), function);
|
dbgprintf("Syscall: %s (%x)\n", Syscall::to_string((Syscall::Function)function), function);
|
||||||
#endif
|
#endif
|
||||||
switch (function) {
|
switch (function) {
|
||||||
|
case SC_getcwd:
|
||||||
|
return virt$getcwd(arg1, arg2);
|
||||||
case SC_ttyname:
|
case SC_ttyname:
|
||||||
return virt$ttyname(arg1, arg2, arg3);
|
return virt$ttyname(arg1, arg2, arg3);
|
||||||
case SC_getpgrp:
|
case SC_getpgrp:
|
||||||
|
@ -1256,4 +1258,14 @@ int Emulator::virt$ttyname(int fd, FlatPtr buffer, size_t buffer_size)
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int Emulator::virt$getcwd(FlatPtr buffer, size_t buffer_size)
|
||||||
|
{
|
||||||
|
auto host_buffer = ByteBuffer::create_zeroed(buffer_size);
|
||||||
|
int rc = syscall(SC_getcwd, host_buffer.data(), host_buffer.size());
|
||||||
|
if (rc < 1)
|
||||||
|
return rc;
|
||||||
|
mmu().copy_to_vm(buffer, host_buffer.data(), host_buffer.size());
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -138,6 +138,7 @@ private:
|
||||||
int virt$sleep(unsigned);
|
int virt$sleep(unsigned);
|
||||||
int virt$getpgrp();
|
int virt$getpgrp();
|
||||||
int virt$ttyname(int fd, FlatPtr buffer, size_t buffer_size);
|
int virt$ttyname(int fd, FlatPtr buffer, size_t buffer_size);
|
||||||
|
int virt$getcwd(FlatPtr buffer, size_t buffer_size);
|
||||||
|
|
||||||
FlatPtr allocate_vm(size_t size, size_t alignment);
|
FlatPtr allocate_vm(size_t size, size_t alignment);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue