Stream: git-cranelift

Topic: cranelift / Issue #34 Compact Layout representation


view this post on Zulip GitHub (Feb 28 2020 at 23:19):

alexcrichton transferred Issue #34:

The ir::layout module keeps track of the ordering of instructions and extended basic blocks in a function. It is currently implemented with doubly linked lists of EBBs and instructions. All program points have a sequence number so the ProgramOrder trait can be implemented efficiently.

This representation uses 20 bytes per EBB and 16 bytes per instruction. We should experiment with a more compact layout representation:

This compact representation uses 8 bytes per EBB and 8 bytes per instruction plus a minimal overhead for the non-leaf nodes in the B+-trees.

The Cursor struct should probably contain a path to its position in both B+-trees which means that the standard library B-trees won't work.


Last updated: Jan 24 2025 at 00:11 UTC