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)
Jan 12 2024, 2:56 AM
Unknown Object (File)
Dec 20 2023, 5:44 AM
Unknown Object (File)
Sep 21 2023, 10:25 PM
Unknown Object (File)
Sep 17 2023, 7:29 AM
Unknown Object (File)
Sep 11 2023, 1:37 PM
Unknown Object (File)
Sep 11 2023, 1:37 PM
Unknown Object (File)
Aug 27 2023, 2:54 PM
Unknown Object (File)
Aug 22 2023, 4:11 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.