Kernel: Fix file open permissions for some syscalls
This commit is contained in:
parent
b779b3cf2d
commit
0620ed3d4f
|
@ -1051,7 +1051,7 @@ namespace Kernel
|
||||||
|
|
||||||
LockGuard _(m_process_lock);
|
LockGuard _(m_process_lock);
|
||||||
|
|
||||||
auto inode = TRY(find_file(fd, path, O_SEARCH | flag)).inode;
|
auto inode = TRY(find_file(fd, path, flag)).inode;
|
||||||
|
|
||||||
if (!m_credentials.is_superuser() && inode->uid() != m_credentials.euid())
|
if (!m_credentials.is_superuser() && inode->uid() != m_credentials.euid())
|
||||||
{
|
{
|
||||||
|
@ -1073,7 +1073,7 @@ namespace Kernel
|
||||||
|
|
||||||
LockGuard _(m_process_lock);
|
LockGuard _(m_process_lock);
|
||||||
|
|
||||||
auto inode = TRY(find_file(fd, path, O_SEARCH | flag)).inode;
|
auto inode = TRY(find_file(fd, path, flag)).inode;
|
||||||
|
|
||||||
if (uid != -1 && !m_credentials.is_superuser())
|
if (uid != -1 && !m_credentials.is_superuser())
|
||||||
return BAN::Error::from_errno(EPERM);
|
return BAN::Error::from_errno(EPERM);
|
||||||
|
@ -1425,7 +1425,7 @@ namespace Kernel
|
||||||
LockGuard _(m_process_lock);
|
LockGuard _(m_process_lock);
|
||||||
TRY(validate_pointer_access(buf, sizeof(struct stat), true));
|
TRY(validate_pointer_access(buf, sizeof(struct stat), true));
|
||||||
|
|
||||||
auto inode = TRY(find_file(fd, path, O_SEARCH | flag)).inode;
|
auto inode = TRY(find_file(fd, path, flag)).inode;
|
||||||
buf->st_dev = inode->dev();
|
buf->st_dev = inode->dev();
|
||||||
buf->st_ino = inode->ino();
|
buf->st_ino = inode->ino();
|
||||||
buf->st_mode = inode->mode().mode;
|
buf->st_mode = inode->mode().mode;
|
||||||
|
@ -1451,7 +1451,7 @@ namespace Kernel
|
||||||
|
|
||||||
auto absolute_path = TRY(absolute_path_of(path));
|
auto absolute_path = TRY(absolute_path_of(path));
|
||||||
|
|
||||||
auto file = TRY(VirtualFileSystem::get().file_from_absolute_path(m_credentials, absolute_path, O_SEARCH));
|
auto file = TRY(VirtualFileSystem::get().file_from_absolute_path(m_credentials, absolute_path, O_RDONLY));
|
||||||
if (file.canonical_path.size() >= PATH_MAX)
|
if (file.canonical_path.size() >= PATH_MAX)
|
||||||
return BAN::Error::from_errno(ENAMETOOLONG);
|
return BAN::Error::from_errno(ENAMETOOLONG);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue