Page MenuHomeFreeBSD

sound: Safely remove channel from list in one pass
ClosedPublic

Authored by dev_submerge.ch on Dec 26 2024, 11:38 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Oct 24, 10:45 PM
Unknown Object (File)
Fri, Oct 24, 1:06 AM
Unknown Object (File)
Thu, Oct 23, 2:16 PM
Unknown Object (File)
Tue, Oct 21, 12:30 PM
Unknown Object (File)
Mon, Oct 6, 1:17 PM
Unknown Object (File)
Sun, Oct 5, 3:49 PM
Unknown Object (File)
Sun, Sep 28, 11:32 PM
Unknown Object (File)
Sep 21 2025, 9:28 PM
Subscribers

Details

Summary

The CHN_REMOVE_SAFE() macro did two traversals of the channel list to
remove a channel, one to check whether the channel is an element of the
list, and a second traversal through SLIST_REMOVE(). Reduce this to one
traversal, while still preventing a NULL dereference in case the channel
in question is not present in the list.

While here, rename the macro arguments to something more descriptive.

MFC after: 1 week

Diff Detail

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

Event Timeline

I stumbled upon that repeated list traversal when reviewing D48185. The implementation is roughly based on SLIST_REMOVE(). Compared to CHN_REMOVE(), the difference in performance should be only minuscule, doing one additional NULL pointer check per iteration. Therefore we may want to consider using the safe variant everywhere.

Renaming the macro arguments improves readability a lot for me, but I'm open for suggestions. I tried to take a hint or two from the SLIST_*() macros.

LGTM. I was also about to recommend using the safe variant throughout sound(4), and just saw you mentioned it here as well. It's a good idea IMHO.

This revision is now accepted and ready to land.Dec 27 2024, 7:40 PM
christos retitled this revision from sound: Safely remove channel from list in one pass. to sound: Safely remove channel from list in one pass.Jan 21 2025, 11:59 AM