From: Tom de Vries Date: Tue, 19 Jul 2022 15:01:21 +0000 (+0200) Subject: [gdb/symtab] Use task size in parallel for in process_queue X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=refs%2Fheads%2Fusers%2Fvries%2Fprocess-queue-parallel;p=thirdparty%2Fbinutils-gdb.git [gdb/symtab] Use task size in parallel for in process_queue --- diff --git a/gdb/dwarf2/read.c b/gdb/dwarf2/read.c index c0d65218172..b279db3ac8b 100644 --- a/gdb/dwarf2/read.c +++ b/gdb/dwarf2/read.c @@ -7624,6 +7624,14 @@ process_queue (dwarf2_per_objfile *per_objfile) using iter_type = decltype (per_objfile->queue->begin ()); using result_type = int; + std::function task_size + = [=] (iter_type iter) + { + dwarf2_queue_item &item = *iter; + dwarf2_per_cu_data *per_cu = item.per_cu; + return per_cu->length (); + }; + /* The queue starts out with one item, but following a DIE reference may load a new CU, adding it to the end of the queue. */ while (!per_objfile->queue->empty ()) @@ -7642,7 +7650,7 @@ process_queue (dwarf2_per_objfile *per_objfile) } return result_type (1); - }); + }, &task_size); for (int i = 0; i < nr_to_be_processed; ++i) {