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)
Feb 10 2024, 5:39 AM
Unknown Object (File)
Dec 27 2023, 10:58 AM
Unknown Object (File)
Dec 23 2023, 12:10 AM
Unknown Object (File)
Dec 12 2023, 1:38 AM
Unknown Object (File)
Nov 4 2023, 10:50 PM
Unknown Object (File)
Nov 4 2023, 10:41 PM
Unknown Object (File)
Oct 3 2023, 7:55 AM
Unknown Object (File)
Sep 13 2023, 11:14 PM
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.