Page MenuHomeFreeBSD

Align refcounting in multicast code between IPv4 and IPv6
ClosedPublic

Authored by hselasky on Nov 28 2019, 6:29 PM.
Tags
None
Referenced Files
F107160416: D22595.diff
Sat, Jan 11, 1:27 AM
Unknown Object (File)
Thu, Jan 9, 6:57 AM
Unknown Object (File)
Sun, Jan 5, 10:46 PM
Unknown Object (File)
Sun, Jan 5, 7:02 PM
Unknown Object (File)
Sun, Jan 5, 8:12 AM
Unknown Object (File)
Fri, Jan 3, 1:12 PM
Unknown Object (File)
Thu, Jan 2, 6:13 AM
Unknown Object (File)
Mon, Dec 23, 5:30 PM

Details

Summary

Use refcount from "in_joingroup_locked()" when joining multicast groups. Do not acquire additional references.
This makes the IPv4 IGMP code in line with the IPv6 MLD code.

Background:
The IPv4 multicast code puts an extra reference on the in_multi struct when joining groups.
This becomes visible when using daemons like igmpproxy from ports, that multicast entries
do not disappear from the output of ifmcstat(8) when multicast streams are disconnected.

This fixes a regression issue after r349762.

Tested by: Guido van Rooij <guido@gvr.org>
MFC after: 1 week
Sponsored by: Mellanox Technologies

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 27905

Event Timeline

rgrimes added a subscriber: rgrimes.

Thanks for quickly addressing this. Just a code comment I noticed, and am curious if I missed something that would not allow the removal of a duplicate conditional

sys/netinet/in_mcast.c
2241–2242

Why restest is_new? Cant this line just be moved up to the last line of the prior if (is_new) right where the lock aquire was done before?

This revision is now accepted and ready to land.Dec 3 2019, 7:38 AM
sys/netinet/in_mcast.c
2241–2242

Then we would need to change the error out logic too, I.E. remove the entry upon failure. I think it is best to not insert the entry before everything is clear.

sys/netinet/in_mcast.c
2241–2242

I see your point. Let me re-order.

This revision now requires review to proceed.Dec 3 2019, 8:17 AM
This revision is now accepted and ready to land.Dec 3 2019, 8:30 AM