Page MenuHomeFreeBSD

queue.h: Define {LIST,TAILQ}_REMOVE_HEAD
ClosedPublic

Authored by cperciva on Jul 19 2023, 12:58 AM.
Tags
None
Referenced Files
F108592942: D41072.id124818.diff
Sun, Jan 26, 6:04 PM
Unknown Object (File)
Fri, Jan 24, 5:10 PM
Unknown Object (File)
Nov 24 2024, 5:34 PM
Unknown Object (File)
Nov 14 2024, 6:24 PM
Unknown Object (File)
Sep 21 2024, 6:18 AM
Unknown Object (File)
Sep 20 2024, 1:17 PM
Unknown Object (File)
Sep 20 2024, 1:59 AM
Unknown Object (File)
Sep 19 2024, 5:34 PM
Subscribers

Details

Summary

The LIST and TAILQ structures have fast _REMOVE macros (since each
element has a pointer to the previous element); we implement the
_REMOVE_HEAD macros for them by simply finding the first element and
then removing it.

Sponsored by: https://www.patreon.com/cperciva

Diff Detail

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

Event Timeline

I wonder why these were never implemented before.
FWIW I found one LIST_REMOVE(LIST_FIRST... in the tree, in sys/dev/neta/if_mvneta.c

I wonder why these were never implemented before.

Probably because _REMOVE was considered the "first class citizen" and _REMOVE_HEAD was only provided as an alternative for list types which didn't have _REMOVE.

FWIW I found one LIST_REMOVE(LIST_FIRST... in the tree, in sys/dev/neta/if_mvneta.c

We can change that later. :-)

This revision is now accepted and ready to land.Jul 19 2023, 5:30 PM
This revision was automatically updated to reflect the committed changes.