Skip to content

Commit 6f11adc

Browse files
committed
io_uring: gate REQ_F_ISREG on !S_ANON_INODE as well
io_uring marks a request as dealing with a regular file on S_ISREG. This drives things like retries on short reads or writes, which is generally not expected on a regular file (or bdev). Applications tend to not expect that, so io_uring tries hard to ensure it doesn't deliver short IO on regular files. However, a recent commit added S_IFREG to anonymous inodes. When io_uring is used to read from various things that are backed by anon inodes, like eventfd, timerfd, etc, then it'll now all of a sudden wait for more data when rather than deliver what was read or written in a single operation. This breaks applications that issue reads on anon inodes, if they ask for more data than a single read delivers. Add a check for !S_ANON_INODE as well before setting REQ_F_ISREG to prevent that. Cc: Christian Brauner <[email protected]> Cc: [email protected] Link: ghostty-org/ghostty#7720 Fixes: cfd86ef ("anon_inode: use a proper mode internally") Signed-off-by: Jens Axboe <[email protected]>
1 parent 178b8ff commit 6f11adc

File tree

1 file changed

+2
-1
lines changed

1 file changed

+2
-1
lines changed

io_uring/io_uring.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1666,11 +1666,12 @@ static void io_iopoll_req_issued(struct io_kiocb *req, unsigned int issue_flags)
16661666

16671667
io_req_flags_t io_file_get_flags(struct file *file)
16681668
{
1669+
struct inode *inode = file_inode(file);
16691670
io_req_flags_t res = 0;
16701671

16711672
BUILD_BUG_ON(REQ_F_ISREG_BIT != REQ_F_SUPPORT_NOWAIT_BIT + 1);
16721673

1673-
if (S_ISREG(file_inode(file)->i_mode))
1674+
if (S_ISREG(inode->i_mode) && !(inode->i_flags & S_ANON_INODE))
16741675
res |= REQ_F_ISREG;
16751676
if ((file->f_flags & O_NONBLOCK) || (file->f_mode & FMODE_NOWAIT))
16761677
res |= REQ_F_SUPPORT_NOWAIT;

0 commit comments

Comments
 (0)