Page MenuHomeFreeBSD

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

Authored by cperciva on Jul 19 2023, 12:58 AM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Oct 21, 4:09 AM
Unknown Object (File)
Mon, Oct 13, 7:54 AM
Unknown Object (File)
Mon, Oct 13, 7:54 AM
Unknown Object (File)
Mon, Oct 13, 7:54 AM
Unknown Object (File)
Sun, Oct 12, 7:38 PM
Unknown Object (File)
Sep 18 2025, 12:25 AM
Unknown Object (File)
Sep 18 2025, 12:25 AM
Unknown Object (File)
Sep 18 2025, 12:25 AM
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.