Page MenuHomeFreeBSD

libc/libc/rpc: refactor some global variables
ClosedPublic

Authored by asomers on Nov 14 2023, 4:51 PM.
Tags
None
Referenced Files
F108429596: D42597.id.diff
Fri, Jan 24, 5:19 PM
Unknown Object (File)
Wed, Jan 22, 8:14 AM
Unknown Object (File)
Sat, Jan 18, 9:49 PM
Unknown Object (File)
Sat, Jan 18, 9:34 PM
Unknown Object (File)
Sat, Jan 18, 9:31 PM
Unknown Object (File)
Mon, Jan 6, 10:37 AM
Unknown Object (File)
Dec 17 2024, 5:48 AM
Unknown Object (File)
Dec 5 2024, 4:15 AM
Subscribers

Details

Summary
  • Combine dg_fd_locks and dg_cv into one array.
  • Similarly for vc_fd_locks and vc_cv
  • Turn some macros into inline functions

This is a mostly cosmetic change to make refactoring these strutures in
a future commit easier.

MFC after: 2 weeks
Sponsored by: Axcient

Switch the per-fd structs in clnt_{dg,vc}.c to RB Trees

This saves oodles of memory, especially when "ulimit -n" is large. It
also prevents a buffer overflow if getrlimit should fail.

PR: 274968
MFC after: 2 weeks
Sponsored by: Axcient

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

lib/libc/rpc/clnt_dg.c
126
151

This assert is not too useful, the next line traps on NULL elem.

335

Or make lock bool

336

I do not think this is valid optimization. If the process is single-threaded, it cannot contend. But if between lock and unlock, process changes from single- to multi-threaded mode, you allow for the unlocked accesses.

lib/libc/rpc/clnt_vc.c
123–128

Condvars are not protected by mutex, they are used together with it.

134

Why is it useful to have per-client cv? You use global mutex, and it would be congested in the same way as global cv, one for all clients.

asomers added inline comments.
lib/libc/rpc/clnt_dg.c
151

Ok, I can eliminate the assert if you prefer.

335

Ok, bool it is.

336

That makes sense. But it's unrelated to the memory savings I'm trying to achieve. Would you accept this review as-is, and I make a followup to remove the single-threaded optimization?

lib/libc/rpc/clnt_vc.c
134

I don't know, but it's always been that way, apparently since at least 1999. The tirpc implementation used on GNU/Linux still allocates one condvar per file descriptor. Solaris eliminated condvars entirely, switching to use an actual mutex for each file descriptor instead of the bool "lock" variable. That switch must've happened sometime before 2005.

asomers marked 2 inline comments as done.
  • Respond to kib's comments.
lib/libc/rpc/clnt_dg.c
126

Still not fixed

336

Sure, it is a different change. I would put it before memory optimization in the patch series.

lib/libc/rpc/clnt_vc.c
134

Should we do the same? This sound more straightforward and IMO simply cleaner.

156
asomers added inline comments.
lib/libc/rpc/clnt_vc.c
134

It's a more intrusive change than what I'd planned. How would you test it? The ATF tests for rpc aren't very comprehensive.

lib/libc/rpc/clnt_dg.c
126

Still not fixed

lib/libc/rpc/clnt_vc.c
134

Isn't just calling client side rpc enough?

BTW, switching to per-fd mutex also fixes the __isthreaded bug.

  • style change to dg_fd_find and vc_fd_find
  • rpc: Replace per-fd condvars with mutexes in clnt_{vc,dg}.c
lib/libc/rpc/clnt_dg.c
145

Why () are needed around mask?

624–625

With minor reordering, can you use release_fd_lock() there?
Also, is nesting of clnt_fd_lock -> elem->mtx is needed? Can you confine clnt_fd_lock to dg_fd_find()?

803–804

Same notes there, about nesting.

asomers added inline comments.
lib/libc/rpc/clnt_dg.c
145

Because this function used to be a macro. I'll remove them.

624–625

With minor reordering, can you use release_fd_lock() there?

Yes

Also, is nesting of clnt_fd_lock -> elem->mtx is needed? Can you confine clnt_fd_lock to dg_fd_find()?

I'm not sure. I started to do that, but the old code held the clnt_fd_lock until after modifying xdrs. I don't know if that is necessary or an accident, so I left it.

asomers marked an inline comment as done.
  • style fixup to "libc/libc/rpc: refactor some global variables"
  • fixup to "rpc: Replace per-fd condvars with mutexes in clnt_{vc,dg}.c"

Two minor issues with possible use of release_fd_lock() IMO worth fixing.

lib/libc/rpc/clnt_dg.c
803–804

So why not use release_fd_lock() there?

lib/libc/rpc/clnt_vc.c
655–656

release_fd_lock()

This revision is now accepted and ready to land.Nov 15 2023, 10:43 PM