Lock active_units references on compaction
This might race with mjit_recompile.
This commit is contained in:
parent
4b4af40f55
commit
556a728508
@ -936,7 +936,9 @@ compile_compact_jit_code(char* c_file)
|
|||||||
// TODO: Consider using a more granular lock after we implement inlining across
|
// TODO: Consider using a more granular lock after we implement inlining across
|
||||||
// compacted functions (not done yet).
|
// compacted functions (not done yet).
|
||||||
bool success = true;
|
bool success = true;
|
||||||
|
CRITICAL_SECTION_START(3, "before active_units list_for_each");
|
||||||
list_for_each(&active_units.head, child_unit, unode) {
|
list_for_each(&active_units.head, child_unit, unode) {
|
||||||
|
CRITICAL_SECTION_FINISH(3, "after active_units list_for_each");
|
||||||
char funcname[MAXPATHLEN];
|
char funcname[MAXPATHLEN];
|
||||||
sprint_funcname(funcname, child_unit);
|
sprint_funcname(funcname, child_unit);
|
||||||
|
|
||||||
@ -950,7 +952,10 @@ compile_compact_jit_code(char* c_file)
|
|||||||
if (!iseq_label) iseq_label = sep = "";
|
if (!iseq_label) iseq_label = sep = "";
|
||||||
fprintf(f, "\n/* %s%s%s:%ld */\n", iseq_label, sep, iseq_path, iseq_lineno);
|
fprintf(f, "\n/* %s%s%s:%ld */\n", iseq_label, sep, iseq_path, iseq_lineno);
|
||||||
success &= mjit_compile(f, child_unit->iseq, funcname, child_unit->id);
|
success &= mjit_compile(f, child_unit->iseq, funcname, child_unit->id);
|
||||||
|
|
||||||
|
CRITICAL_SECTION_START(3, "before active_units list_for_each");
|
||||||
}
|
}
|
||||||
|
CRITICAL_SECTION_FINISH(3, "after active_units list_for_each");
|
||||||
|
|
||||||
// release blocking mjit_gc_start_hook
|
// release blocking mjit_gc_start_hook
|
||||||
CRITICAL_SECTION_START(3, "after mjit_compile to wakeup client for GC");
|
CRITICAL_SECTION_START(3, "after mjit_compile to wakeup client for GC");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user