-
-
Notifications
You must be signed in to change notification settings - Fork 31.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
gh-130704: Strength reduce LOAD_FAST{_LOAD_FAST}
#130708
Merged
+1,282
−345
Merged
Changes from all commits
Commits
Show all changes
81 commits
Select commit
Hold shift + click to select a range
d716faa
Experiment with borrowing load_fast
mpage 3736923
Checkpoint poc
mpage 7a14254
Fix pyframe copy
mpage b1607aa
Strengthen refs when frame is copied
mpage e765735
Cleanup
mpage 291ace9
Consider all instructions when computing mutations
mpage 17d6dd6
Add a super instruction
mpage 0a74052
Don't optimize during quickening
mpage afbfd88
Use abstract interpretation
mpage 696c630
Fix test_generators
mpage 483ac7a
Optimize returns
mpage 259d5db
Remove unused arg
mpage aeafa98
Make sure we convert borrowed refs on frame
mpage 85f9a64
Don't test with malformed bytecode
mpage b6ab2f7
Make sure we convert borrowed refs to func/code when copying generato…
mpage fd1ad3d
Add support for disassembling LOAD_FAST_BORROW_LOAD_FAST_BORROW
mpage eee2195
Make sure exc_obj is always defined
mpage d75ec9a
Make sure we store new stackrefs for frame executable/funcobj
mpage 66f5351
Remove refcount check
mpage 7ef6a0b
Don't hardcode initial refcount in refcount tests
mpage 2af2bbc
Remove invalid bytecode from `test_peepholer`
mpage bf19b7d
Fix invalid bytecode in `test_peepholer.DirectCfgOptimizerTests.test_…
mpage a9bca03
Fix tests that checked for `LOAD_FAST` instructions that are now opti…
mpage 293c317
Update disassembly in test_dis to match new bytecode
mpage a12ccd9
Fix refleak in _BINARY_OP_INPLACE_ADD_UNICODE
mpage 1ef26c5
Create new references to fast locals overwritten via f_locals
mpage 1eb9226
Implement two missing opcodes in the static analysis
mpage 7291c49
Use g_block_list when resetting stack depth
mpage 90bf8df
Avoid reallocating state for each basic block
mpage 9bfa922
Generators
mpage bf6222b
Move optimize after all other passes have run
mpage dd97d0c
Don't promote borrowed references in STORE_FAST
mpage 6680709
Track reasons for not being able to optimize instructions
mpage 6568fd9
Rename PyStackRef_DupDeferred
mpage 6fde7b0
Rename _PyStackRef_StealIfUnborrowed
mpage de13810
Avoid extra copies in take_ownership
mpage fdeae7d
Make the default build work
mpage 1aed281
Add docs for new opcodes
mpage c332912
Fix flag array size computation
mpage 76a75a7
Add a high level comment explaining our approach
mpage dd6426f
Bump magic number after merge (was bumped on main)
mpage bf68eb9
Add more tests
mpage 474a587
Update commented out assertion
mpage 4b3aacf
Add NEWS entry
mpage e692037
Remove debug print
mpage 2ecfe08
Merge branch 'main' into load-fast-borrow-absinterp
mpage f98d91d
Fix doctest
mpage 725dc8e
Fix JIT tests
mpage 03d35b2
Fix missed doctest
mpage 39ff3f0
Fix narrowing
mpage f012a9f
Formatting
mpage b4b7f73
Merge branch 'main' into load-fast-borrow-absinterp
mpage 8ea82b5
Implement PyStackRef_{Is,Make}HeapSafe
mpage 9bec9f5
Add missing error handling
mpage 902ae84
Simplify frees
mpage b0ea38f
Get rid of `PyStackRef_IsBorrowed`
mpage 1f5cfcd
Use PyStackRef_Borrow as the new API
mpage d1e8e45
Make the default build work
mpage 00c95cc
Merge branch 'main' into load-fast-borrow-absinterp
mpage cc01a30
Regen frozenmain
mpage 6c5faab
Add a workaround for failing tests rather than change marshal.c
mpage 32bd0c6
Update dis.rst to reflect support for LOAD_FAST_BORROW in the default…
mpage fdb8a82
Exclude immortal objects when keeping overwritten locals alive
mpage a962017
Use a tuple to store overwritten fast locals
mpage 6c2f07d
Fix off-by-one error
mpage 85b0b00
Merge branch 'main' into load-fast-borrow-absinterp
mpage 5ff2dea
Fix post-merge issues
mpage 0c1e67f
English is hard
mpage ae2ec65
Improve readability of test cases
mpage 03c474e
Elaborate in the blurb
mpage 60665c9
Remove parameter to calculate stackdepth
mpage ac8940b
Update comment
mpage f12573f
Test optimize_load_fast as part of OptimizeCfg
mpage 44f7ffc
Remove test with invalid bytecode
mpage 818e94e
Add helper macro for pushing refs
mpage c30e1e9
Handle opcodes that leave at least one input on the stack
mpage 112cee6
Merge branch 'main' into load-fast-borrow-absinterp
mpage 80fc5aa
Avoid having stackref only visible from the c stack
mpage 492cce1
Merge branch 'main' into load-fast-borrow-absinterp
mpage 2e38f0d
Merge branch 'main' into load-fast-borrow-absinterp
mpage 2c55722
Merge branch 'main' into load-fast-borrow-absinterp
mpage File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there an issue for adding lifetime checking for this?
If not, could you make one and assign it to either yourself or me?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
#131527