From cfe0c84ee27f9ef8a8c9f32e71354d89bf644524 Mon Sep 17 00:00:00 2001 From: Tim Holy Date: Fri, 25 Feb 2022 09:22:05 -0600 Subject: [PATCH 1/2] Pre-allocate htables when serializing external methodinstances Fixes #44338 --- src/dump.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/dump.c b/src/dump.c index 919bac8c82a07..355d1f7b8cd4e 100644 --- a/src/dump.c +++ b/src/dump.c @@ -286,10 +286,10 @@ static size_t queue_external_mis(jl_array_t *list) { size_t i, n = 0; htable_t visited; - htable_new(&visited, 0); if (list) { assert(jl_is_array(list)); size_t n0 = jl_array_len(list); + htable_new(&visited, n0); for (i = 0; i < n0; i++) { jl_method_instance_t *mi = (jl_method_instance_t*)jl_array_ptr_ref(list, i); assert(jl_is_method_instance(mi)); @@ -2640,7 +2640,7 @@ JL_DLLEXPORT int jl_save_incremental(const char *fname, jl_array_t *worklist) arraylist_new(&reinit_list, 0); htable_new(&edges_map, 0); htable_new(&backref_table, 5000); - htable_new(&external_mis, 0); + htable_new(&external_mis, newly_inferred ? jl_array_len(newly_inferred) : 0); ptrhash_put(&backref_table, jl_main_module, (char*)HT_NOTFOUND + 1); backref_table_numel = 1; jl_idtable_type = jl_base_module ? jl_get_global(jl_base_module, jl_symbol("IdDict")) : NULL; From fc57ef7dc5848ddb596538b87bfe5d99033f54ce Mon Sep 17 00:00:00 2001 From: Tim Holy Date: Wed, 2 Mar 2022 17:23:03 -0600 Subject: [PATCH 2/2] fix memory error --- src/dump.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/dump.c b/src/dump.c index 355d1f7b8cd4e..c23533c81702f 100644 --- a/src/dump.c +++ b/src/dump.c @@ -272,6 +272,7 @@ static int has_backedge_to_worklist(jl_method_instance_t *mi, htable_t *visited) for (i = 0; i < n; i++) { jl_method_instance_t *be = (jl_method_instance_t*)jl_array_ptr_ref(mi->backedges, i); if (has_backedge_to_worklist(be, visited)) { + bp = ptrhash_bp(visited, mi); // re-acquire since rehashing might change the location *bp = (void*)((char*)HT_NOTFOUND + 2); // found return 1; }