Prevent BuildPhi from encountering a null llvm_entry_block (#4663)

There is a scenario where `aot_compile_op_block()` does not prepare a block for
`if`. As a result, the return value of `LLVMBuildPhi()` in
`push_aot_block_to_stack_and_pass_params()` will be dangling, leading to a
memory leak as it cannot be released.
This commit is contained in:
liang.he 2025-10-16 10:19:44 +08:00 committed by GitHub
parent 163acd2259
commit 826ae6eb01
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -495,15 +495,17 @@ push_aot_block_to_stack_and_pass_params(AOTCompContext *comp_ctx,
/* Create param phis */ /* Create param phis */
for (i = 0; i < block->param_count; i++) { for (i = 0; i < block->param_count; i++) {
SET_BUILDER_POS(block->llvm_entry_block); if (block->llvm_entry_block) {
snprintf(name, sizeof(name), "%s%d_phi%d", SET_BUILDER_POS(block->llvm_entry_block);
block_name_prefix[block->label_type], block->block_index, snprintf(name, sizeof(name), "%s%d_phi%d",
i); block_name_prefix[block->label_type],
if (!(block->param_phis[i] = LLVMBuildPhi( block->block_index, i);
comp_ctx->builder, TO_LLVM_TYPE(block->param_types[i]), if (!(block->param_phis[i] = LLVMBuildPhi(
name))) { comp_ctx->builder,
aot_set_last_error("llvm build phi failed."); TO_LLVM_TYPE(block->param_types[i]), name))) {
goto fail; aot_set_last_error("llvm build phi failed.");
goto fail;
}
} }
if (block->label_type == LABEL_TYPE_IF if (block->label_type == LABEL_TYPE_IF