Page MenuHomeFreeBSD

rb_tree: optimize tree rotation
ClosedPublic

Authored by dougm on Jun 19 2022, 2:59 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Oct 30, 7:14 PM
Unknown Object (File)
Sep 27 2024, 7:58 PM
Unknown Object (File)
Sep 20 2024, 3:02 PM
Unknown Object (File)
Sep 20 2024, 8:03 AM
Unknown Object (File)
Sep 19 2024, 1:38 PM
Unknown Object (File)
Sep 19 2024, 4:39 AM
Unknown Object (File)
Sep 18 2024, 11:47 AM
Unknown Object (File)
Sep 18 2024, 6:19 AM
Subscribers

Details

Summary

The RB_ROTATE macros begin with fetching a field via a pointer. In almost most cases, that value is one that is already in a register, and the compiler cannot infer it. So, to eliminate those needless fetches, have the caller of the RB_ROTATE macros present the data in the third macro parameter, rather than having the macro fetch it.

And a few minor style cleanups.

Diff Detail

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

Event Timeline

dougm requested review of this revision.Jun 19 2022, 2:59 AM
dougm created this revision.

Rename variables in REMOVE_COLOR (elm->child, sib->elm) to make it look more like the INSERT_COLOR code.

Find a better (smaller) way to set 'child' in RB_INSERT_COLOR. Reduce lip3 size from 8830 to 8734.

This revision is now accepted and ready to land.Jun 25 2022, 7:30 AM
This revision was automatically updated to reflect the committed changes.