Page MenuHomeFreeBSD

libc/libc/rpc: refactor some global variables
ClosedPublic

Authored by asomers on Nov 14 2023, 4:51 PM.
Tags
None
Referenced Files
Unknown Object (File)
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 Passed
Unit
No Test Coverage
Build Status
Buildable 54421
Build 51311: arc lint + arc unit

Event Timeline

lib/libc/rpc/clnt_dg.c
128
153

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

356

Or make lock bool

358

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
124

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

135

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
153

Ok, I can eliminate the assert if you prefer.

356

Ok, bool it is.

358

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
135

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
128

Still not fixed

358

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

lib/libc/rpc/clnt_vc.c
135

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

157
asomers added inline comments.
lib/libc/rpc/clnt_vc.c
135

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
128

Still not fixed

lib/libc/rpc/clnt_vc.c
135

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
147

Why () are needed around mask?

648–649

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()?

831–832

Same notes there, about nesting.

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

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

648–649

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
831–832

So why not use release_fd_lock() there?

lib/libc/rpc/clnt_vc.c
683–684

release_fd_lock()

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