Re: io_uring vs in_compat_syscall()

From: Christoph Hellwig
Date: Tue Jul 21 2020 - 03:07:14 EST


On Mon, Jul 20, 2020 at 10:28:55AM -0700, Andy Lutomirski wrote:
> > Sure, I'd consider that implementation detail for the actual patch(es)
> > for this issue.
>
> Thereâs a corner case, though: doesnât io_uring submission frequently do the work synchronously in the context of the calling thread?

Yes.

> If so, can a thread do a 64-bit submit with 32-bit work or vice versa?

In theory you could share an fd created in a 32-bit thread to a 64-bit
thread or vice versa, but I think at that point you absolutely are in
"you get to keep the pieces" land.

> Sometimes I think that in_compat_syscall() should have a mode in which calling it warns (e.g. not actually in a syscall when doing things in io_uring). And the relevant operations should be properly wired up to avoid global state like this.

What do you mean with "properly wired up". Do you really want to spread
->compat_foo methods everywhere, including read and write? I found
in_compat_syscall() a lot small and easier to maintain than all the
separate compat cruft.