1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-25 14:27:35 +00:00

LibC+Kernel: Switch off_t to 64 bits

This commit is contained in:
Jean-Baptiste Boric 2021-03-13 22:02:54 +01:00 committed by Andreas Kling
parent b05b4d4b24
commit 7a079f7780
7 changed files with 23 additions and 13 deletions

View file

@ -244,7 +244,7 @@ struct SC_mmap_params {
int32_t prot; int32_t prot;
int32_t flags; int32_t flags;
int32_t fd; int32_t fd;
ssize_t offset; int64_t offset;
StringArgument name; StringArgument name;
}; };

View file

@ -276,7 +276,6 @@ public:
KResultOr<int> sys$dump_backtrace(); KResultOr<int> sys$dump_backtrace();
KResultOr<pid_t> sys$gettid(); KResultOr<pid_t> sys$gettid();
KResultOr<int> sys$donate(pid_t tid); KResultOr<int> sys$donate(pid_t tid);
KResultOr<int> sys$ftruncate(int fd, off_t);
KResultOr<pid_t> sys$setsid(); KResultOr<pid_t> sys$setsid();
KResultOr<pid_t> sys$getsid(pid_t); KResultOr<pid_t> sys$getsid(pid_t);
KResultOr<int> sys$setpgid(pid_t pid, pid_t pgid); KResultOr<int> sys$setpgid(pid_t pid, pid_t pgid);
@ -299,7 +298,8 @@ public:
KResultOr<ssize_t> sys$writev(int fd, Userspace<const struct iovec*> iov, int iov_count); KResultOr<ssize_t> sys$writev(int fd, Userspace<const struct iovec*> iov, int iov_count);
KResultOr<int> sys$fstat(int fd, Userspace<stat*>); KResultOr<int> sys$fstat(int fd, Userspace<stat*>);
KResultOr<int> sys$stat(Userspace<const Syscall::SC_stat_params*>); KResultOr<int> sys$stat(Userspace<const Syscall::SC_stat_params*>);
KResultOr<int> sys$lseek(int fd, off_t, int whence); KResultOr<int> sys$lseek(int fd, Userspace<off_t*>, int whence);
KResultOr<int> sys$ftruncate(int fd, Userspace<off_t*>);
KResultOr<int> sys$kill(pid_t pid_or_pgid, int sig); KResultOr<int> sys$kill(pid_t pid_or_pgid, int sig);
[[noreturn]] void sys$exit(int status); [[noreturn]] void sys$exit(int status);
KResultOr<int> sys$sigreturn(RegisterState& registers); KResultOr<int> sys$sigreturn(RegisterState& registers);

View file

@ -29,9 +29,12 @@
namespace Kernel { namespace Kernel {
KResultOr<int> Process::sys$ftruncate(int fd, off_t length) KResultOr<int> Process::sys$ftruncate(int fd, Userspace<off_t*> userspace_length)
{ {
REQUIRE_PROMISE(stdio); REQUIRE_PROMISE(stdio);
off_t length;
if (!copy_from_user(&length, userspace_length))
return EFAULT;
if (length < 0) if (length < 0)
return EINVAL; return EINVAL;
auto description = file_description(fd); auto description = file_description(fd);

View file

@ -29,13 +29,22 @@
namespace Kernel { namespace Kernel {
KResultOr<int> Process::sys$lseek(int fd, off_t offset, int whence) KResultOr<int> Process::sys$lseek(int fd, Userspace<off_t*> userspace_offset, int whence)
{ {
REQUIRE_PROMISE(stdio); REQUIRE_PROMISE(stdio);
auto description = file_description(fd); auto description = file_description(fd);
if (!description) if (!description)
return EBADF; return EBADF;
return description->seek(offset, whence); off_t offset;
if (!copy_from_user(&offset, userspace_offset))
return EFAULT;
offset = description->seek(offset, whence);
if (!copy_to_user(userspace_offset, &offset))
return EFAULT;
if (offset < 0)
return offset;
else
return 0;
} }
} }

View file

@ -424,9 +424,7 @@ struct sigaction {
#define CLD_STOPPED 4 #define CLD_STOPPED 4
#define CLD_CONTINUED 5 #define CLD_CONTINUED 5
#define OFF_T_MAX 2147483647 typedef i64 off_t;
typedef ssize_t off_t;
typedef i64 time_t; typedef i64 time_t;
struct utimbuf { struct utimbuf {

View file

@ -55,7 +55,7 @@ typedef int id_t;
typedef __WINT_TYPE__ wint_t; typedef __WINT_TYPE__ wint_t;
typedef uint32_t ino_t; typedef uint32_t ino_t;
typedef ssize_t off_t; typedef int64_t off_t;
typedef uint32_t dev_t; typedef uint32_t dev_t;
typedef uint16_t mode_t; typedef uint16_t mode_t;

View file

@ -440,8 +440,8 @@ ssize_t readlink(const char* path, char* buffer, size_t size)
off_t lseek(int fd, off_t offset, int whence) off_t lseek(int fd, off_t offset, int whence)
{ {
int rc = syscall(SC_lseek, fd, offset, whence); int rc = syscall(SC_lseek, fd, &offset, whence);
__RETURN_WITH_ERRNO(rc, rc, -1); __RETURN_WITH_ERRNO(rc, offset, -1);
} }
int link(const char* old_path, const char* new_path) int link(const char* old_path, const char* new_path)
@ -633,7 +633,7 @@ char* getlogin()
int ftruncate(int fd, off_t length) int ftruncate(int fd, off_t length)
{ {
int rc = syscall(SC_ftruncate, fd, length); int rc = syscall(SC_ftruncate, fd, &length);
__RETURN_WITH_ERRNO(rc, rc, -1); __RETURN_WITH_ERRNO(rc, rc, -1);
} }