Page MenuHomeFreeBSD

Defer inpcb deletion until after a grace period has elapsed
ClosedPublic

Authored by mmacy on May 21 2018, 6:08 PM.
Tags
None
Referenced Files
F108313435: D15510.id42803.diff
Thu, Jan 23, 7:02 PM
Unknown Object (File)
Sat, Jan 18, 5:52 PM
Unknown Object (File)
Thu, Jan 9, 12:20 AM
Unknown Object (File)
Dec 23 2024, 8:53 AM
Unknown Object (File)
Nov 19 2024, 8:39 PM
Unknown Object (File)
Nov 1 2024, 3:07 PM
Unknown Object (File)
Oct 26 2024, 10:39 AM
Unknown Object (File)
Sep 25 2024, 7:55 AM

Details

Summary

I believe that this fixes at least the issue raised in the revert request.

Test Plan

pho + LLNW canary

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

Having stared at this a bit, I generally think its fine. In fact, in some aspects it is an improvement over what it replaces.

Personally, I can't see any obvious locking/lifecycle assumptions that are violated that could cause problems, but would appreciate other eyes staring at it.

sys/netinet/in_pcb.c
1353 ↗(On Diff #42803)

It's not entirely clear to me what this comment means. Therefore, I wonder if this comment is still placed correctly after this change?

1373 ↗(On Diff #42803)

Its a small nit (and has existed for a while), but I believe this needs to always return non-0 in this context. A zero return value would indicate a bug.

So, this should probably be asserted to return non-zero for INVARIANTS.

1409 ↗(On Diff #42803)

Since in_pcbremlists also increments the gencnt, this results in a double gencnt change. It looks like this was added 20 years ago (r36079). Why don't we fix this 20-year-old bug? :-)

This revision is now accepted and ready to land.May 21 2018, 6:59 PM
sys/netinet/in_pcb.c
1353 ↗(On Diff #42803)

Yes. It can go.

1373 ↗(On Diff #42803)

You're right. Even if refcount is > 0 the INP_FREED check will cause it to return 1.

1409 ↗(On Diff #42803)

Coming right up.

Looking closely at this and thinking about tcp_hpts.c, if I grok this correctly
this should all integrate ok. Assuming that someone calls inp_pcbfree() on
something that is in hpts, even if the epoch_call happens, the inpcb won't
be freed until the hpts's main loop see the INP_FREED flag and does
its in_pcbrele_wlocked() call at which time the INP will finally get destroyed.

I am not as familiar with your epoch system yet
(though it reminds me of something I did at Adara). I would suggest you
test this with the hpts system and INVARIANTS on to see if my
supposition is true. If you don't have access to the rack or bbr code
let me know I can provide you with it. I am a bit behind due to meetings
with google getting the phabricator up with rack in it which would have made
it a bit easier :-o

We'll test this at LLNW with the stacks

This revision was automatically updated to reflect the committed changes.