* [PATCH] Fail if dwz fails.
@ 2021-04-22 11:11 Martin Liška
2021-05-13 8:01 ` Martin Liška
0 siblings, 1 reply; 6+ messages in thread
From: Martin Liška @ 2021-04-22 11:11 UTC (permalink / raw)
To: debugedit; +Cc: Tom de Vries
Right now, dwz return code is 0 or a small integer value (<= 3)
for situations like:
- dwz: Too few files for multifile optimization
- dwz: Multi-file optimization not allowed for different pointer sizes or endianity
These are not fatal errors and the script should continue. On the other
hand abort or segfault error values should cause failure of the script.
Let's reserve values 1-16 for a recoverable dwz exit codes.
---
scripts/find-debuginfo.sh | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/scripts/find-debuginfo.sh b/scripts/find-debuginfo.sh
index 3d736e0..7fb9b62 100755
--- a/scripts/find-debuginfo.sh
+++ b/scripts/find-debuginfo.sh
@@ -556,6 +556,10 @@ if $run_dwz \
&& dwz_opts="${dwz_opts} -L ${dwz_max_die_limit}"
if type dwz >/dev/null 2>&1; then
( cd "${RPM_BUILD_ROOT}/usr/lib/debug" && dwz $dwz_opts ${dwz_files[@]} )
+ if [ $? -gt 16 ]; then
+ echo >&2 "*** ERROR: DWARF compression failed"
+ exit 3
+ fi
else
echo >&2 "*** ERROR: DWARF compression requested, but no dwz installed"
exit 2
--
2.31.1
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Fail if dwz fails.
2021-04-22 11:11 [PATCH] Fail if dwz fails Martin Liška
@ 2021-05-13 8:01 ` Martin Liška
2021-05-13 14:07 ` Mark Wielaard
0 siblings, 1 reply; 6+ messages in thread
From: Martin Liška @ 2021-05-13 8:01 UTC (permalink / raw)
To: debugedit; +Cc: Tom de Vries
PING^1
On 4/22/21 1:11 PM, Martin Liška wrote:
> Right now, dwz return code is 0 or a small integer value (<= 3)
> for situations like:
>
> - dwz: Too few files for multifile optimization
> - dwz: Multi-file optimization not allowed for different pointer sizes or endianity
>
> These are not fatal errors and the script should continue. On the other
> hand abort or segfault error values should cause failure of the script.
>
> Let's reserve values 1-16 for a recoverable dwz exit codes.
> ---
> scripts/find-debuginfo.sh | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/scripts/find-debuginfo.sh b/scripts/find-debuginfo.sh
> index 3d736e0..7fb9b62 100755
> --- a/scripts/find-debuginfo.sh
> +++ b/scripts/find-debuginfo.sh
> @@ -556,6 +556,10 @@ if $run_dwz \
> && dwz_opts="${dwz_opts} -L ${dwz_max_die_limit}"
> if type dwz >/dev/null 2>&1; then
> ( cd "${RPM_BUILD_ROOT}/usr/lib/debug" && dwz $dwz_opts ${dwz_files[@]} )
> + if [ $? -gt 16 ]; then
> + echo >&2 "*** ERROR: DWARF compression failed"
> + exit 3
> + fi
> else
> echo >&2 "*** ERROR: DWARF compression requested, but no dwz installed"
> exit 2
>
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Fail if dwz fails.
2021-05-13 8:01 ` Martin Liška
@ 2021-05-13 14:07 ` Mark Wielaard
2021-05-14 10:46 ` Martin Liška
0 siblings, 1 reply; 6+ messages in thread
From: Mark Wielaard @ 2021-05-13 14:07 UTC (permalink / raw)
To: Martin Liška, debugedit; +Cc: Tom de Vries, dwz
Hi Martin,
On Thu, 2021-05-13 at 10:01 +0200, Martin Liška wrote:
> PING^1
Sorry I missed this earlier.
> On 4/22/21 1:11 PM, Martin Liška wrote:
> > Right now, dwz return code is 0 or a small integer value (<= 3)
> > for situations like:
> >
> > - dwz: Too few files for multifile optimization
> > - dwz: Multi-file optimization not allowed for different pointer sizes or endianity
> >
> > These are not fatal errors and the script should continue. On the other
> > hand abort or segfault error values should cause failure of the script.
> >
> > Let's reserve values 1-16 for a recoverable dwz exit codes.
With "recoverable" you mean that dwz did do compression, but could not
deliver optimal compression?
It would be good to have an ack from the dwz developers that 1 to 16
are "recoverable" errors (I added dwz@sourceware.org to CC).
Would it be possible to tweak the find-debuginfo.sh script to avoid
them? e.g. Could we see how many arguments we have so that we only use
-m when there are 1+ debug files? And/Or detect debug files using
different endianess and ptr sizes so they are processed in different
batches?
Ideally an error code from dwz means something went terribly wrong and
we abort find-debuginfo.sh. IMHO.
Cheers,
Mark
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Fail if dwz fails.
2021-05-13 14:07 ` Mark Wielaard
@ 2021-05-14 10:46 ` Martin Liška
2021-05-16 20:14 ` Mark Wielaard
0 siblings, 1 reply; 6+ messages in thread
From: Martin Liška @ 2021-05-14 10:46 UTC (permalink / raw)
To: Mark Wielaard, debugedit; +Cc: dwz, Tom de Vries
On 5/13/21 4:07 PM, Mark Wielaard wrote:
> Hi Martin,
>
> On Thu, 2021-05-13 at 10:01 +0200, Martin Liška wrote:
>> PING^1
>
> Sorry I missed this earlier.
>
>> On 4/22/21 1:11 PM, Martin Liška wrote:
>>> Right now, dwz return code is 0 or a small integer value (<= 3)
>>> for situations like:
>>>
>>> - dwz: Too few files for multifile optimization
>>> - dwz: Multi-file optimization not allowed for different pointer sizes or endianity
>>>
>>> These are not fatal errors and the script should continue. On the other
>>> hand abort or segfault error values should cause failure of the script.
>>>
>>> Let's reserve values 1-16 for a recoverable dwz exit codes.
>
> With "recoverable" you mean that dwz did do compression, but could not
> deliver optimal compression?
No, I speak about cases, where compression cannot be done
(different endianess, ptr sizes, not beneficial, any other reason).
>
> It would be good to have an ack from the dwz developers that 1 to 16
> are "recoverable" errors (I added dwz@sourceware.org to CC).
Yes. That's why I CCed Tom.
>
> Would it be possible to tweak the find-debuginfo.sh script to avoid
> them? e.g. Could we see how many arguments we have so that we only use
> -m when there are 1+ debug files? And/Or detect debug files using
> different endianess and ptr sizes so they are processed in different
> batches?
No, I would leave it to dwz. There may be other reasons.
>
> Ideally an error code from dwz means something went terribly wrong and
> we abort find-debuginfo.sh. IMHO.
I would allow the mentioned "soft" error codes.
Martin
>
> Cheers,
>
> Mark
>
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Fail if dwz fails.
2021-05-14 10:46 ` Martin Liška
@ 2021-05-16 20:14 ` Mark Wielaard
2021-05-17 10:06 ` Tom de Vries
0 siblings, 1 reply; 6+ messages in thread
From: Mark Wielaard @ 2021-05-16 20:14 UTC (permalink / raw)
To: Martin Liška; +Cc: debugedit, dwz, Tom de Vries
Hi Martin,
On Fri, May 14, 2021 at 12:46:15PM +0200, Martin Liška wrote:
> On 5/13/21 4:07 PM, Mark Wielaard wrote:
> > > On 4/22/21 1:11 PM, Martin Liška wrote:
> > > > Right now, dwz return code is 0 or a small integer value (<= 3)
> > > > for situations like:
> > > >
> > > > - dwz: Too few files for multifile optimization
> > > > - dwz: Multi-file optimization not allowed for different pointer sizes or endianity
> > > >
> > > > These are not fatal errors and the script should continue. On the other
> > > > hand abort or segfault error values should cause failure of the script.
> > > >
> > > > Let's reserve values 1-16 for a recoverable dwz exit codes.
> >
> > With "recoverable" you mean that dwz did do compression, but could not
> > deliver optimal compression?
>
> No, I speak about cases, where compression cannot be done
> (different endianess, ptr sizes, not beneficial, any other reason).
I think we are talking about somewhat the same thing. In those cases
dwz does something. The result is just not optimal.
> > It would be good to have an ack from the dwz developers that 1 to 16
> > are "recoverable" errors (I added dwz@sourceware.org to CC).
>
> Yes. That's why I CCed Tom.
>
> >
> > Would it be possible to tweak the find-debuginfo.sh script to avoid
> > them? e.g. Could we see how many arguments we have so that we only use
> > -m when there are 1+ debug files? And/Or detect debug files using
> > different endianess and ptr sizes so they are processed in different
> > batches?
>
> No, I would leave it to dwz. There may be other reasons.
But for the reasons we do know about we could improve
find-debuginfo.sh to do the right thing (not use -m if there is only
one file, sort files by endianess/ptrsize). Ideally you call
find-debuginfo.sh and it does the right thing even if you only have
one ELF file or a mix of ELF files.
> > Ideally an error code from dwz means something went terribly wrong and
> > we abort find-debuginfo.sh. IMHO.
>
> I would allow the mentioned "soft" error codes.
Couldn't optimize is an "soft" error indeed. I don't know about the
others.
Cheers,
Mark
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] Fail if dwz fails.
2021-05-16 20:14 ` Mark Wielaard
@ 2021-05-17 10:06 ` Tom de Vries
0 siblings, 0 replies; 6+ messages in thread
From: Tom de Vries @ 2021-05-17 10:06 UTC (permalink / raw)
To: Mark Wielaard, Martin Liška; +Cc: debugedit, dwz
On 5/16/21 10:14 PM, Mark Wielaard wrote:
> Hi Martin,
>
> On Fri, May 14, 2021 at 12:46:15PM +0200, Martin Liška wrote:
>> On 5/13/21 4:07 PM, Mark Wielaard wrote:
>>>> On 4/22/21 1:11 PM, Martin Liška wrote:
>>>>> Right now, dwz return code is 0 or a small integer value (<= 3)
>>>>> for situations like:
>>>>>
>>>>> - dwz: Too few files for multifile optimization
>>>>> - dwz: Multi-file optimization not allowed for different pointer sizes or endianity
>>>>>
>>>>> These are not fatal errors and the script should continue. On the other
>>>>> hand abort or segfault error values should cause failure of the script.
>>>>>
>>>>> Let's reserve values 1-16 for a recoverable dwz exit codes.
>>>
>>> With "recoverable" you mean that dwz did do compression, but could not
>>> deliver optimal compression?
>>
>> No, I speak about cases, where compression cannot be done
>> (different endianess, ptr sizes, not beneficial, any other reason).
>
> I think we are talking about somewhat the same thing. In those cases
> dwz does something. The result is just not optimal.
>
>>> It would be good to have an ack from the dwz developers that 1 to 16
>>> are "recoverable" errors (I added dwz@sourceware.org to CC).
>>
>> Yes. That's why I CCed Tom.
>>
>>>
AFAIK, the exit codes are either 0 or 1 (excluding abort/assert).
FWIW, also invalid input dwarf results in exit code 1.
>>> Would it be possible to tweak the find-debuginfo.sh script to avoid
>>> them? e.g. Could we see how many arguments we have so that we only use
>>> -m when there are 1+ debug files? And/Or detect debug files using
>>> different endianess and ptr sizes so they are processed in different
>>> batches?
>>
>> No, I would leave it to dwz. There may be other reasons.
>
> But for the reasons we do know about we could improve
> find-debuginfo.sh to do the right thing (not use -m if there is only
> one file, sort files by endianess/ptrsize). Ideally you call
> find-debuginfo.sh and it does the right thing even if you only have
> one ELF file or a mix of ELF files.
>
>>> Ideally an error code from dwz means something went terribly wrong and
>>> we abort find-debuginfo.sh. IMHO.
>>
>> I would allow the mentioned "soft" error codes.
>
> Couldn't optimize is an "soft" error indeed. I don't know about the
> others.
Couldn't optimize is not an error:
...
$ ./dwz hello ; echo $?
0
$ ./dwz hello ; echo $?
./dwz: hello: DWARF compression not beneficial - old size 3372 new size 3372
0
$ ...
OTOH, failing to create a file specified with -o is:
...
$ ./dwz hello -o hello.1; echo $?
0
$ ./dwz hello.1 -o hello.2; echo $?
./dwz: hello.1: DWARF compression not beneficial - old size 3372 new
size 3372
1
$
...
FWIW, I don't have a strong opinion on this patch.
As dwz developer, more bug reports means a better dwz, so this is good
for me.
I just wonder whether this is a good choice for package developers.
Isn't a dwz crash for them just a case of "no debuginfo compression"?
Thanks,
- Tom
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2021-05-17 10:06 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-04-22 11:11 [PATCH] Fail if dwz fails Martin Liška
2021-05-13 8:01 ` Martin Liška
2021-05-13 14:07 ` Mark Wielaard
2021-05-14 10:46 ` Martin Liška
2021-05-16 20:14 ` Mark Wielaard
2021-05-17 10:06 ` Tom de Vries
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).