summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--py/bc0.h152
-rw-r--r--py/emitbc.c30
-rw-r--r--py/showbc.c53
-rw-r--r--py/vm.c85
-rw-r--r--py/vmentrytable.h13
5 files changed, 159 insertions, 174 deletions
diff --git a/py/bc0.h b/py/bc0.h
index b8e07cbc50..0b10917595 100644
--- a/py/bc0.h
+++ b/py/bc0.h
@@ -31,92 +31,90 @@
#define MP_BC_LOAD_CONST_NONE (0x11)
#define MP_BC_LOAD_CONST_TRUE (0x12)
#define MP_BC_LOAD_CONST_ELLIPSIS (0x13)
-#define MP_BC_LOAD_CONST_SMALL_INT (0x14) // 24-bit, in excess
+#define MP_BC_LOAD_CONST_SMALL_INT (0x14) // signed var-int
#define MP_BC_LOAD_CONST_INT (0x15) // qstr
#define MP_BC_LOAD_CONST_DEC (0x16) // qstr
-#define MP_BC_LOAD_CONST_BYTES (0x18) // qstr
-#define MP_BC_LOAD_CONST_STRING (0x19) // qstr
-#define MP_BC_LOAD_NULL (0x1a)
+#define MP_BC_LOAD_CONST_BYTES (0x17) // qstr
+#define MP_BC_LOAD_CONST_STRING (0x18) // qstr
+#define MP_BC_LOAD_NULL (0x19)
-#define MP_BC_LOAD_FAST_0 (0x20)
-#define MP_BC_LOAD_FAST_1 (0x21)
-#define MP_BC_LOAD_FAST_2 (0x22)
-#define MP_BC_LOAD_FAST_N (0x23) // uint
-#define MP_BC_LOAD_DEREF (0x25) // uint
-#define MP_BC_LOAD_NAME (0x26) // qstr
-#define MP_BC_LOAD_GLOBAL (0x27) // qstr
-#define MP_BC_LOAD_ATTR (0x28) // qstr
-#define MP_BC_LOAD_METHOD (0x29) // qstr
-#define MP_BC_LOAD_BUILD_CLASS (0x2a)
-#define MP_BC_LOAD_SUBSCR (0x2b)
+#define MP_BC_LOAD_FAST_N (0x1a) // uint
+#define MP_BC_LOAD_DEREF (0x1b) // uint
+#define MP_BC_LOAD_NAME (0x1c) // qstr
+#define MP_BC_LOAD_GLOBAL (0x1d) // qstr
+#define MP_BC_LOAD_ATTR (0x1e) // qstr
+#define MP_BC_LOAD_METHOD (0x1f) // qstr
+#define MP_BC_LOAD_BUILD_CLASS (0x20)
+#define MP_BC_LOAD_SUBSCR (0x21)
-#define MP_BC_STORE_FAST_0 (0x30)
-#define MP_BC_STORE_FAST_1 (0x31)
-#define MP_BC_STORE_FAST_2 (0x32)
-#define MP_BC_STORE_FAST_N (0x33) // uint
-#define MP_BC_STORE_DEREF (0x34) // uint
-#define MP_BC_STORE_NAME (0x35) // qstr
-#define MP_BC_STORE_GLOBAL (0x36) // qstr
-#define MP_BC_STORE_ATTR (0x37) // qstr
-#define MP_BC_STORE_SUBSCR (0x38)
+#define MP_BC_STORE_FAST_N (0x22) // uint
+#define MP_BC_STORE_DEREF (0x23) // uint
+#define MP_BC_STORE_NAME (0x24) // qstr
+#define MP_BC_STORE_GLOBAL (0x25) // qstr
+#define MP_BC_STORE_ATTR (0x26) // qstr
+#define MP_BC_STORE_SUBSCR (0x27)
-#define MP_BC_DELETE_FAST (0x39) // uint
-#define MP_BC_DELETE_DEREF (0x3a) // uint
-#define MP_BC_DELETE_NAME (0x3b) // qstr
-#define MP_BC_DELETE_GLOBAL (0x3c) // qstr
+#define MP_BC_DELETE_FAST (0x28) // uint
+#define MP_BC_DELETE_DEREF (0x29) // uint
+#define MP_BC_DELETE_NAME (0x2a) // qstr
+#define MP_BC_DELETE_GLOBAL (0x2b) // qstr
-#define MP_BC_DUP_TOP (0x40)
-#define MP_BC_DUP_TOP_TWO (0x41)
-#define MP_BC_POP_TOP (0x42)
-#define MP_BC_ROT_TWO (0x43)
-#define MP_BC_ROT_THREE (0x44)
+#define MP_BC_DUP_TOP (0x30)
+#define MP_BC_DUP_TOP_TWO (0x31)
+#define MP_BC_POP_TOP (0x32)
+#define MP_BC_ROT_TWO (0x33)
+#define MP_BC_ROT_THREE (0x34)
-#define MP_BC_JUMP (0x45) // rel byte code offset, 16-bit signed, in excess
-#define MP_BC_POP_JUMP_IF_TRUE (0x46) // rel byte code offset, 16-bit signed, in excess
-#define MP_BC_POP_JUMP_IF_FALSE (0x47) // rel byte code offset, 16-bit signed, in excess
-#define MP_BC_JUMP_IF_TRUE_OR_POP (0x48) // rel byte code offset, 16-bit signed, in excess
-#define MP_BC_JUMP_IF_FALSE_OR_POP (0x49) // rel byte code offset, 16-bit signed, in excess
-#define MP_BC_SETUP_WITH (0x4d) // rel byte code offset, 16-bit unsigned
-#define MP_BC_WITH_CLEANUP (0x4e)
-#define MP_BC_SETUP_EXCEPT (0x4f) // rel byte code offset, 16-bit unsigned
-#define MP_BC_SETUP_FINALLY (0x50) // rel byte code offset, 16-bit unsigned
-#define MP_BC_END_FINALLY (0x51)
-#define MP_BC_GET_ITER (0x52)
-#define MP_BC_FOR_ITER (0x53) // rel byte code offset, 16-bit unsigned
-#define MP_BC_POP_BLOCK (0x54)
-#define MP_BC_POP_EXCEPT (0x55)
-#define MP_BC_UNWIND_JUMP (0x56) // rel byte code offset, 16-bit signed, in excess; then a byte
+#define MP_BC_JUMP (0x35) // rel byte code offset, 16-bit signed, in excess
+#define MP_BC_POP_JUMP_IF_TRUE (0x36) // rel byte code offset, 16-bit signed, in excess
+#define MP_BC_POP_JUMP_IF_FALSE (0x37) // rel byte code offset, 16-bit signed, in excess
+#define MP_BC_JUMP_IF_TRUE_OR_POP (0x38) // rel byte code offset, 16-bit signed, in excess
+#define MP_BC_JUMP_IF_FALSE_OR_POP (0x39) // rel byte code offset, 16-bit signed, in excess
+#define MP_BC_SETUP_WITH (0x3d) // rel byte code offset, 16-bit unsigned
+#define MP_BC_WITH_CLEANUP (0x3e)
+#define MP_BC_SETUP_EXCEPT (0x3f) // rel byte code offset, 16-bit unsigned
+#define MP_BC_SETUP_FINALLY (0x40) // rel byte code offset, 16-bit unsigned
+#define MP_BC_END_FINALLY (0x41)
+#define MP_BC_GET_ITER (0x42)
+#define MP_BC_FOR_ITER (0x43) // rel byte code offset, 16-bit unsigned
+#define MP_BC_POP_BLOCK (0x44)
+#define MP_BC_POP_EXCEPT (0x45)
+#define MP_BC_UNWIND_JUMP (0x46) // rel byte code offset, 16-bit signed, in excess; then a byte
-#define MP_BC_NOT (0x60)
-#define MP_BC_UNARY_OP (0x61) // byte
-#define MP_BC_BINARY_OP (0x62) // byte
+#define MP_BC_NOT (0x47)
-#define MP_BC_BUILD_TUPLE (0x70) // uint
-#define MP_BC_BUILD_LIST (0x71) // uint
-#define MP_BC_LIST_APPEND (0x72) // uint
-#define MP_BC_BUILD_MAP (0x73) // uint
-#define MP_BC_STORE_MAP (0x74)
-#define MP_BC_MAP_ADD (0x75) // uint
-#define MP_BC_BUILD_SET (0x76) // uint
-#define MP_BC_SET_ADD (0x77) // uint
-#define MP_BC_BUILD_SLICE (0x78) // uint
-#define MP_BC_UNPACK_SEQUENCE (0x79) // uint
-#define MP_BC_UNPACK_EX (0x7a) // uint
+#define MP_BC_BUILD_TUPLE (0x50) // uint
+#define MP_BC_BUILD_LIST (0x51) // uint
+#define MP_BC_LIST_APPEND (0x52) // uint
+#define MP_BC_BUILD_MAP (0x53) // uint
+#define MP_BC_STORE_MAP (0x54)
+#define MP_BC_MAP_ADD (0x55) // uint
+#define MP_BC_BUILD_SET (0x56) // uint
+#define MP_BC_SET_ADD (0x57) // uint
+#define MP_BC_BUILD_SLICE (0x58) // uint
+#define MP_BC_UNPACK_SEQUENCE (0x59) // uint
+#define MP_BC_UNPACK_EX (0x5a) // uint
-#define MP_BC_RETURN_VALUE (0x80)
-#define MP_BC_RAISE_VARARGS (0x81) // byte
-#define MP_BC_YIELD_VALUE (0x82)
-#define MP_BC_YIELD_FROM (0x83)
+#define MP_BC_RETURN_VALUE (0x5b)
+#define MP_BC_RAISE_VARARGS (0x5c) // byte
+#define MP_BC_YIELD_VALUE (0x5d)
+#define MP_BC_YIELD_FROM (0x5e)
-#define MP_BC_MAKE_FUNCTION (0x90) // uint
-#define MP_BC_MAKE_FUNCTION_DEFARGS (0x91) // uint
-#define MP_BC_MAKE_CLOSURE (0x92) // uint
-#define MP_BC_MAKE_CLOSURE_DEFARGS (0x93) // uint
-#define MP_BC_CALL_FUNCTION (0x94) // uint
-#define MP_BC_CALL_FUNCTION_VAR_KW (0x95) // uint
-#define MP_BC_CALL_METHOD (0x96) // uint
-#define MP_BC_CALL_METHOD_VAR_KW (0x97) // uint
+#define MP_BC_MAKE_FUNCTION (0x60) // uint
+#define MP_BC_MAKE_FUNCTION_DEFARGS (0x61) // uint
+#define MP_BC_MAKE_CLOSURE (0x62) // uint
+#define MP_BC_MAKE_CLOSURE_DEFARGS (0x63) // uint
+#define MP_BC_CALL_FUNCTION (0x64) // uint
+#define MP_BC_CALL_FUNCTION_VAR_KW (0x65) // uint
+#define MP_BC_CALL_METHOD (0x66) // uint
+#define MP_BC_CALL_METHOD_VAR_KW (0x67) // uint
-#define MP_BC_IMPORT_NAME (0xe0) // qstr
-#define MP_BC_IMPORT_FROM (0xe1) // qstr
-#define MP_BC_IMPORT_STAR (0xe2)
+#define MP_BC_IMPORT_NAME (0x68) // qstr
+#define MP_BC_IMPORT_FROM (0x69) // qstr
+#define MP_BC_IMPORT_STAR (0x6a)
+
+#define MP_BC_LOAD_CONST_SMALL_INT_MULTI (0x70) // + N(64)
+#define MP_BC_LOAD_FAST_MULTI (0xb0) // + N(16)
+#define MP_BC_STORE_FAST_MULTI (0xc0) // + N(16)
+#define MP_BC_UNARY_OP_MULTI (0xd0) // + op(5)
+#define MP_BC_BINARY_OP_MULTI (0xd5) // + op(35)
diff --git a/py/emitbc.c b/py/emitbc.c
index cee6d3396c..795c412830 100644
--- a/py/emitbc.c
+++ b/py/emitbc.c
@@ -469,7 +469,11 @@ STATIC void emit_bc_load_const_tok(emit_t *emit, mp_token_kind_t tok) {
STATIC void emit_bc_load_const_small_int(emit_t *emit, mp_int_t arg) {
emit_bc_pre(emit, 1);
- emit_write_bytecode_byte_int(emit, MP_BC_LOAD_CONST_SMALL_INT, arg);
+ if (-16 <= arg && arg <= 47) {
+ emit_write_bytecode_byte(emit, MP_BC_LOAD_CONST_SMALL_INT_MULTI + 16 + arg);
+ } else {
+ emit_write_bytecode_byte_int(emit, MP_BC_LOAD_CONST_SMALL_INT, arg);
+ }
}
STATIC void emit_bc_load_const_int(emit_t *emit, qstr qst) {
@@ -499,11 +503,10 @@ STATIC void emit_bc_load_null(emit_t *emit) {
STATIC void emit_bc_load_fast(emit_t *emit, qstr qst, mp_uint_t id_flags, mp_uint_t local_num) {
assert(local_num >= 0);
emit_bc_pre(emit, 1);
- switch (local_num) {
- case 0: emit_write_bytecode_byte(emit, MP_BC_LOAD_FAST_0); break;
- case 1: emit_write_bytecode_byte(emit, MP_BC_LOAD_FAST_1); break;
- case 2: emit_write_bytecode_byte(emit, MP_BC_LOAD_FAST_2); break;
- default: emit_write_bytecode_byte_uint(emit, MP_BC_LOAD_FAST_N, local_num); break;
+ if (local_num <= 15) {
+ emit_write_bytecode_byte(emit, MP_BC_LOAD_FAST_MULTI + local_num);
+ } else {
+ emit_write_bytecode_byte_uint(emit, MP_BC_LOAD_FAST_N, local_num);
}
}
@@ -545,11 +548,10 @@ STATIC void emit_bc_load_subscr(emit_t *emit) {
STATIC void emit_bc_store_fast(emit_t *emit, qstr qst, mp_uint_t local_num) {
assert(local_num >= 0);
emit_bc_pre(emit, -1);
- switch (local_num) {
- case 0: emit_write_bytecode_byte(emit, MP_BC_STORE_FAST_0); break;
- case 1: emit_write_bytecode_byte(emit, MP_BC_STORE_FAST_1); break;
- case 2: emit_write_bytecode_byte(emit, MP_BC_STORE_FAST_2); break;
- default: emit_write_bytecode_byte_uint(emit, MP_BC_STORE_FAST_N, local_num); break;
+ if (local_num <= 15) {
+ emit_write_bytecode_byte(emit, MP_BC_STORE_FAST_MULTI + local_num);
+ } else {
+ emit_write_bytecode_byte_uint(emit, MP_BC_STORE_FAST_N, local_num);
}
}
@@ -724,12 +726,12 @@ STATIC void emit_bc_pop_except(emit_t *emit) {
STATIC void emit_bc_unary_op(emit_t *emit, mp_unary_op_t op) {
if (op == MP_UNARY_OP_NOT) {
emit_bc_pre(emit, 0);
- emit_write_bytecode_byte_byte(emit, MP_BC_UNARY_OP, MP_UNARY_OP_BOOL);
+ emit_write_bytecode_byte(emit, MP_BC_UNARY_OP_MULTI + MP_UNARY_OP_BOOL);
emit_bc_pre(emit, 0);
emit_write_bytecode_byte(emit, MP_BC_NOT);
} else {
emit_bc_pre(emit, 0);
- emit_write_bytecode_byte_byte(emit, MP_BC_UNARY_OP, op);
+ emit_write_bytecode_byte(emit, MP_BC_UNARY_OP_MULTI + op);
}
}
@@ -743,7 +745,7 @@ STATIC void emit_bc_binary_op(emit_t *emit, mp_binary_op_t op) {
op = MP_BINARY_OP_IS;
}
emit_bc_pre(emit, -1);
- emit_write_bytecode_byte_byte(emit, MP_BC_BINARY_OP, op);
+ emit_write_bytecode_byte(emit, MP_BC_BINARY_OP_MULTI + op);
if (invert) {
emit_bc_pre(emit, 0);
emit_write_bytecode_byte(emit, MP_BC_NOT);
diff --git a/py/showbc.c b/py/showbc.c
index 13d257d304..93fe2c3787 100644
--- a/py/showbc.c
+++ b/py/showbc.c
@@ -190,18 +190,6 @@ void mp_bytecode_print2(const byte *ip, mp_uint_t len) {
printf("LOAD_NULL");
break;
- case MP_BC_LOAD_FAST_0:
- printf("LOAD_FAST_0");
- break;
-
- case MP_BC_LOAD_FAST_1:
- printf("LOAD_FAST_1");
- break;
-
- case MP_BC_LOAD_FAST_2:
- printf("LOAD_FAST_2");
- break;
-
case MP_BC_LOAD_FAST_N:
DECODE_UINT;
printf("LOAD_FAST_N " UINT_FMT, unum);
@@ -240,18 +228,6 @@ void mp_bytecode_print2(const byte *ip, mp_uint_t len) {
printf("LOAD_SUBSCR");
break;
- case MP_BC_STORE_FAST_0:
- printf("STORE_FAST_0");
- break;
-
- case MP_BC_STORE_FAST_1:
- printf("STORE_FAST_1");
- break;
-
- case MP_BC_STORE_FAST_2:
- printf("STORE_FAST_2");
- break;
-
case MP_BC_STORE_FAST_N:
DECODE_UINT;
printf("STORE_FAST_N " UINT_FMT, unum);
@@ -397,16 +373,6 @@ void mp_bytecode_print2(const byte *ip, mp_uint_t len) {
printf("NOT");
break;
- case MP_BC_UNARY_OP:
- unum = *ip++;
- printf("UNARY_OP " UINT_FMT, unum);
- break;
-
- case MP_BC_BINARY_OP:
- unum = *ip++;
- printf("BINARY_OP " UINT_FMT, unum);
- break;
-
case MP_BC_BUILD_TUPLE:
DECODE_UINT;
printf("BUILD_TUPLE " UINT_FMT, unum);
@@ -534,9 +500,22 @@ void mp_bytecode_print2(const byte *ip, mp_uint_t len) {
break;
default:
- printf("code %p, byte code 0x%02x not implemented\n", ip, ip[-1]);
- assert(0);
- return;
+ if (ip[-1] < MP_BC_LOAD_CONST_SMALL_INT_MULTI + 64) {
+ printf("LOAD_CONST_SMALL_INT " INT_FMT, (mp_int_t)ip[-1] - MP_BC_LOAD_CONST_SMALL_INT_MULTI - 16);
+ } else if (ip[-1] < MP_BC_LOAD_FAST_MULTI + 16) {
+ printf("LOAD_FAST " UINT_FMT, (mp_uint_t)ip[-1] - MP_BC_LOAD_FAST_MULTI);
+ } else if (ip[-1] < MP_BC_STORE_FAST_MULTI + 16) {
+ printf("STORE_FAST " UINT_FMT, (mp_uint_t)ip[-1] - MP_BC_STORE_FAST_MULTI);
+ } else if (ip[-1] < MP_BC_UNARY_OP_MULTI + 5) {
+ printf("UNARY_OP " UINT_FMT, (mp_uint_t)ip[-1] - MP_BC_UNARY_OP_MULTI);
+ } else if (ip[-1] < MP_BC_BINARY_OP_MULTI + 35) {
+ printf("BINARY_OP " UINT_FMT, (mp_uint_t)ip[-1] - MP_BC_BINARY_OP_MULTI);
+ } else {
+ printf("code %p, byte code 0x%02x not implemented\n", ip, ip[-1]);
+ assert(0);
+ return;
+ }
+ break;
}
printf("\n");
}
diff --git a/py/vm.c b/py/vm.c
index d959880f12..36ea10f5c0 100644
--- a/py/vm.c
+++ b/py/vm.c
@@ -223,18 +223,6 @@ dispatch_loop:
PUSH(MP_OBJ_NULL);
DISPATCH();
- ENTRY(MP_BC_LOAD_FAST_0):
- obj_shared = fastn[0];
- goto load_check;
-
- ENTRY(MP_BC_LOAD_FAST_1):
- obj_shared = fastn[-1];
- goto load_check;
-
- ENTRY(MP_BC_LOAD_FAST_2):
- obj_shared = fastn[-2];
- goto load_check;
-
ENTRY(MP_BC_LOAD_FAST_N):
DECODE_UINT;
obj_shared = fastn[-unum];
@@ -288,18 +276,6 @@ dispatch_loop:
DISPATCH();
}
- ENTRY(MP_BC_STORE_FAST_0):
- fastn[0] = POP();
- DISPATCH();
-
- ENTRY(MP_BC_STORE_FAST_1):
- fastn[-1] = POP();
- DISPATCH();
-
- ENTRY(MP_BC_STORE_FAST_2):
- fastn[-2] = POP();
- DISPATCH();
-
ENTRY(MP_BC_STORE_FAST_N):
DECODE_UINT;
fastn[-unum] = POP();
@@ -606,19 +582,6 @@ unwind_jump:
}
DISPATCH();
- ENTRY(MP_BC_UNARY_OP):
- unum = *ip++;
- SET_TOP(mp_unary_op(unum, TOP()));
- DISPATCH();
-
- ENTRY(MP_BC_BINARY_OP): {
- unum = *ip++;
- mp_obj_t rhs = POP();
- mp_obj_t lhs = TOP();
- SET_TOP(mp_binary_op(unum, lhs, rhs));
- DISPATCH();
- }
-
ENTRY(MP_BC_BUILD_TUPLE):
DECODE_UINT;
sp -= unum - 1;
@@ -890,7 +853,53 @@ yield:
mp_import_all(POP());
DISPATCH();
- ENTRY_DEFAULT: {
+#if MICROPY_OPT_COMPUTED_GOTO
+ ENTRY(MP_BC_LOAD_CONST_SMALL_INT_MULTI):
+ PUSH(MP_OBJ_NEW_SMALL_INT((mp_int_t)ip[-1] - MP_BC_LOAD_CONST_SMALL_INT_MULTI - 16));
+ DISPATCH();
+
+ ENTRY(MP_BC_LOAD_FAST_MULTI):
+ obj_shared = fastn[MP_BC_LOAD_FAST_MULTI - (mp_int_t)ip[-1]];
+ goto load_check;
+
+ ENTRY(MP_BC_STORE_FAST_MULTI):
+ fastn[MP_BC_STORE_FAST_MULTI - (mp_int_t)ip[-1]] = POP();
+ DISPATCH();
+
+ ENTRY(MP_BC_UNARY_OP_MULTI):
+ SET_TOP(mp_unary_op(ip[-1] - MP_BC_UNARY_OP_MULTI, TOP()));
+ DISPATCH();
+
+ ENTRY(MP_BC_BINARY_OP_MULTI): {
+ mp_obj_t rhs = POP();
+ mp_obj_t lhs = TOP();
+ SET_TOP(mp_binary_op(ip[-1] - MP_BC_BINARY_OP_MULTI, lhs, rhs));
+ DISPATCH();
+ }
+
+ ENTRY_DEFAULT:
+#else
+ ENTRY_DEFAULT:
+ if (ip[-1] < MP_BC_LOAD_CONST_SMALL_INT_MULTI + 64) {
+ PUSH(MP_OBJ_NEW_SMALL_INT((mp_int_t)ip[-1] - MP_BC_LOAD_CONST_SMALL_INT_MULTI - 16));
+ DISPATCH();
+ } else if (ip[-1] < MP_BC_LOAD_FAST_MULTI + 16) {
+ obj_shared = fastn[MP_BC_LOAD_FAST_MULTI - (mp_int_t)ip[-1]];
+ goto load_check;
+ } else if (ip[-1] < MP_BC_STORE_FAST_MULTI + 16) {
+ fastn[MP_BC_STORE_FAST_MULTI - (mp_int_t)ip[-1]] = POP();
+ DISPATCH();
+ } else if (ip[-1] < MP_BC_UNARY_OP_MULTI + 5) {
+ SET_TOP(mp_unary_op(ip[-1] - MP_BC_UNARY_OP_MULTI, TOP()));
+ DISPATCH();
+ } else if (ip[-1] < MP_BC_BINARY_OP_MULTI + 35) {
+ mp_obj_t rhs = POP();
+ mp_obj_t lhs = TOP();
+ SET_TOP(mp_binary_op(ip[-1] - MP_BC_BINARY_OP_MULTI, lhs, rhs));
+ DISPATCH();
+ } else
+#endif
+ {
mp_obj_t obj = mp_obj_new_exception_msg(&mp_type_NotImplementedError, "byte code not implemented");
nlr_pop();
fastn[0] = obj;
diff --git a/py/vmentrytable.h b/py/vmentrytable.h
index 598b5b8726..29cfdce4e2 100644
--- a/py/vmentrytable.h
+++ b/py/vmentrytable.h
@@ -41,9 +41,6 @@ static void* entry_table[256] = {
[MP_BC_LOAD_CONST_BYTES] = &&entry_MP_BC_LOAD_CONST_BYTES,
[MP_BC_LOAD_CONST_STRING] = &&entry_MP_BC_LOAD_CONST_STRING,
[MP_BC_LOAD_NULL] = &&entry_MP_BC_LOAD_NULL,
- [MP_BC_LOAD_FAST_0] = &&entry_MP_BC_LOAD_FAST_0,
- [MP_BC_LOAD_FAST_1] = &&entry_MP_BC_LOAD_FAST_1,
- [MP_BC_LOAD_FAST_2] = &&entry_MP_BC_LOAD_FAST_2,
[MP_BC_LOAD_FAST_N] = &&entry_MP_BC_LOAD_FAST_N,
[MP_BC_LOAD_DEREF] = &&entry_MP_BC_LOAD_DEREF,
[MP_BC_LOAD_NAME] = &&entry_MP_BC_LOAD_NAME,
@@ -52,9 +49,6 @@ static void* entry_table[256] = {
[MP_BC_LOAD_METHOD] = &&entry_MP_BC_LOAD_METHOD,
[MP_BC_LOAD_BUILD_CLASS] = &&entry_MP_BC_LOAD_BUILD_CLASS,
[MP_BC_LOAD_SUBSCR] = &&entry_MP_BC_LOAD_SUBSCR,
- [MP_BC_STORE_FAST_0] = &&entry_MP_BC_STORE_FAST_0,
- [MP_BC_STORE_FAST_1] = &&entry_MP_BC_STORE_FAST_1,
- [MP_BC_STORE_FAST_2] = &&entry_MP_BC_STORE_FAST_2,
[MP_BC_STORE_FAST_N] = &&entry_MP_BC_STORE_FAST_N,
[MP_BC_STORE_DEREF] = &&entry_MP_BC_STORE_DEREF,
[MP_BC_STORE_NAME] = &&entry_MP_BC_STORE_NAME,
@@ -86,8 +80,6 @@ static void* entry_table[256] = {
[MP_BC_POP_BLOCK] = &&entry_MP_BC_POP_BLOCK,
[MP_BC_POP_EXCEPT] = &&entry_MP_BC_POP_EXCEPT,
[MP_BC_NOT] = &&entry_MP_BC_NOT,
- [MP_BC_UNARY_OP] = &&entry_MP_BC_UNARY_OP,
- [MP_BC_BINARY_OP] = &&entry_MP_BC_BINARY_OP,
[MP_BC_BUILD_TUPLE] = &&entry_MP_BC_BUILD_TUPLE,
[MP_BC_BUILD_LIST] = &&entry_MP_BC_BUILD_LIST,
[MP_BC_LIST_APPEND] = &&entry_MP_BC_LIST_APPEND,
@@ -114,6 +106,11 @@ static void* entry_table[256] = {
[MP_BC_IMPORT_NAME] = &&entry_MP_BC_IMPORT_NAME,
[MP_BC_IMPORT_FROM] = &&entry_MP_BC_IMPORT_FROM,
[MP_BC_IMPORT_STAR] = &&entry_MP_BC_IMPORT_STAR,
+ [MP_BC_LOAD_CONST_SMALL_INT_MULTI ... MP_BC_LOAD_CONST_SMALL_INT_MULTI + 63] = &&entry_MP_BC_LOAD_CONST_SMALL_INT_MULTI,
+ [MP_BC_LOAD_FAST_MULTI ... MP_BC_LOAD_FAST_MULTI + 15] = &&entry_MP_BC_LOAD_FAST_MULTI,
+ [MP_BC_STORE_FAST_MULTI ... MP_BC_STORE_FAST_MULTI + 15] = &&entry_MP_BC_STORE_FAST_MULTI,
+ [MP_BC_UNARY_OP_MULTI ... MP_BC_UNARY_OP_MULTI + 4] = &&entry_MP_BC_UNARY_OP_MULTI,
+ [MP_BC_BINARY_OP_MULTI ... MP_BC_BINARY_OP_MULTI + 34] = &&entry_MP_BC_BINARY_OP_MULTI,
};
#if __clang__