[committed] Add ret to struct file_result
Tom de Vries
tdevries@suse.de
Mon Mar 29 06:36:55 GMT 2021
Hi,
Further simplify the serial/parallel code in dwz_files_1 by factoring out the
return status handling. Add a ret field to struct file_result to store the
per-file return status.
Committed to trunk.
Thanks,
- Tom
Add ret to struct file_result
2021-03-29 Tom de Vries <tdevries@suse.de>
* dwz.c (struct file_result): Add ret field.
(wait_child_exit): Return void. Set ret.
(wait_children_exit): Return void. Update call to wait_child_exit.
(dwz_files_1): Move return status handling out of serial/parallel code.
---
dwz.c | 68 ++++++++++++++++++++++++++++++++-----------------------------------
1 file changed, 32 insertions(+), 36 deletions(-)
diff --git a/dwz.c b/dwz.c
index 377e1be..de600c1 100644
--- a/dwz.c
+++ b/dwz.c
@@ -15049,6 +15049,7 @@ struct file_result
0: Processed, changed.
1: Processed, unchanged. */
int res;
+ int ret;
size_t hardlink_to;
unsigned int die_count;
bool skip_multifile;
@@ -16444,7 +16445,7 @@ decode_child_exit_status (int state, struct file_result *res)
}
/* Wait on child exit with PID, update PIDS and RES. */
-static int
+static void
wait_child_exit (pid_t pid, pid_t *pids, int nr_pids,
struct file_result *resa)
{
@@ -16460,28 +16461,21 @@ wait_child_exit (pid_t pid, pid_t *pids, int nr_pids,
}
assert (i < nr_pids);
- return decode_child_exit_status (state, &resa[i]);
+ resa[i].ret = decode_child_exit_status (state, &resa[i]);
}
/* Wait on exit of chilren in PIDS, update RESA. */
-static int
+static void
wait_children_exit (pid_t *pids, int nr_files, struct file_result *resa)
{
- int ret = 0;
-
int i;
for (i = 0; i < nr_files; i++)
{
- int thisret;
struct file_result *res = &resa[i];
if (pids[i] == 0)
continue;
- thisret = wait_child_exit (pids[i], &pids[i], 1, res);
- if (thisret == 1)
- ret = 1;
+ wait_child_exit (pids[i], &pids[i], 1, res);
}
-
- return ret;
}
/* Dwarf-compress FILES. If HARDLINK, detect if some files are hardlinks and
@@ -16540,13 +16534,10 @@ dwz_files_1 (int nr_files, char *files[], bool hardlink,
for (j = 0; j < workset_size; j++)
{
int i = workset[j];
- int thisret;
if (nr_forks == max_forks)
{
- int thisret = wait_child_exit (-1, pids, i, resa);
- if (thisret == 1)
- ret = 1;
+ wait_child_exit (-1, pids, i, resa);
nr_forks--;
}
@@ -16556,7 +16547,7 @@ dwz_files_1 (int nr_files, char *files[], bool hardlink,
{
file = files[i];
struct file_result *res = &resa[i];
- thisret = dwz_with_low_mem (file, NULL, res);
+ int thisret = dwz_with_low_mem (file, NULL, res);
return encode_child_exit_status (thisret, res);
}
else
@@ -16566,30 +16557,32 @@ dwz_files_1 (int nr_files, char *files[], bool hardlink,
}
}
if (nr_forks > 0)
- {
- int thisret = wait_children_exit (pids, nr_files, resa);
- if (thisret == 1)
- ret = 1;
- }
+ wait_children_exit (pids, nr_files, resa);
}
else
{
for (j = 0; j < workset_size; j++)
{
int i = workset[j];
- int thisret;
file = files[i];
struct file_result *res = &resa[i];
if (stats_p)
init_stats (file);
- thisret = dwz_with_low_mem (file, NULL, res);
- if (thisret == 1)
- ret = 1;
- else if (!res->low_mem_p && !res->skip_multifile && res->res >= 0)
- successcount++;
+ res->ret = dwz_with_low_mem (file, NULL, res);
}
}
+ for (j = 0; j < workset_size; j++)
+ {
+ int i = workset[j];
+ struct file_result *res = &resa[i];
+ int thisret = res->ret;
+ if (thisret == 1)
+ ret = 1;
+ else if (!res->low_mem_p && !res->skip_multifile && res->res >= 0)
+ successcount++;
+ }
+
if (hardlink)
update_hardlinks (nr_files, files, resa);
@@ -16647,9 +16640,7 @@ dwz_files_1 (int nr_files, char *files[], bool hardlink,
if (nr_forks == max_forks)
{
- int thisret = wait_child_exit (-1, pids, i, resa);
- if (thisret == 1)
- ret = 1;
+ wait_child_exit (-1, pids, i, resa);
nr_forks--;
}
@@ -16670,17 +16661,14 @@ dwz_files_1 (int nr_files, char *files[], bool hardlink,
}
}
if (nr_forks > 0)
- {
- int thisret = wait_children_exit (pids, nr_files, resa);
- if (thisret == 1)
- ret = 1;
- }
+ wait_children_exit (pids, nr_files, resa);
}
else
{
for (j = 0; j < workset_size; j++)
{
int i = workset[j];
+ struct file_result *res = &resa[i];
dw_cu_ref cu;
file = files[i];
if (stats_p)
@@ -16688,10 +16676,18 @@ dwz_files_1 (int nr_files, char *files[], bool hardlink,
multifile_mode = MULTIFILE_MODE_FI;
for (cu = alt_first_cu; cu; cu = cu->cu_next)
alt_clear_dups (cu->cu_die);
- ret |= dwz (file, NULL, &resa[i]);
+ res->ret = dwz (file, NULL, res);
}
}
+ for (j = 0; j < workset_size; j++)
+ {
+ int i = workset[j];
+ struct file_result *res = &resa[i];
+ int thisret = res->ret;
+ ret |= thisret;
+ }
+
if (hardlink)
update_hardlinks (nr_files, files, resa);
More information about the Dwz
mailing list