aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/tools/python3/src/Lib/opcode.py
diff options
context:
space:
mode:
authorshadchin <shadchin@yandex-team.com>2024-02-12 07:53:52 +0300
committershadchin <shadchin@yandex-team.com>2024-02-12 08:07:36 +0300
commitce1b7ca3171f9158180640c6a02a74b4afffedea (patch)
treee47c1e8391b1b0128262c1e9b1e6ed4c8fff2348 /contrib/tools/python3/src/Lib/opcode.py
parent57350d96f030db90f220ce50ee591d5c5d403df7 (diff)
downloadydb-ce1b7ca3171f9158180640c6a02a74b4afffedea.tar.gz
Update Python from 3.11.8 to 3.12.2
Diffstat (limited to 'contrib/tools/python3/src/Lib/opcode.py')
-rw-r--r--contrib/tools/python3/src/Lib/opcode.py294
1 files changed, 190 insertions, 104 deletions
diff --git a/contrib/tools/python3/src/Lib/opcode.py b/contrib/tools/python3/src/Lib/opcode.py
index bc3c02af2b..6bb2f1c140 100644
--- a/contrib/tools/python3/src/Lib/opcode.py
+++ b/contrib/tools/python3/src/Lib/opcode.py
@@ -4,9 +4,9 @@ opcode module - potentially shared between dis and other modules which
operate on bytecodes (e.g. peephole optimizers).
"""
-__all__ = ["cmp_op", "hasconst", "hasname", "hasjrel", "hasjabs",
- "haslocal", "hascompare", "hasfree", "opname", "opmap",
- "HAVE_ARGUMENT", "EXTENDED_ARG", "hasnargs"]
+__all__ = ["cmp_op", "hasarg", "hasconst", "hasname", "hasjrel", "hasjabs",
+ "haslocal", "hascompare", "hasfree", "hasexc", "opname", "opmap",
+ "HAVE_ARGUMENT", "EXTENDED_ARG"]
# It's a chicken-and-egg I'm afraid:
# We're imported before _opcode's made.
@@ -23,6 +23,7 @@ except ImportError:
cmp_op = ('<', '<=', '==', '!=', '>', '>=')
+hasarg = []
hasconst = []
hasname = []
hasjrel = []
@@ -30,13 +31,24 @@ hasjabs = []
haslocal = []
hascompare = []
hasfree = []
-hasnargs = [] # unused
+hasexc = []
+
+
+ENABLE_SPECIALIZATION = True
+
+def is_pseudo(op):
+ return op >= MIN_PSEUDO_OPCODE and op <= MAX_PSEUDO_OPCODE
+
+oplists = [hasarg, hasconst, hasname, hasjrel, hasjabs,
+ haslocal, hascompare, hasfree, hasexc]
opmap = {}
-opname = ['<%r>' % (op,) for op in range(256)]
+
+## pseudo opcodes (used in the compiler) mapped to the values
+## they can become in the actual code.
+_pseudo_ops = {}
def def_op(name, op):
- opname[op] = name
opmap[name] = op
def name_op(name, op):
@@ -51,21 +63,42 @@ def jabs_op(name, op):
def_op(name, op)
hasjabs.append(op)
+def pseudo_op(name, op, real_ops):
+ def_op(name, op)
+ _pseudo_ops[name] = real_ops
+ # add the pseudo opcode to the lists its targets are in
+ for oplist in oplists:
+ res = [opmap[rop] in oplist for rop in real_ops]
+ if any(res):
+ assert all(res)
+ oplist.append(op)
+
+
# Instruction opcodes for compiled code
# Blank lines correspond to available opcodes
def_op('CACHE', 0)
def_op('POP_TOP', 1)
def_op('PUSH_NULL', 2)
+def_op('INTERPRETER_EXIT', 3)
+
+def_op('END_FOR', 4)
+def_op('END_SEND', 5)
def_op('NOP', 9)
-def_op('UNARY_POSITIVE', 10)
+
def_op('UNARY_NEGATIVE', 11)
def_op('UNARY_NOT', 12)
def_op('UNARY_INVERT', 15)
+# We reserve 17 as it is the initial value for the specializing counter
+# This helps us catch cases where we attempt to execute a cache.
+def_op('RESERVED', 17)
+
def_op('BINARY_SUBSCR', 25)
+def_op('BINARY_SLICE', 26)
+def_op('STORE_SLICE', 27)
def_op('GET_LEN', 30)
def_op('MATCH_MAPPING', 31)
@@ -82,28 +115,27 @@ def_op('GET_ANEXT', 51)
def_op('BEFORE_ASYNC_WITH', 52)
def_op('BEFORE_WITH', 53)
def_op('END_ASYNC_FOR', 54)
+def_op('CLEANUP_THROW', 55)
def_op('STORE_SUBSCR', 60)
def_op('DELETE_SUBSCR', 61)
def_op('GET_ITER', 68)
def_op('GET_YIELD_FROM_ITER', 69)
-def_op('PRINT_EXPR', 70)
+
def_op('LOAD_BUILD_CLASS', 71)
def_op('LOAD_ASSERTION_ERROR', 74)
def_op('RETURN_GENERATOR', 75)
-def_op('LIST_TO_TUPLE', 82)
def_op('RETURN_VALUE', 83)
-def_op('IMPORT_STAR', 84)
+
def_op('SETUP_ANNOTATIONS', 85)
-def_op('YIELD_VALUE', 86)
-def_op('ASYNC_GEN_WRAP', 87)
-def_op('PREP_RERAISE_STAR', 88)
+def_op('LOAD_LOCALS', 87)
+
def_op('POP_EXCEPT', 89)
-HAVE_ARGUMENT = 90 # Opcodes from here have an argument:
+HAVE_ARGUMENT = 90 # real opcodes from here have an argument:
name_op('STORE_NAME', 90) # Index in name list
name_op('DELETE_NAME', 91) # ""
@@ -128,25 +160,27 @@ hascompare.append(107)
name_op('IMPORT_NAME', 108) # Index in name list
name_op('IMPORT_FROM', 109) # Index in name list
jrel_op('JUMP_FORWARD', 110) # Number of words to skip
-jrel_op('JUMP_IF_FALSE_OR_POP', 111) # Number of words to skip
-jrel_op('JUMP_IF_TRUE_OR_POP', 112) # ""
-jrel_op('POP_JUMP_FORWARD_IF_FALSE', 114)
-jrel_op('POP_JUMP_FORWARD_IF_TRUE', 115)
+jrel_op('POP_JUMP_IF_FALSE', 114)
+jrel_op('POP_JUMP_IF_TRUE', 115)
name_op('LOAD_GLOBAL', 116) # Index in name list
def_op('IS_OP', 117)
def_op('CONTAINS_OP', 118)
def_op('RERAISE', 119)
def_op('COPY', 120)
+def_op('RETURN_CONST', 121)
+hasconst.append(121)
def_op('BINARY_OP', 122)
-jrel_op('SEND', 123) # Number of bytes to skip
-def_op('LOAD_FAST', 124) # Local variable number
+jrel_op('SEND', 123) # Number of words to skip
+def_op('LOAD_FAST', 124) # Local variable number, no null check
haslocal.append(124)
def_op('STORE_FAST', 125) # Local variable number
haslocal.append(125)
def_op('DELETE_FAST', 126) # Local variable number
haslocal.append(126)
-jrel_op('POP_JUMP_FORWARD_IF_NOT_NONE', 128)
-jrel_op('POP_JUMP_FORWARD_IF_NONE', 129)
+def_op('LOAD_FAST_CHECK', 127) # Local variable number
+haslocal.append(127)
+jrel_op('POP_JUMP_IF_NOT_NONE', 128)
+jrel_op('POP_JUMP_IF_NONE', 129)
def_op('RAISE_VARARGS', 130) # Number of raise arguments (1, 2, or 3)
def_op('GET_AWAITABLE', 131)
def_op('MAKE_FUNCTION', 132) # Flags
@@ -163,18 +197,19 @@ hasfree.append(138)
def_op('DELETE_DEREF', 139)
hasfree.append(139)
jrel_op('JUMP_BACKWARD', 140) # Number of words to skip (backwards)
-
+name_op('LOAD_SUPER_ATTR', 141)
def_op('CALL_FUNCTION_EX', 142) # Flags
+def_op('LOAD_FAST_AND_CLEAR', 143) # Local variable number
+haslocal.append(143)
def_op('EXTENDED_ARG', 144)
EXTENDED_ARG = 144
def_op('LIST_APPEND', 145)
def_op('SET_ADD', 146)
def_op('MAP_ADD', 147)
-def_op('LOAD_CLASSDEREF', 148)
hasfree.append(148)
def_op('COPY_FREE_VARS', 149)
-
+def_op('YIELD_VALUE', 150)
def_op('RESUME', 151) # This must be kept in sync with deepfreeze.py
def_op('MATCH_CLASS', 152)
@@ -182,25 +217,74 @@ def_op('FORMAT_VALUE', 155)
def_op('BUILD_CONST_KEY_MAP', 156)
def_op('BUILD_STRING', 157)
-name_op('LOAD_METHOD', 160)
-
def_op('LIST_EXTEND', 162)
def_op('SET_UPDATE', 163)
def_op('DICT_MERGE', 164)
def_op('DICT_UPDATE', 165)
-def_op('PRECALL', 166)
def_op('CALL', 171)
def_op('KW_NAMES', 172)
hasconst.append(172)
+def_op('CALL_INTRINSIC_1', 173)
+def_op('CALL_INTRINSIC_2', 174)
+
+name_op('LOAD_FROM_DICT_OR_GLOBALS', 175)
+def_op('LOAD_FROM_DICT_OR_DEREF', 176)
+hasfree.append(176)
+
+# Instrumented instructions
+MIN_INSTRUMENTED_OPCODE = 237
+
+def_op('INSTRUMENTED_LOAD_SUPER_ATTR', 237)
+def_op('INSTRUMENTED_POP_JUMP_IF_NONE', 238)
+def_op('INSTRUMENTED_POP_JUMP_IF_NOT_NONE', 239)
+def_op('INSTRUMENTED_RESUME', 240)
+def_op('INSTRUMENTED_CALL', 241)
+def_op('INSTRUMENTED_RETURN_VALUE', 242)
+def_op('INSTRUMENTED_YIELD_VALUE', 243)
+def_op('INSTRUMENTED_CALL_FUNCTION_EX', 244)
+def_op('INSTRUMENTED_JUMP_FORWARD', 245)
+def_op('INSTRUMENTED_JUMP_BACKWARD', 246)
+def_op('INSTRUMENTED_RETURN_CONST', 247)
+def_op('INSTRUMENTED_FOR_ITER', 248)
+def_op('INSTRUMENTED_POP_JUMP_IF_FALSE', 249)
+def_op('INSTRUMENTED_POP_JUMP_IF_TRUE', 250)
+def_op('INSTRUMENTED_END_FOR', 251)
+def_op('INSTRUMENTED_END_SEND', 252)
+def_op('INSTRUMENTED_INSTRUCTION', 253)
+def_op('INSTRUMENTED_LINE', 254)
+# 255 is reserved
+
+hasarg.extend([op for op in opmap.values() if op >= HAVE_ARGUMENT])
+
+MIN_PSEUDO_OPCODE = 256
+
+pseudo_op('SETUP_FINALLY', 256, ['NOP'])
+hasexc.append(256)
+pseudo_op('SETUP_CLEANUP', 257, ['NOP'])
+hasexc.append(257)
+pseudo_op('SETUP_WITH', 258, ['NOP'])
+hasexc.append(258)
+pseudo_op('POP_BLOCK', 259, ['NOP'])
+
+pseudo_op('JUMP', 260, ['JUMP_FORWARD', 'JUMP_BACKWARD'])
+pseudo_op('JUMP_NO_INTERRUPT', 261, ['JUMP_FORWARD', 'JUMP_BACKWARD_NO_INTERRUPT'])
+
+pseudo_op('LOAD_METHOD', 262, ['LOAD_ATTR'])
+pseudo_op('LOAD_SUPER_METHOD', 263, ['LOAD_SUPER_ATTR'])
+pseudo_op('LOAD_ZERO_SUPER_METHOD', 264, ['LOAD_SUPER_ATTR'])
+pseudo_op('LOAD_ZERO_SUPER_ATTR', 265, ['LOAD_SUPER_ATTR'])
+
+pseudo_op('STORE_FAST_MAYBE_NULL', 266, ['STORE_FAST'])
+
+MAX_PSEUDO_OPCODE = MIN_PSEUDO_OPCODE + len(_pseudo_ops) - 1
+
+del def_op, name_op, jrel_op, jabs_op, pseudo_op
+
+opname = ['<%r>' % (op,) for op in range(MAX_PSEUDO_OPCODE + 1)]
+for op, i in opmap.items():
+ opname[i] = op
-jrel_op('POP_JUMP_BACKWARD_IF_NOT_NONE', 173)
-jrel_op('POP_JUMP_BACKWARD_IF_NONE', 174)
-jrel_op('POP_JUMP_BACKWARD_IF_FALSE', 175)
-jrel_op('POP_JUMP_BACKWARD_IF_TRUE', 176)
-
-
-del def_op, name_op, jrel_op, jabs_op
_nb_ops = [
("NB_ADD", "+"),
@@ -231,9 +315,31 @@ _nb_ops = [
("NB_INPLACE_XOR", "^="),
]
+_intrinsic_1_descs = [
+ "INTRINSIC_1_INVALID",
+ "INTRINSIC_PRINT",
+ "INTRINSIC_IMPORT_STAR",
+ "INTRINSIC_STOPITERATION_ERROR",
+ "INTRINSIC_ASYNC_GEN_WRAP",
+ "INTRINSIC_UNARY_POSITIVE",
+ "INTRINSIC_LIST_TO_TUPLE",
+ "INTRINSIC_TYPEVAR",
+ "INTRINSIC_PARAMSPEC",
+ "INTRINSIC_TYPEVARTUPLE",
+ "INTRINSIC_SUBSCRIPT_GENERIC",
+ "INTRINSIC_TYPEALIAS",
+]
+
+_intrinsic_2_descs = [
+ "INTRINSIC_2_INVALID",
+ "INTRINSIC_PREP_RERAISE_STAR",
+ "INTRINSIC_TYPEVAR_WITH_BOUND",
+ "INTRINSIC_TYPEVAR_WITH_CONSTRAINTS",
+ "INTRINSIC_SET_FUNCTION_TYPE_PARAMS",
+]
+
_specializations = {
"BINARY_OP": [
- "BINARY_OP_ADAPTIVE",
"BINARY_OP_ADD_FLOAT",
"BINARY_OP_ADD_INT",
"BINARY_OP_ADD_UNICODE",
@@ -244,35 +350,58 @@ _specializations = {
"BINARY_OP_SUBTRACT_INT",
],
"BINARY_SUBSCR": [
- "BINARY_SUBSCR_ADAPTIVE",
"BINARY_SUBSCR_DICT",
"BINARY_SUBSCR_GETITEM",
"BINARY_SUBSCR_LIST_INT",
"BINARY_SUBSCR_TUPLE_INT",
],
"CALL": [
- "CALL_ADAPTIVE",
"CALL_PY_EXACT_ARGS",
"CALL_PY_WITH_DEFAULTS",
+ "CALL_BOUND_METHOD_EXACT_ARGS",
+ "CALL_BUILTIN_CLASS",
+ "CALL_BUILTIN_FAST_WITH_KEYWORDS",
+ "CALL_METHOD_DESCRIPTOR_FAST_WITH_KEYWORDS",
+ "CALL_NO_KW_BUILTIN_FAST",
+ "CALL_NO_KW_BUILTIN_O",
+ "CALL_NO_KW_ISINSTANCE",
+ "CALL_NO_KW_LEN",
+ "CALL_NO_KW_LIST_APPEND",
+ "CALL_NO_KW_METHOD_DESCRIPTOR_FAST",
+ "CALL_NO_KW_METHOD_DESCRIPTOR_NOARGS",
+ "CALL_NO_KW_METHOD_DESCRIPTOR_O",
+ "CALL_NO_KW_STR_1",
+ "CALL_NO_KW_TUPLE_1",
+ "CALL_NO_KW_TYPE_1",
],
"COMPARE_OP": [
- "COMPARE_OP_ADAPTIVE",
- "COMPARE_OP_FLOAT_JUMP",
- "COMPARE_OP_INT_JUMP",
- "COMPARE_OP_STR_JUMP",
+ "COMPARE_OP_FLOAT",
+ "COMPARE_OP_INT",
+ "COMPARE_OP_STR",
],
- "EXTENDED_ARG": [
- "EXTENDED_ARG_QUICK",
+ "FOR_ITER": [
+ "FOR_ITER_LIST",
+ "FOR_ITER_TUPLE",
+ "FOR_ITER_RANGE",
+ "FOR_ITER_GEN",
],
- "JUMP_BACKWARD": [
- "JUMP_BACKWARD_QUICK",
+ "LOAD_SUPER_ATTR": [
+ "LOAD_SUPER_ATTR_ATTR",
+ "LOAD_SUPER_ATTR_METHOD",
],
"LOAD_ATTR": [
- "LOAD_ATTR_ADAPTIVE",
+ # These potentially push [NULL, bound method] onto the stack.
+ "LOAD_ATTR_CLASS",
+ "LOAD_ATTR_GETATTRIBUTE_OVERRIDDEN",
"LOAD_ATTR_INSTANCE_VALUE",
"LOAD_ATTR_MODULE",
+ "LOAD_ATTR_PROPERTY",
"LOAD_ATTR_SLOT",
"LOAD_ATTR_WITH_HINT",
+ # These will always push [unbound method, self] onto the stack.
+ "LOAD_ATTR_METHOD_LAZY_DICT",
+ "LOAD_ATTR_METHOD_NO_DICT",
+ "LOAD_ATTR_METHOD_WITH_VALUES",
],
"LOAD_CONST": [
"LOAD_CONST__LOAD_FAST",
@@ -282,42 +411,10 @@ _specializations = {
"LOAD_FAST__LOAD_FAST",
],
"LOAD_GLOBAL": [
- "LOAD_GLOBAL_ADAPTIVE",
"LOAD_GLOBAL_BUILTIN",
"LOAD_GLOBAL_MODULE",
],
- "LOAD_METHOD": [
- "LOAD_METHOD_ADAPTIVE",
- "LOAD_METHOD_CLASS",
- "LOAD_METHOD_MODULE",
- "LOAD_METHOD_NO_DICT",
- "LOAD_METHOD_WITH_DICT",
- "LOAD_METHOD_WITH_VALUES",
- ],
- "PRECALL": [
- "PRECALL_ADAPTIVE",
- "PRECALL_BOUND_METHOD",
- "PRECALL_BUILTIN_CLASS",
- "PRECALL_BUILTIN_FAST_WITH_KEYWORDS",
- "PRECALL_METHOD_DESCRIPTOR_FAST_WITH_KEYWORDS",
- "PRECALL_NO_KW_BUILTIN_FAST",
- "PRECALL_NO_KW_BUILTIN_O",
- "PRECALL_NO_KW_ISINSTANCE",
- "PRECALL_NO_KW_LEN",
- "PRECALL_NO_KW_LIST_APPEND",
- "PRECALL_NO_KW_METHOD_DESCRIPTOR_FAST",
- "PRECALL_NO_KW_METHOD_DESCRIPTOR_NOARGS",
- "PRECALL_NO_KW_METHOD_DESCRIPTOR_O",
- "PRECALL_NO_KW_STR_1",
- "PRECALL_NO_KW_TUPLE_1",
- "PRECALL_NO_KW_TYPE_1",
- "PRECALL_PYFUNC",
- ],
- "RESUME": [
- "RESUME_QUICK",
- ],
"STORE_ATTR": [
- "STORE_ATTR_ADAPTIVE",
"STORE_ATTR_INSTANCE_VALUE",
"STORE_ATTR_SLOT",
"STORE_ATTR_WITH_HINT",
@@ -327,34 +424,27 @@ _specializations = {
"STORE_FAST__STORE_FAST",
],
"STORE_SUBSCR": [
- "STORE_SUBSCR_ADAPTIVE",
"STORE_SUBSCR_DICT",
"STORE_SUBSCR_LIST_INT",
],
"UNPACK_SEQUENCE": [
- "UNPACK_SEQUENCE_ADAPTIVE",
"UNPACK_SEQUENCE_LIST",
"UNPACK_SEQUENCE_TUPLE",
"UNPACK_SEQUENCE_TWO_TUPLE",
],
+ "SEND": [
+ "SEND_GEN",
+ ],
}
_specialized_instructions = [
opcode for family in _specializations.values() for opcode in family
]
-_specialization_stats = [
- "success",
- "failure",
- "hit",
- "deferred",
- "miss",
- "deopt",
-]
_cache_format = {
"LOAD_GLOBAL": {
"counter": 1,
"index": 1,
- "module_keys_version": 2,
+ "module_keys_version": 1,
"builtin_keys_version": 1,
},
"BINARY_OP": {
@@ -365,39 +455,35 @@ _cache_format = {
},
"COMPARE_OP": {
"counter": 1,
- "mask": 1,
},
"BINARY_SUBSCR": {
"counter": 1,
- "type_version": 2,
- "func_version": 1,
+ },
+ "FOR_ITER": {
+ "counter": 1,
+ },
+ "LOAD_SUPER_ATTR": {
+ "counter": 1,
},
"LOAD_ATTR": {
"counter": 1,
"version": 2,
- "index": 1,
+ "keys_version": 2,
+ "descr": 4,
},
"STORE_ATTR": {
"counter": 1,
"version": 2,
"index": 1,
},
- "LOAD_METHOD": {
- "counter": 1,
- "type_version": 2,
- "dict_offset": 1,
- "keys_version": 2,
- "descr": 4,
- },
"CALL": {
"counter": 1,
"func_version": 2,
- "min_args": 1,
},
- "PRECALL": {
+ "STORE_SUBSCR": {
"counter": 1,
},
- "STORE_SUBSCR": {
+ "SEND": {
"counter": 1,
},
}