Skip to content

feat[venom]: improve liveness computation time#4086

Merged
charles-cooper merged 8 commits intovyperlang:masterfrom
charles-cooper:perf/liveness
Sep 18, 2024
Merged

feat[venom]: improve liveness computation time#4086
charles-cooper merged 8 commits intovyperlang:masterfrom
charles-cooper:perf/liveness

Conversation

@charles-cooper
Copy link
Copy Markdown
Member

@charles-cooper charles-cooper commented May 31, 2024

What I did

reduce time spent in liveness by only recomputing liveness for basic blocks which need it (any of its cfg_out has changed).

reduces time in venom by 25% (e.g. CurveStableSwapNG-0.4.0.vy goes from 1.3s spent in venom to 1s).

there is also a slight codesize improvement. it seems to be sensitive to the order in which items are added to the worklist.

How I did it

How to verify it

Commit message

reduce time spent in liveness by only recomputing liveness for basic
blocks which need it (any of its `cfg_out` has changed).

reduces time in venom by roughly 25%

there is also a slight codesize improvement. it seems to be sensitive
to the order in which items are added to the worklist.

Description for the changelog

Cute Animal Picture

Put a link to a cute animal picture inside the parenthesis-->

harkal and others added 2 commits May 31, 2024 14:54
reduce time spent in liveness by starting from the leaves of the DFS,
and only recomputing liveness for basic blocks which need it (any of its
cfg_out has changed).
@charles-cooper charles-cooper requested a review from harkal May 31, 2024 19:53
@charles-cooper charles-cooper marked this pull request as ready for review May 31, 2024 20:38
@charles-cooper charles-cooper enabled auto-merge (squash) September 18, 2024 19:51
@charles-cooper charles-cooper merged commit e1de93a into vyperlang:master Sep 18, 2024
charles-cooper added a commit to charles-cooper/vyper that referenced this pull request Oct 5, 2024
reduce time spent in liveness by only recomputing liveness for basic
blocks which need it (any of its `cfg_out` has changed).

reduces time in venom by roughly 25%

there is also a slight codesize improvement. it seems to be sensitive
to the order in which items are added to the worklist.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants