Page MenuHomeFreeBSD

Remove artificial restriction on lio_listio's operation count
ClosedPublic

Authored by asomers on Aug 24 2017, 7:35 PM.
Tags
None
Referenced Files
F108512519: D12120.id33413.diff
Sat, Jan 25, 7:19 PM
F108511607: D12120.id32370.diff
Sat, Jan 25, 7:11 PM
Unknown Object (File)
Fri, Jan 24, 7:16 PM
Unknown Object (File)
Fri, Jan 24, 7:14 PM
Unknown Object (File)
Fri, Jan 24, 3:36 PM
Unknown Object (File)
Sat, Jan 18, 8:09 AM
Unknown Object (File)
Fri, Jan 10, 5:24 AM
Unknown Object (File)
Dec 26 2024, 1:10 AM
Subscribers

Details

Summary

Remove artificial restriction on lio_listio's operation count

In r322258 I made p1003_1b.aio_listio_max a tunable. However, further
investigation shows that there was never any good reason for that limit to
exist in the first place. It's used in two completely different ways:

  • To size a UMA zone, which globally limits the number of concurrent aio_suspend calls.
  • To artifically limit the number of operations in a single lio_listio call. There doesn't seem to be any memory allocation associated with this limit.

This change does two things:

  • Properly names aio_suspend's UMA zone, and sizes it based on a new constant.
  • Eliminates the artifical restriction on lio_listio. Instead, lio_listio calls will now be limited by the more generous max_aio_queue_per_proc. The old p1003_1b.aio_listio_max is now an alias for vfs.aio.max_aio_queue_per_proc, so sysconf(3) will still work with _SC_AIO_LISTIO_MAX.

Reported by: bde

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 11226
Build 11604: arc lint + arc unit

Event Timeline

sys/kern/vfs_aio.c
1959

This should probably honor the max aio queue per proc limit rather than being its own thing.

1970

I kind of feel like this shouldn't be a UMA zone at all, but just a plain malloc + free. It's just an array of pointers, not a structure, and will often be variable sized. If you do this, then you can just honor the current max per proc limit above and not have to worry about the fixed size of a UMA zone item.

Respond to jhb's suggestions:

  1. Use malloc instead of uma_zalloc for aio_suspend
  2. remove the MAX_AIO_SUSPEND constant
This revision is now accepted and ready to land.Sep 25 2017, 8:00 PM
This revision now requires review to proceed.Sep 25 2017, 8:28 PM

Sorry I didn't include the man page differences originally. I just realized that they need updating. I also noticed that there are a lot of other man pages that reference preprocessor symbols like IOV_MAX when they should be referencing sysconf/getconf variables like {IOV_MAX} instead. I'll update those separately.

This revision was automatically updated to reflect the committed changes.