diff options
author | Anton Kling <anton@kling.gg> | 2024-03-28 10:34:00 +0100 |
---|---|---|
committer | Anton Kling <anton@kling.gg> | 2024-03-28 10:34:00 +0100 |
commit | 7eceb43433634ee253507208baf1d8298b40e377 (patch) | |
tree | 59c399d8bd9a24d9a74c52f3830125b1dd217e95 /kernel/fs/vfs.c | |
parent | 873c45b99fe05e43c71763c385da54b0945bf8a3 (diff) |
new stuff
Diffstat (limited to 'kernel/fs/vfs.c')
-rw-r--r-- | kernel/fs/vfs.c | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/kernel/fs/vfs.c b/kernel/fs/vfs.c index f2b763c..505d6ae 100644 --- a/kernel/fs/vfs.c +++ b/kernel/fs/vfs.c @@ -375,7 +375,23 @@ int vfs_pwrite(int fd, void *buf, u64 count, u64 offset) { if (!(vfs_fd->flags & O_WRITE)) { return -EBADF; } - return raw_vfs_pwrite(vfs_fd, buf, count, offset); + int rc = raw_vfs_pwrite(vfs_fd, buf, count, offset); + if (-EAGAIN == rc) { + if (!(vfs_fd->flags & O_NONBLOCK)) { + struct pollfd fds; + do { + fds.fd = fd; + fds.events = POLLOUT; + fds.revents = 0; + int rc = poll(&fds, 1, 0); + if (-EINTR == rc) { + return -EINTR; + } + } while (!(fds.revents & POLLOUT)); + return vfs_pwrite(fd, buf, count, offset); + } + } + return rc; } vfs_vm_object_t *vfs_get_vm_object(int fd, u64 length, u64 offset) { |