mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
bpo-44626: Merge basic blocks earlier to enable better handling of exit blocks without line numbers (GH-27138) (GH-27182)
(cherry picked from commit a86f7dae0a
)
This commit is contained in:
parent
0e349ea554
commit
37686f78cc
5 changed files with 3901 additions and 3835 deletions
|
@ -6934,10 +6934,11 @@ makecode(struct compiler *c, struct assembler *a, PyObject *consts)
|
|||
/* For debugging purposes only */
|
||||
#if 0
|
||||
static void
|
||||
dump_instr(const struct instr *i)
|
||||
dump_instr(struct instr *i)
|
||||
{
|
||||
const char *jrel = (is_relative_jump(instr)) ? "jrel " : "";
|
||||
const char *jabs = (is_jump(instr) && !is_relative_jump(instr))? "jabs " : "";
|
||||
const char *jrel = (is_relative_jump(i)) ? "jrel " : "";
|
||||
const char *jabs = (is_jump(i) && !is_relative_jump(i))? "jabs " : "";
|
||||
|
||||
char arg[128];
|
||||
|
||||
*arg = '\0';
|
||||
|
@ -6974,6 +6975,9 @@ optimize_cfg(struct compiler *c, struct assembler *a, PyObject *consts);
|
|||
static int
|
||||
ensure_exits_have_lineno(struct compiler *c);
|
||||
|
||||
static int
|
||||
extend_block(basicblock *bb);
|
||||
|
||||
static int
|
||||
insert_generator_prefix(struct compiler *c, basicblock *entryblock) {
|
||||
|
||||
|
@ -7063,6 +7067,12 @@ assemble(struct compiler *c, int addNone)
|
|||
}
|
||||
}
|
||||
|
||||
for (basicblock *b = c->u->u_blocks; b != NULL; b = b->b_list) {
|
||||
if (extend_block(b)) {
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
if (ensure_exits_have_lineno(c)) {
|
||||
return NULL;
|
||||
}
|
||||
|
@ -7096,6 +7106,7 @@ assemble(struct compiler *c, int addNone)
|
|||
if (consts == NULL) {
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (optimize_cfg(c, &a, consts)) {
|
||||
goto error;
|
||||
}
|
||||
|
@ -7459,19 +7470,14 @@ optimize_basic_block(struct compiler *c, basicblock *bb, PyObject *consts)
|
|||
goto error;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
if (inst->i_target->b_exit && inst->i_target->b_iused <= MAX_COPY_SIZE) {
|
||||
basicblock *to_copy = inst->i_target;
|
||||
inst->i_opcode = NOP;
|
||||
for (i = 0; i < to_copy->b_iused; i++) {
|
||||
int index = compiler_next_instr(bb);
|
||||
if (index < 0) {
|
||||
return -1;
|
||||
}
|
||||
bb->b_instr[index] = to_copy->b_instr[i];
|
||||
}
|
||||
bb->b_exit = 1;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case FOR_ITER:
|
||||
assert (i == bb->b_iused-1);
|
||||
if (target->i_opcode == JUMP_FORWARD) {
|
||||
if (eliminate_jump_to_jump(bb, inst->i_opcode)) {
|
||||
goto error;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case ROT_N:
|
||||
|
@ -7501,6 +7507,32 @@ error:
|
|||
return -1;
|
||||
}
|
||||
|
||||
/* If this block ends with an unconditional jump to an exit block,
|
||||
* then remove the jump and extend this block with the target.
|
||||
*/
|
||||
static int
|
||||
extend_block(basicblock *bb) {
|
||||
if (bb->b_iused == 0) {
|
||||
return 0;
|
||||
}
|
||||
struct instr *last = &bb->b_instr[bb->b_iused-1];
|
||||
if (last->i_opcode != JUMP_ABSOLUTE && last->i_opcode != JUMP_FORWARD) {
|
||||
return 0;
|
||||
}
|
||||
if (last->i_target->b_exit && last->i_target->b_iused <= MAX_COPY_SIZE) {
|
||||
basicblock *to_copy = last->i_target;
|
||||
last->i_opcode = NOP;
|
||||
for (int i = 0; i < to_copy->b_iused; i++) {
|
||||
int index = compiler_next_instr(bb);
|
||||
if (index < 0) {
|
||||
return -1;
|
||||
}
|
||||
bb->b_instr[index] = to_copy->b_instr[i];
|
||||
}
|
||||
bb->b_exit = 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void
|
||||
clean_basic_block(basicblock *bb, int prev_lineno) {
|
||||
|
|
3316
Python/importlib.h
generated
3316
Python/importlib.h
generated
File diff suppressed because it is too large
Load diff
4311
Python/importlib_external.h
generated
4311
Python/importlib_external.h
generated
File diff suppressed because it is too large
Load diff
Loading…
Add table
Add a link
Reference in a new issue