diff options
author | Anton Kling <anton@kling.gg> | 2023-11-17 21:24:33 +0100 |
---|---|---|
committer | Anton Kling <anton@kling.gg> | 2023-11-17 21:27:26 +0100 |
commit | 99e5c8e046dfff53c331eb35394bfbcab4629fd0 (patch) | |
tree | 690994f164306688bfb3346f218c79301c0f0452 /kernel/fs/vfs.c | |
parent | 6723c96863425bda541e321127f6944bf008446a (diff) |
Kernel: Add isatty syscall
Diffstat (limited to 'kernel/fs/vfs.c')
-rw-r--r-- | kernel/fs/vfs.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/kernel/fs/vfs.c b/kernel/fs/vfs.c index d0c1b95..d55a2bf 100644 --- a/kernel/fs/vfs.c +++ b/kernel/fs/vfs.c @@ -54,7 +54,8 @@ vfs_inode_t *vfs_create_inode( return r; } -int vfs_create_fd(int flags, int mode, vfs_inode_t *inode, vfs_fd_t **fd) { +int vfs_create_fd(int flags, int mode, int is_tty, vfs_inode_t *inode, + vfs_fd_t **fd) { process_t *p = (process_t *)get_current_task(); int i; for (i = 0; i < 100; i++) @@ -67,6 +68,7 @@ int vfs_create_fd(int flags, int mode, vfs_inode_t *inode, vfs_fd_t **fd) { r->mode = mode; r->inode = inode; r->reference_count = 1; + r->is_tty = is_tty; r->offset = 0; p->file_descriptors[i] = r; if (fd) @@ -266,7 +268,8 @@ int vfs_open(const char *file, int flags, int mode) { return uds_open(resolved_path); } - return vfs_create_fd(flags, mode, inode, NULL); + // FIXME: Maybe it is sometimes a TTY? + return vfs_create_fd(flags, mode, 0 /*is_tty*/, inode, NULL); } int vfs_close(int fd) { |