Title: JIT error stubs don't account for peeks · Issue #126222 · python/cpython · GitHub
Open Graph Title: JIT error stubs don't account for peeks · Issue #126222 · python/cpython
X Title: JIT error stubs don't account for peeks · Issue #126222 · python/cpython
Description: Crash report When deciding how many stack items to pop in an _ERROR_POP_N stub, we use _PyUop_num_popped. However, for opcodes with "peeked" items that never get popped, this is incorrect. For example, consider SET_ADD(2). It has three i...
Open Graph Description: Crash report When deciding how many stack items to pop in an _ERROR_POP_N stub, we use _PyUop_num_popped. However, for opcodes with "peeked" items that never get popped, this is incorrect. For exam...
X Description: Crash report When deciding how many stack items to pop in an _ERROR_POP_N stub, we use _PyUop_num_popped. However, for opcodes with "peeked" items that never get popped, this is incorrect...
Opengraph URL: https://github.com/python/cpython/issues/126222
X: @github
Domain: github.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"JIT error stubs don't account for peeks","articleBody":"# Crash report\r\n\r\nWhen deciding how many stack items to pop in an `_ERROR_POP_N` stub, we use `_PyUop_num_popped`. However, for opcodes with \"peeked\" items that never get popped, this is incorrect.\r\n\r\nFor example, consider `SET_ADD(2)`. It has three inputs and two outputs. However, both of the bottom inputs are the same as the outputs, and are never really popped. When compiling an error stub for the JIT, using `_PyUop_num_popped` will create `_ERROR_POP_N(3)`, which leaks both references and shrinks the stack too far:\r\n\r\n```py\r\n# 17 Nones to warm up, then a list to raise TypeError:\r\nitems = 17 * [None] + [[]]\r\n{item for item in items}\r\n# Assertion failed: (STACK_LEVEL() \u003e= level), function _PyEval_EvalFrameDefault, file ceval.c, line 966.\r\n```\r\n\r\nThe compiled trace for the comprehension is:\r\n\r\n```\r\n 0 OPTIMIZED: _START_EXECUTOR (0, target=20, operand=0x101644de0)\r\n 1 OPTIMIZED: _MAKE_WARM (0, target=0, operand=0)\r\n 2 OPTIMIZED: _SET_IP (0, target=20, operand=0x1017b85f8)\r\n 3 OPTIMIZED: _CHECK_PERIODIC (0, jump_target=0, operand=0, error_target=13)\r\n 4 OPTIMIZED: _CHECK_VALIDITY (0, jump_target=14, operand=0x1017b85f0)\r\n 5 OPTIMIZED: _ITER_CHECK_LIST (4, jump_target=15, operand=0)\r\n 6 OPTIMIZED: _GUARD_NOT_EXHAUSTED_LIST (4, jump_target=16, operand=0)\r\n 7 OPTIMIZED: _ITER_NEXT_LIST (4, target=16, operand=0)\r\n 8 OPTIMIZED: _STORE_FAST_0 (0, target=18, operand=0)\r\n 9 OPTIMIZED: _LOAD_FAST_0 (0, target=18, operand=0)\r\n 10 OPTIMIZED: _SET_IP (0, target=19, operand=0x1017b85f6)\r\n 11 OPTIMIZED: _SET_ADD (2, jump_target=0, operand=0, error_target=17)\r\n 12 OPTIMIZED: _JUMP_TO_TOP (0, jump_target=1, operand=0)\r\n 13 OPTIMIZED: _ERROR_POP_N (0, target=0, operand=0x14)\r\n 14 OPTIMIZED: _DEOPT (0, target=16, operand=0)\r\n 15 OPTIMIZED: _EXIT_TRACE (0, target=16, operand=0x101644e60)\r\n 16 OPTIMIZED: _EXIT_TRACE (0, target=23, operand=0x101644e70)\r\n 17 OPTIMIZED: _ERROR_POP_N (3, target=0, operand=0x13)\r\n```\r\n\r\n@markshannon, does this make sense to generate new tables for in the cases generator? Not sure what the best option is.\n\n\u003c!-- gh-linked-prs --\u003e\n### Linked PRs\n* gh-126507\n\u003c!-- /gh-linked-prs --\u003e\n","author":{"url":"https://github.com/brandtbucher","@type":"Person","name":"brandtbucher"},"datePublished":"2024-10-31T03:23:55.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":1},"url":"https://github.com/126222/cpython/issues/126222"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:6a84c8f4-96a8-11cd-ce90-d3936bc3b0dc |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | 84D8:3C9251:15BA5B:1D1329:696B309E |
| html-safe-nonce | 6feea6ee59c0fe5539b3cf5556b431614f1bfc0ccfaa0a4635f7bdfb436251de |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4NEQ4OjNDOTI1MToxNUJBNUI6MUQxMzI5OjY5NkIzMDlFIiwidmlzaXRvcl9pZCI6Ijc0MTMwMTMwMTM3NzUyMDA0MTQiLCJyZWdpb25fZWRnZSI6ImlhZCIsInJlZ2lvbl9yZW5kZXIiOiJpYWQifQ== |
| visitor-hmac | c8508d4009040cfc5884008ef2edd929df355de745d49bb757a40c519df6ce19 |
| hovercard-subject-tag | issue:2625887267 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/python/cpython/126222/issue_layout |
| twitter:image | https://opengraph.githubassets.com/beb07973412f0d9b9b37e6e67ff54ab6b5aac0331489ae9accce15c61a73a966/python/cpython/issues/126222 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/beb07973412f0d9b9b37e6e67ff54ab6b5aac0331489ae9accce15c61a73a966/python/cpython/issues/126222 |
| og:image:alt | Crash report When deciding how many stack items to pop in an _ERROR_POP_N stub, we use _PyUop_num_popped. However, for opcodes with "peeked" items that never get popped, this is incorrect. For exam... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | brandtbucher |
| hostname | github.com |
| expected-hostname | github.com |
| None | 5f99f7c1d70f01da5b93e5ca90303359738944d8ab470e396496262c66e60b8d |
| turbo-cache-control | no-preview |
| go-import | github.com/python/cpython git https://github.com/python/cpython.git |
| octolytics-dimension-user_id | 1525981 |
| octolytics-dimension-user_login | python |
| octolytics-dimension-repository_id | 81598961 |
| octolytics-dimension-repository_nwo | python/cpython |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 81598961 |
| octolytics-dimension-repository_network_root_nwo | python/cpython |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | 82560a55c6b2054555076f46e683151ee28a19bc |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width