Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | GH-111843: Tier 2 exponential backoff (GH-111850) | Mark Shannon | 2023-11-09 | 1 | -5/+18 |
| | |||||
* | GH-109369: Exit tier 2 if executor is invalid (GH-111657) | Mark Shannon | 2023-11-09 | 1 | -0/+5 |
| | |||||
* | GH-111848: Tidy up tier 2 handling of FOR_ITER specialization by using ↵ | Mark Shannon | 2023-11-08 | 1 | -29/+11 |
| | | | | DEOPT_IF instead of jumps. (GH-111849) | ||||
* | GH-111485: Allow arbitrary annotations on instructions and micro-ops. ↵ | Mark Shannon | 2023-11-07 | 1 | -13/+18 |
| | | | | (GH-111697) | ||||
* | GH-111485: Make BEFORE_WITH a uop (GH-111812) | Brandt Bucher | 2023-11-07 | 1 | -3/+2 |
| | |||||
* | gh-111354: Simplify _PyGen_yf by moving some of its work to the compiler and ↵ | Irit Katriel | 2023-11-03 | 1 | -2/+6 |
| | | | | frame state (#111648) | ||||
* | gh-111654: remove redundant decref in LOAD_FROM_DICT_OR_DEREF (#111655) | AN Long | 2023-11-03 | 1 | -2/+1 |
| | |||||
* | gh-111354: simplify detection of RESUME after YIELD_VALUE at except-depth 1 ↵ | Irit Katriel | 2023-11-02 | 1 | -4/+2 |
| | | | | (#111459) | ||||
* | GH-111485: Silence warnings in Python/executor_cases.c.h (#111619) | Guido van Rossum | 2023-11-01 | 1 | -0/+2 |
| | |||||
* | gh-111520: Integrate the Tier 2 interpreter in the Tier 1 interpreter (#111428) | Guido van Rossum | 2023-11-01 | 1 | -62/+64 |
| | | | | | | | | | | | - There is no longer a separate Python/executor.c file. - Conventions in Python/bytecodes.c are slightly different -- don't use `goto error`, you must use `GOTO_ERROR(error)` (same for others like `unused_local_error`). - The `TIER_ONE` and `TIER_TWO` symbols are only valid in the generated (.c.h) files. - In Lib/test/support/__init__.py, `Py_C_RECURSION_LIMIT` is imported from `_testcapi`. - On Windows, in debug mode, stack allocation grows from 8MiB to 12MiB. - **Beware!** This changes the env vars to enable uops and their debugging to `PYTHON_UOPS` and `PYTHON_LLTRACE`. | ||||
* | GH-111537: Avoid using `this_instr` in asserts. (GH-111600) | Mark Shannon | 2023-11-01 | 1 | -18/+12 |
| | |||||
* | GH-111485: Use micro-ops to split specialization code from base action ↵ | Mark Shannon | 2023-11-01 | 1 | -40/+112 |
| | | | | (GH-111561) | ||||
* | GH-111485: Remove some special cases from the code generator and bytecodes.c ↵ | Mark Shannon | 2023-10-31 | 1 | -5/+13 |
| | | | | (GH-111540) | ||||
* | GH-111485: Increment `next_instr` consistently at the start of the ↵ | Mark Shannon | 2023-10-31 | 1 | -162/+129 |
| | | | | instruction. (GH-111486) | ||||
* | gh-111386: Fix `uint32_t` cast in `generated_cases.c.h` (#111387) | Nikita Sobolev | 2023-10-27 | 1 | -1/+1 |
| | |||||
* | gh-111354: define names for RESUME oparg values (#111365) | Irit Katriel | 2023-10-26 | 1 | -1/+1 |
| | |||||
* | gh-109094: replace frame->prev_instr by frame->instr_ptr (#109095) | Irit Katriel | 2023-10-26 | 1 | -37/+62 |
| | |||||
* | GH-109214: _SET_IP before _PUSH_FRAME (but not _POP_FRAME) (GH-111001) | Brandt Bucher | 2023-10-24 | 1 | -2/+0 |
| | |||||
* | gh-109094: remove redundant arg to _PyFrame_PushTrampolineUnchecked (GH-110759) | Irit Katriel | 2023-10-12 | 1 | -1/+1 |
| | |||||
* | GH-109214: Convert _SAVE_CURRENT_IP to _SET_IP in tier 2 trace creation. ↵ | Mark Shannon | 2023-10-12 | 1 | -10/+2 |
| | | | | (GH-110755) | ||||
* | GH-109329: Add tier 2 stats (GH-109913) | Michael Droettboom | 2023-10-04 | 1 | -1/+2 |
| | |||||
* | GH-109369: Merge all eval-breaker flags and monitoring version into one ↵ | Mark Shannon | 2023-10-04 | 1 | -9/+13 |
| | | | | word. (GH-109846) | ||||
* | gh-104909: Split more LOAD_ATTR specializations (GH-110317) | Guido van Rossum | 2023-10-04 | 1 | -33/+68 |
| | | | | | | | | | | | | | | | | | | | * Split LOAD_ATTR_MODULE * Split LOAD_ATTR_WITH_HINT * Split _GUARD_TYPE_VERSION out of the latter * Split LOAD_ATTR_CLASS * Split LOAD_ATTR_NONDESCRIPTOR_WITH_VALUES * Fix indent of DEOPT_IF in macros * Split LOAD_ATTR_METHOD_LAZY_DICT * Split LOAD_ATTR_NONDESCRIPTOR_NO_DICT * Fix omission of _CHECK_ATTR_METHOD_LAZY_DICT | ||||
* | gh-109979: Unify _GUARD_TYPE_VERSION{,_STORE} (#110301) | Guido van Rossum | 2023-10-03 | 1 | -8/+2 |
| | | | | | Now the target for `DEOPT_IF()` is auto-filled, we don't need a separate `_GUARD_TYPE_VERSION_STORE` uop. | ||||
* | gh-109979: Auto-generate the target for DEOPT_IF() (#110193) | Guido van Rossum | 2023-10-03 | 1 | -183/+169 |
| | | | | | | | | | | | | | | | | In Python/bytecodes.c, you now write ``` DEOPT_IF(condition); ``` The code generator expands this to ``` DEOPT_IF(condition, opcode); ``` where `opcode` is the name of the unspecialized instruction. This works inside macro expansions too. **CAVEAT:** The entire `DEOPT_IF(condition)` statement must be on a single line. If it isn't, the substitution will fail; an error will be printed by the code generator and the C compiler will report some errors. | ||||
* | gh-110020: Fix unused variable warnings in bytecodes.c (GH-110023) | Nikita Sobolev | 2023-09-28 | 1 | -6/+3 |
| | |||||
* | gh-104909: Split some more insts into ops (#109943) | Guido van Rossum | 2023-09-27 | 1 | -15/+51 |
| | | | | | | | | | | | | | | | | | | | | These are the most popular specializations of `LOAD_ATTR` and `STORE_ATTR` that weren't already viable uops: * Split LOAD_ATTR_METHOD_WITH_VALUES * Split LOAD_ATTR_METHOD_NO_DICT * Split LOAD_ATTR_SLOT * Split STORE_ATTR_SLOT * Split STORE_ATTR_INSTANCE_VALUE Also: * Add `-v` flag to code generator which prints a list of non-viable uops (easter-egg: it can print execution counts -- see source) * Double _Py_UOP_MAX_TRACE_LENGTH to 128 I had dropped one of the DEOPT_IF() calls! :-( | ||||
* | GH-104584: Don't call executors from JUMP_BACKWARD (GH-109347) | Brandt Bucher | 2023-09-13 | 1 | -12/+8 |
| | |||||
* | GH-105848: Replace KW_NAMES + CALL with LOAD_CONST + CALL_KW (GH-109300) | Brandt Bucher | 2023-09-13 | 1 | -72/+118 |
| | |||||
* | gh-109216: Fix possible memory leak in `BUILD_MAP` (#109257) | Nikita Sobolev | 2023-09-12 | 1 | -3/+0 |
| | |||||
* | gh-109214: Rename SAVE_IP to _SET_IP, and similar (#109285) | Guido van Rossum | 2023-09-11 | 1 | -17/+17 |
| | | | | | | | | * Rename SAVE_IP to _SET_IP * Rename EXIT_TRACE to _EXIT_TRACE * Rename SAVE_CURRENT_IP to _SAVE_CURRENT_IP * Rename INSERT to _INSERT (This is for Ken Jin's abstract interpreter) * Rename IS_NONE to _IS_NONE * Rename JUMP_TO_TOP to _JUMP_TO_TOP | ||||
* | gh-109039: Branch prediction for Tier 2 interpreter (#109038) | Guido van Rossum | 2023-09-11 | 1 | -13/+37 |
| | | | | | | | | | | | This adds a 16-bit inline cache entry to the conditional branch instructions POP_JUMP_IF_{FALSE,TRUE,NONE,NOT_NONE} and their instrumented variants, which is used to keep track of the branch direction. Each time we encounter these instructions we shift the cache entry left by one and set the bottom bit to whether we jumped. Then when it's time to translate such a branch to Tier 2 uops, we use the bit count from the cache entry to decided whether to continue translating the "didn't jump" branch or the "jumped" branch. The counter is initialized to a pattern of alternating ones and zeros to avoid bias. The .pyc file magic number is updated. There's a new test, some fixes for existing tests, and a few miscellaneous cleanups. | ||||
* | gh-109118: Fix runtime crash when NameError happens in PEP 695 function ↵ | Jelle Zijlstra | 2023-09-09 | 1 | -9/+35 |
| | | | | (#109123) | ||||
* | GH-108614: Unbreak emscripten build (GH-109132) | Mark Shannon | 2023-09-08 | 1 | -2/+2 |
| | |||||
* | GH-108614: Add `RESUME_CHECK` instruction (GH-108630) | Mark Shannon | 2023-09-07 | 1 | -8/+21 |
| | |||||
* | GH-108614: Remove `TIER_ONE` and `TIER_TWO` from `_PUSH_FRAME` (GH-108725) | Mark Shannon | 2023-09-04 | 1 | -9/+11 |
| | |||||
* | GH-108614: Remove non-debug uses of `#if TIER_ONE` and `#if TIER_TWO` from ↵ | Mark Shannon | 2023-08-31 | 1 | -11/+12 |
| | | | | `_POP_FRAME` op. (GH-108685) | ||||
* | gh-108487: Move assert(self != NULL) down beyond DEOPT_IF() (#108510) | Guido van Rossum | 2023-08-28 | 1 | -1/+1 |
| | |||||
* | GH-106581: Fix instrumentation in tier 2 (GH-108493) | Brandt Bucher | 2023-08-25 | 1 | -4/+6 |
| | |||||
* | gh-106581: Split CALL_BOUND_METHOD_EXACT_ARGS into uops (#108462) | Guido van Rossum | 2023-08-25 | 1 | -9/+20 |
| | | | Instead of using `GO_TO_INSTRUCTION(CALL_PY_EXACT_ARGS)` we just add the macro elements of the latter to the macro for the former. This requires lengthening the uops array in struct opcode_macro_expansion. (It also required changes to stacking.py that were merged already.) | ||||
* | gh-106581: Project through calls (#108067) | Guido van Rossum | 2023-08-17 | 1 | -23/+33 |
| | | | | This finishes the work begun in gh-107760. When, while projecting a superblock, we encounter a call to a short, simple function, the superblock will now enter the function using `_PUSH_FRAME`, continue through it, and leave it using `_POP_FRAME`, and then continue through the original code. Multiple frame pushes and pops are even possible. It is also possible to stop appending to the superblock in the middle of a called function, when running out of space or encountering an unsupported bytecode. | ||||
* | GH-108035: Remove the `_PyCFrame` struct as it is no longer needed for ↵ | Mark Shannon | 2023-08-17 | 1 | -19/+15 |
| | | | | performance. (GH-108036) | ||||
* | gh-106581: Split `CALL_PY_EXACT_ARGS` into uops (#107760) | Guido van Rossum | 2023-08-16 | 1 | -16/+66 |
| | | | | | | | | | | | | * Split `CALL_PY_EXACT_ARGS` into uops This is only the first step for doing `CALL` in Tier 2. The next step involves tracing into the called code object and back. After that we'll have to do the remaining `CALL` specialization. Finally we'll have to deal with `KW_NAMES`. Note: this moves setting `frame->return_offset` directly in front of `DISPATCH_INLINED()`, to make it easier to move it into `_PUSH_FRAME`. | ||||
* | gh-105481: generate op IDs from bytecode.c instead of hard coding them in ↵ | Irit Katriel | 2023-08-16 | 1 | -1/+0 |
| | | | | opcode.py (#107971) | ||||
* | gh-107557: Setup abstract interpretation (#107847) | Ken Jin | 2023-08-15 | 1 | -0/+5 |
| | | | | Co-authored-by: Guido van Rossum <gvanrossum@users.noreply.github.com> Co-authored-by: Jules <57632293+juliapoo@users.noreply.github.com> | ||||
* | GH-106485: Dematerialize instance dictionaries when possible (GH-106539) | Brandt Bucher | 2023-08-09 | 1 | -6/+12 |
| | |||||
* | GH-105848: Simplify the arrangement of CALL's stack (GH-107788) | Brandt Bucher | 2023-08-09 | 1 | -203/+169 |
| | |||||
* | GH-107596: Specialize str[int] (GH-107597) | Brandt Bucher | 2023-08-08 | 1 | -0/+16 |
| | |||||
* | GH-107263: Increase C stack limit for most functions, except ↵ | Mark Shannon | 2023-08-04 | 1 | -1/+1 |
| | | | | | | `_PyEval_EvalFrameDefault()` (GH-107535) * Set C recursion limit to 1500, set cost of eval loop to 2 frames, and compiler mutliply to 2. | ||||
* | Use tstate->interp to get the interpreter state in bytecodes.c (GH-107506) | Brandt Bucher | 2023-07-31 | 1 | -3/+3 |
| |