Page MenuHomeFreeBSD

Account for AIO socket operations in thread/process resource usage.
ClosedPublic

Authored by jhb on Jun 21 2016, 9:28 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 17, 2:39 PM
Unknown Object (File)
Thu, Jan 9, 1:11 PM
Unknown Object (File)
Mon, Jan 6, 10:16 PM
Unknown Object (File)
Nov 24 2024, 7:51 AM
Unknown Object (File)
Nov 16 2024, 1:53 AM
Unknown Object (File)
Nov 5 2024, 11:56 AM
Unknown Object (File)
Oct 19 2024, 11:18 AM
Unknown Object (File)
Oct 2 2024, 9:41 PM
Subscribers

Details

Summary

Account for AIO socket operations in thread/process resource usage.

File and disk-backed I/O requests store counts of read/written disk
blocks in each AIO job so that they can be charged to the thread that
completes an AIO request via aio_return() or aio_waitcomplete(). This
change extends AIO jobs to store counts of received/sent messages and
updates socket backends to set these counts accordingly. Note that
the socket backends are careful to only charge a single messages for
each AIO request even though a single request on a blocking socket might
invoke sosend or soreceive multiple times. This is to mimic the
resource accounting of synchronous read/write.

Adjust the UNIX socketpair AIO test to verify that the message resource
usage counts update accordingly for aio_read and aio_write.

Test Plan
  • Run the added test before and after.
  • Verify the Chelsio DDP change by using '/usr/bin/time -l' on a DDP test program.

Diff Detail

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

Event Timeline

jhb retitled this revision from to Account for AIO socket operations in thread/process resource usage..
jhb updated this object.
jhb edited the test plan for this revision. (Show Details)
  • Simplify the socket msgru accounting.
  • Use long's for raw usage statistics.
This revision was automatically updated to reflect the committed changes.