- Update to 0.15 release:
* Uses xxHash hashing algorithm. A 8% ~ 14% speedup. * Set endianity of multifile using -e, --multifile-endian. * Set pointer size of multifile using -p, --multifile-pointer-size * Process files in parallel using -j N --jobs N. The default is processors / 2. Disabled when multifile is used. * Prints abbrev or DIE offset for Unknown DWARF error messages. * All testcases have been updated to work against the binutils 2.39. - Remove upstreamed patches: * dwz-fix-another-reference-from-pu-to-cu-for-odr.patch * dwz-handle-reordered-dup-chains-in-create-import-tree.patch * dwz-testsuite-fix-pr27463.sh-on-riscv64.patch * dwz-use-grep-E-instead-of-egrep.patch - Rebased patches: * dwz-remove-odr-struct-multifile.sh.patch * dwz-enable-odr-by-default.patch OBS-URL: https://build.opensuse.org/package/show/devel:tools:compiler/dwz?expand=0&rev=44
This commit is contained in:
parent
d147a35d9d
commit
c7b04ac477
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:87ea6f138bdb85b8ef37883e97b04e329fae56302a49cfd41c267d1f53fe6e0f
|
|
||||||
size 147428
|
|
BIN
dwz-0.15.tar.xz
(Stored with Git LFS)
Normal file
BIN
dwz-0.15.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -1,39 +1,17 @@
|
|||||||
Enable odr by default
|
diff --git a/args.c b/args.c
|
||||||
|
index e93c24d..3e1113f 100644
|
||||||
|
--- a/args.c
|
||||||
|
+++ b/args.c
|
||||||
|
@@ -66,7 +66,7 @@ int gen_cu_p = 0;
|
||||||
|
|
||||||
This reverts commit d49096d "[odr] Disable --odr by default".
|
enum die_count_methods die_count_method = estimate;
|
||||||
|
|
||||||
---
|
|
||||||
dwz.1 | 2 +-
|
|
||||||
dwz.c | 4 ++--
|
|
||||||
2 files changed, 3 insertions(+), 3 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/dwz.1 b/dwz.1
|
|
||||||
index 19dc814..63c50d5 100644
|
|
||||||
--- a/dwz.1
|
|
||||||
+++ b/dwz.1
|
|
||||||
@@ -119,7 +119,7 @@ considered equal. This has the effect that DIEs referring to distinct DIEs
|
|
||||||
representing the same type (like f.i. pointer type DIEs) are considered equal,
|
|
||||||
and may be deduplicated. The status of this optimization is experimental.
|
|
||||||
It's disabled in low-mem mode.
|
|
||||||
-Disabled by default.
|
|
||||||
+Enabled by default.
|
|
||||||
.TP
|
|
||||||
.B \-\-odr-mode=<basic|link>
|
|
||||||
Set the One-Definition-Rule optimization aggressiveness: basic or link.
|
|
||||||
diff --git a/dwz.c b/dwz.c
|
|
||||||
index 5effbc1..a02b8fd 100644
|
|
||||||
--- a/dwz.c
|
|
||||||
+++ b/dwz.c
|
|
||||||
@@ -230,7 +230,7 @@ enum die_count_methods
|
|
||||||
};
|
|
||||||
static enum die_count_methods die_count_method = estimate;
|
|
||||||
|
|
||||||
-int odr = 0;
|
-int odr = 0;
|
||||||
+int odr = 1;
|
+int odr = 1;
|
||||||
enum odr_mode { ODR_BASIC, ODR_LINK };
|
|
||||||
enum odr_mode odr_mode = ODR_LINK;
|
enum odr_mode odr_mode = ODR_LINK;
|
||||||
int odr_mode_parsed = 0;
|
|
||||||
@@ -16343,7 +16343,7 @@ static struct option_help dwz_common_options_help[] =
|
/* Filename if inter-file size optimization should be performed. */
|
||||||
|
@@ -202,7 +202,7 @@ static struct option_help dwz_common_options_help[] =
|
||||||
"Don't optimize files larger than this limit." },
|
"Don't optimize files larger than this limit." },
|
||||||
{ NULL, "odr", NULL, NULL,
|
{ NULL, "odr", NULL, NULL,
|
||||||
NULL },
|
NULL },
|
||||||
@ -42,3 +20,16 @@ index 5effbc1..a02b8fd 100644
|
|||||||
"Enable/disable one definition rule optimization." },
|
"Enable/disable one definition rule optimization." },
|
||||||
{ NULL, "odr-mode", "<basic|link>", "link",
|
{ NULL, "odr-mode", "<basic|link>", "link",
|
||||||
"Set aggressiveness level of one definition rule optimization." },
|
"Set aggressiveness level of one definition rule optimization." },
|
||||||
|
diff --git a/dwz.1 b/dwz.1
|
||||||
|
index 1cff329..f3cd3dd 100644
|
||||||
|
--- a/dwz.1
|
||||||
|
+++ b/dwz.1
|
||||||
|
@@ -133,7 +133,7 @@ considered equal. This has the effect that DIEs referring to distinct DIEs
|
||||||
|
representing the same type (like f.i. pointer type DIEs) are considered equal,
|
||||||
|
and may be deduplicated. The status of this optimization is experimental.
|
||||||
|
It's disabled in low-mem mode.
|
||||||
|
-Disabled by default.
|
||||||
|
+Enabled by default.
|
||||||
|
.TP
|
||||||
|
.B \-\-odr-mode=<basic|link>
|
||||||
|
Set the One-Definition-Rule optimization aggressiveness: basic or link.
|
||||||
|
@ -1,82 +0,0 @@
|
|||||||
Fix another reference from PU to CU for odr
|
|
||||||
|
|
||||||
[ Backport of master commit f765cd9. ]
|
|
||||||
|
|
||||||
When using the test-case from PR27578 with --no-import-optimize, we run into:
|
|
||||||
...
|
|
||||||
$ dwz libvclplug_genlo.so.debug -o libvclplug_genlo.so.debug.z \
|
|
||||||
-lnone --odr --no-import-optimize
|
|
||||||
dwz: dwz.c:12700: write_die: \
|
|
||||||
Assertion `IMPLIES (cu->cu_kind == CU_PU, \
|
|
||||||
die_cu (refd)->cu_kind == CU_PU)' failed.
|
|
||||||
Aborted (core dumped)
|
|
||||||
...
|
|
||||||
|
|
||||||
The assert is triggered when trying to write out the reference to the DIE at
|
|
||||||
2f5e for DW_AT_type:
|
|
||||||
...
|
|
||||||
<1><2e8c>: Abbrev Number: 76 (DW_TAG_structure_type)
|
|
||||||
<2e8d> DW_AT_name : (indirect string, offset: 0x5f592): SalXLib
|
|
||||||
<2e91> DW_AT_byte_size : 320
|
|
||||||
...
|
|
||||||
<2><2ed9>: Abbrev Number: 22 (DW_TAG_member)
|
|
||||||
<2eda> DW_AT_name : (indirect string, offset: 0x56c9b): aReadFDS_
|
|
||||||
<2ede> DW_AT_decl_file : 33
|
|
||||||
<2edf> DW_AT_decl_line : 173
|
|
||||||
<2ee0> DW_AT_decl_column : 21
|
|
||||||
<2ee1> DW_AT_type : <0x2f5e>
|
|
||||||
<2ee5> DW_AT_data_member_location: 48
|
|
||||||
<2ee6> DW_AT_accessibility: 2 (protected)
|
|
||||||
...
|
|
||||||
|
|
||||||
The corresponding duplicate chain (with some annotations manually added) is:
|
|
||||||
...
|
|
||||||
duplicate chain:
|
|
||||||
Compilation Unit @ offset 0x44:
|
|
||||||
2d01 O 9f6a4268(29178f4e) 9f6a4268 SalXLib structure_type DECL
|
|
||||||
2e8c O 9f6a4268(87d059e8) 9f6a4268 SalXLib structure_type DEF
|
|
||||||
40a6 O 9f6a4268(87d059e8) 9f6a4268 SalXLib structure_type DEF
|
|
||||||
Compilation Unit @ offset 0xfaf6:
|
|
||||||
419be O 9f6a4268(29178f4e) 9f6a4268 SalXLib structure_type DECL
|
|
||||||
50e56 O 9f6a4268(29178f4e) 9f6a4268 SalXLib structure_type DECL
|
|
||||||
6063a O 9f6a4268(29178f4e) 9f6a4268 SalXLib structure_type DECL
|
|
||||||
Compilation Unit @ offset 0x1bb0f:
|
|
||||||
...
|
|
||||||
|
|
||||||
The duplicate chain is created by split_dups, which merged all the DECLs with
|
|
||||||
one duplicate chain containing only DEFs.
|
|
||||||
|
|
||||||
When doing the test for merged_singleton on this duplicate chain, it returns
|
|
||||||
NULL, because there are two DEFs. However, the DEFs are from the same CU, and
|
|
||||||
the type for aReadFDS_ is 0x2f5e for both DEFs. Consequently, there is no
|
|
||||||
duplicate chain for 0x2f5e, and we need to force a singleton duplicate chain.
|
|
||||||
|
|
||||||
Fix this by making merged_singleton return the first DEF.
|
|
||||||
|
|
||||||
2021-03-16 Tom de Vries <tdevries@suse.de>
|
|
||||||
|
|
||||||
PR dwz/27578
|
|
||||||
* dwz.c (merged_singleton): Handle DEFs in the same CU.
|
|
||||||
|
|
||||||
---
|
|
||||||
dwz.c | 7 ++++++-
|
|
||||||
1 file changed, 6 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/dwz.c b/dwz.c
|
|
||||||
index 5effbc1..fb7fbb1 100644
|
|
||||||
--- a/dwz.c
|
|
||||||
+++ b/dwz.c
|
|
||||||
@@ -8378,7 +8378,12 @@ merged_singleton (dw_die_ref die)
|
|
||||||
{
|
|
||||||
case ODR_DEF:
|
|
||||||
if (res)
|
|
||||||
- return NULL;
|
|
||||||
+ {
|
|
||||||
+ if (die_cu (res) == die_cu (d))
|
|
||||||
+ continue;
|
|
||||||
+ else
|
|
||||||
+ return NULL;
|
|
||||||
+ }
|
|
||||||
else
|
|
||||||
res = d;
|
|
||||||
break;
|
|
@ -1,107 +0,0 @@
|
|||||||
Handle reordered dup chains in create_import_tree
|
|
||||||
|
|
||||||
[ Backport of master commit 4e7ce44. ]
|
|
||||||
|
|
||||||
With the test-case from PR27578, we run into:
|
|
||||||
...
|
|
||||||
$ dwz libvclplug_genlo.so.debug -o libvclplug_genlo.so.debug.z \
|
|
||||||
-lnone --odr --devel-progress
|
|
||||||
create_import_tree phase 2
|
|
||||||
dwz: dwz.c:8833: remove_import_edges: Assertion `i == cucount' failed.
|
|
||||||
Aborted (core dumped)
|
|
||||||
...
|
|
||||||
|
|
||||||
Using --devel-verify-edges, we can trigger an assert earlier:
|
|
||||||
...
|
|
||||||
create_import_tree phase 1
|
|
||||||
dwz: dwz.c:8923: verify_edges_1: \
|
|
||||||
Assertion `count == 0 || e1->icu->idx > last_idx' failed.
|
|
||||||
Aborted (core dumped)
|
|
||||||
...
|
|
||||||
where e1->icu->idx == 201 and last_idx == 201.
|
|
||||||
|
|
||||||
The problem is (as we can see using --devel-dump-edges) that there's a
|
|
||||||
duplicate edge from CU 201 to PU 48:
|
|
||||||
...
|
|
||||||
idx: 48
|
|
||||||
cu: 0xbc
|
|
||||||
incoming: 200
|
|
||||||
incoming: 201
|
|
||||||
incoming: 201
|
|
||||||
incoming: 203
|
|
||||||
incoming: 204
|
|
||||||
incoming: 208
|
|
||||||
...
|
|
||||||
|
|
||||||
This can be traced back to this duplicate chain:
|
|
||||||
...
|
|
||||||
duplicate chain:
|
|
||||||
7fe2 O 2de8b1f3(fc1aa040) 2de8b1f3 Visual structure_type DECL
|
|
||||||
19d67 O 2de8b1f3(fc1aa040) 2de8b1f3 Visual structure_type DECL
|
|
||||||
2a7aa O 2de8b1f3(fc1aa040) 2de8b1f3 Visual structure_type DECL
|
|
||||||
41434 O 2de8b1f3(fc1aa040) 2de8b1f3 Visual structure_type DECL
|
|
||||||
Compilation Unit @ offset 0x5bf84:
|
|
||||||
5fd9d O 2de8b1f3(fc1aa040) 2de8b1f3 Visual structure_type DECL
|
|
||||||
611f5 O 2de8b1f3(deb4b00f) 2de8b1f3 Visual structure_type DEF
|
|
||||||
...
|
|
||||||
|
|
||||||
Since it starts with a DECL, it will be reordered such that the DEF is at
|
|
||||||
the start. However, that breaks the code in create_import_tree that checks
|
|
||||||
for duplicate chain members from the same CU, which assumes that those are
|
|
||||||
adjacent.
|
|
||||||
|
|
||||||
Fix this in create_import_tree.
|
|
||||||
|
|
||||||
2021-03-16 Tom de Vries <tdevries@suse.de>
|
|
||||||
|
|
||||||
PR dwz/27578
|
|
||||||
* dwz.c (create_import_tree): Handle reorder duplicate chain.
|
|
||||||
|
|
||||||
---
|
|
||||||
dwz.c | 18 ++++++++++++++++--
|
|
||||||
1 file changed, 16 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/dwz.c b/dwz.c
|
|
||||||
index fb7fbb1..481674f 100644
|
|
||||||
--- a/dwz.c
|
|
||||||
+++ b/dwz.c
|
|
||||||
@@ -9080,11 +9080,18 @@ create_import_tree (void)
|
|
||||||
ipu->cu = pu;
|
|
||||||
pu->u1.cu_icu = ipu;
|
|
||||||
assert (rdie->die_toplevel);
|
|
||||||
+ dw_die_ref firstdie = NULL;
|
|
||||||
+ dw_cu_ref firstdiecu = NULL;
|
|
||||||
for (die = rdie->die_nextdup, prev_cu = NULL;
|
|
||||||
die; die = die->die_nextdup)
|
|
||||||
{
|
|
||||||
dw_cu_ref diecu = die_cu (die);
|
|
||||||
- if (diecu == prev_cu)
|
|
||||||
+ if (firstdie == NULL)
|
|
||||||
+ {
|
|
||||||
+ firstdie = die;
|
|
||||||
+ firstdiecu = die_cu (firstdie);
|
|
||||||
+ }
|
|
||||||
+ if (diecu == prev_cu || (die != firstdie && diecu == firstdiecu))
|
|
||||||
continue;
|
|
||||||
ipu->incoming_count++;
|
|
||||||
size += 1 + (diecu->cu_version == 2 ? ptr_size : 4);
|
|
||||||
@@ -9094,11 +9101,18 @@ create_import_tree (void)
|
|
||||||
obstack_alloc (&ob2,
|
|
||||||
ipu->incoming_count
|
|
||||||
* sizeof (*ipu->incoming));
|
|
||||||
+ firstdie = NULL;
|
|
||||||
+ firstdiecu = NULL;
|
|
||||||
for (die = rdie->die_nextdup, i = 0, prev_cu = NULL;
|
|
||||||
die; die = die->die_nextdup)
|
|
||||||
{
|
|
||||||
dw_cu_ref diecu = die_cu (die);
|
|
||||||
- if (diecu == prev_cu)
|
|
||||||
+ if (firstdie == NULL)
|
|
||||||
+ {
|
|
||||||
+ firstdie = die;
|
|
||||||
+ firstdiecu = die_cu (firstdie);
|
|
||||||
+ }
|
|
||||||
+ if (diecu == prev_cu || (die != firstdie && diecu == firstdiecu))
|
|
||||||
continue;
|
|
||||||
icu = diecu->u1.cu_icu;
|
|
||||||
if (icu == NULL)
|
|
@ -1,13 +1,18 @@
|
|||||||
diff --git a/testsuite/dwz.tests/odr-struct-multifile.sh b/testsuite/dwz.tests/odr-struct-multifile.sh
|
diff --git a/testsuite/dwz.tests/odr-struct-multifile.sh b/testsuite/dwz.tests/odr-struct-multifile.sh
|
||||||
deleted file mode 100644
|
deleted file mode 100755
|
||||||
index cc462c9..0000000
|
index 5961abf..0000000
|
||||||
--- a/testsuite/dwz.tests/odr-struct-multifile.sh
|
--- a/testsuite/dwz.tests/odr-struct-multifile.sh
|
||||||
+++ /dev/null
|
+++ /dev/null
|
||||||
@@ -1,53 +0,0 @@
|
@@ -1,61 +0,0 @@
|
||||||
-if ! $execs/dwz-for-test --odr -v 2>/dev/null; then
|
-if ! $execs/dwz-for-test --odr -v 2>/dev/null; then
|
||||||
- exit 77
|
- exit 77
|
||||||
-fi
|
-fi
|
||||||
-
|
-
|
||||||
|
-readelf_flags=""
|
||||||
|
-if readelf -h 2>&1 | grep -q "\-wN"; then
|
||||||
|
- readelf_flags=-wN
|
||||||
|
-fi
|
||||||
|
-
|
||||||
-cp $execs/odr-struct 1
|
-cp $execs/odr-struct 1
|
||||||
-cp 1 2
|
-cp 1 2
|
||||||
-
|
-
|
||||||
@ -45,14 +50,17 @@ index cc462c9..0000000
|
|||||||
- [ $cnt -eq 1 ]
|
- [ $cnt -eq 1 ]
|
||||||
-done
|
-done
|
||||||
-
|
-
|
||||||
|
-# Even with -wN readelf 2.38-15.fc37 follows and prints the contents
|
||||||
|
-# of the alt file. So make sure it cannot do that by removing it.
|
||||||
|
-rm 3
|
||||||
-
|
-
|
||||||
-for name in aaa bbb ccc; do
|
-for name in aaa bbb ccc; do
|
||||||
- cnt=$(readelf -wi 1 | grep -c "DW_AT_name.*:.*$name" || true)
|
- cnt=$(readelf -wi $readelf_flags 1 | grep -c "DW_AT_name.*:.*$name" || true)
|
||||||
- [ $cnt -eq 0 ]
|
- [ $cnt -eq 0 ]
|
||||||
-done
|
-done
|
||||||
-
|
-
|
||||||
-for name in member_one member_two member_three member_four; do
|
-for name in member_one member_two member_three member_four; do
|
||||||
- cnt=$(readelf -wi 1 | grep -c "DW_AT_name.*:.*$name" || true)
|
- cnt=$(readelf -wi $readelf_flags 1 | grep -c "DW_AT_name.*:.*$name" || true)
|
||||||
- [ $cnt -eq 0 ]
|
- [ $cnt -eq 0 ]
|
||||||
-done
|
-done
|
||||||
-
|
-
|
||||||
|
@ -1,39 +0,0 @@
|
|||||||
[testsuite] Fix pr27463.sh on riscv64
|
|
||||||
|
|
||||||
On riscv64, I run into:
|
|
||||||
...
|
|
||||||
cc main.c unavailable-dwarf-piece-dw.S -o unavailable-dwarf-piece
|
|
||||||
unavailable-dwarf-piece-dw.S: Assembler messages:
|
|
||||||
unavailable-dwarf-piece-dw.S:24: Error: non-constant .uleb128 is not supported
|
|
||||||
...
|
|
||||||
make: *** [Makefile:100: unavailable-dwarf-piece] Error 1
|
|
||||||
...
|
|
||||||
|
|
||||||
Fix this similar to commit 53c0488 "[testsuite] Fix pr25109.sh on riscv64".
|
|
||||||
|
|
||||||
2021-03-17 Tom de Vries <tdevries@suse.de>
|
|
||||||
|
|
||||||
* Makefile (no-multifile-prop): Allow target rule to fail.
|
|
||||||
|
|
||||||
---
|
|
||||||
Makefile | 4 ++--
|
|
||||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/Makefile b/Makefile
|
|
||||||
index 2f7c76a..2990567 100644
|
|
||||||
--- a/Makefile
|
|
||||||
+++ b/Makefile
|
|
||||||
@@ -96,11 +96,11 @@ $(TEMP_ASM_FILES): %-dw.S: $(TEST_SRC)/../lib/%.exp
|
|
||||||
export DEJAGNU=$(DEJAGNU); \
|
|
||||||
runtest --tool=dwz -srcdir $(srcdir)/testsuite/ lib/$*.exp
|
|
||||||
|
|
||||||
-$(filter-out no-multifile-prop, $(TEST_EXECS_DWARF_ASM)): %: %-dw.S
|
|
||||||
+$(filter-out no-multifile-prop unavailable-dwarf-piece, $(TEST_EXECS_DWARF_ASM)): %: %-dw.S
|
|
||||||
$(CC) $(TEST_SRC)/main.c $< -o $@
|
|
||||||
|
|
||||||
# Fails to compile on riscv64: Error: non-constant .uleb128 is not supported.
|
|
||||||
-no-multifile-prop: %: %-dw.S
|
|
||||||
+no-multifile-prop unavailable-dwarf-piece: %: %-dw.S
|
|
||||||
$(CC) $(TEST_SRC)/main.c $< -o $@ || true
|
|
||||||
|
|
||||||
odr-struct:
|
|
@ -1,32 +0,0 @@
|
|||||||
From a57177980a05f0f84bf290ab7b68f73c0f78053f Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?Martin=20Li=C5=A1ka?= <mliska@suse.cz>
|
|
||||||
Date: Wed, 7 Sep 2022 21:55:03 +0200
|
|
||||||
Subject: [PATCH] Use grep -E instead of egrep.
|
|
||||||
|
|
||||||
egrep is obsoleted starting with GNU Grep 3.8.
|
|
||||||
diff --git a/contrib/bytes-per-die.sh b/contrib/bytes-per-die.sh
|
|
||||||
index 969f733..fda8998 100755
|
|
||||||
--- a/contrib/bytes-per-die.sh
|
|
||||||
+++ b/contrib/bytes-per-die.sh
|
|
||||||
@@ -3,7 +3,7 @@
|
|
||||||
f="$1"
|
|
||||||
|
|
||||||
size=$(readelf -WS "$f" \
|
|
||||||
- | egrep "[ \t]\.debug_info" \
|
|
||||||
+ | grep -E "[ \t]\.debug_info" \
|
|
||||||
| sed 's/.*\.debug_info//' \
|
|
||||||
| awk '{print $4}')
|
|
||||||
size=$((16#$size))
|
|
||||||
diff --git a/testsuite/dwz.tests/two-files-low-mem-die-limit-0.sh b/testsuite/dwz.tests/two-files-low-mem-die-limit-0.sh
|
|
||||||
index 7f1e174..71d8518 100644
|
|
||||||
--- a/testsuite/dwz.tests/two-files-low-mem-die-limit-0.sh
|
|
||||||
+++ b/testsuite/dwz.tests/two-files-low-mem-die-limit-0.sh
|
|
||||||
@@ -7,7 +7,7 @@ $execs/dwz-for-test \
|
|
||||||
1 2 \
|
|
||||||
2> dwz.err
|
|
||||||
|
|
||||||
-if egrep -q "Compressing (1|2)$" dwz.err; then
|
|
||||||
+if grep -Eq "Compressing (1|2)$" dwz.err; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
20
dwz.changes
20
dwz.changes
@ -1,3 +1,23 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Mon Nov 7 08:09:38 UTC 2022 - Martin Liška <mliska@suse.cz>
|
||||||
|
|
||||||
|
- Update to 0.15 release:
|
||||||
|
* Uses xxHash hashing algorithm. A 8% ~ 14% speedup.
|
||||||
|
* Set endianity of multifile using -e, --multifile-endian.
|
||||||
|
* Set pointer size of multifile using -p, --multifile-pointer-size
|
||||||
|
* Process files in parallel using -j N --jobs N. The default is
|
||||||
|
processors / 2. Disabled when multifile is used.
|
||||||
|
* Prints abbrev or DIE offset for Unknown DWARF error messages.
|
||||||
|
* All testcases have been updated to work against the binutils 2.39.
|
||||||
|
- Remove upstreamed patches:
|
||||||
|
* dwz-fix-another-reference-from-pu-to-cu-for-odr.patch
|
||||||
|
* dwz-handle-reordered-dup-chains-in-create-import-tree.patch
|
||||||
|
* dwz-testsuite-fix-pr27463.sh-on-riscv64.patch
|
||||||
|
* dwz-use-grep-E-instead-of-egrep.patch
|
||||||
|
- Rebased patches:
|
||||||
|
* dwz-remove-odr-struct-multifile.sh.patch
|
||||||
|
* dwz-enable-odr-by-default.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Thu Sep 8 17:53:27 UTC 2022 - Martin Liška <mliska@suse.cz>
|
Thu Sep 8 17:53:27 UTC 2022 - Martin Liška <mliska@suse.cz>
|
||||||
|
|
||||||
|
15
dwz.spec
15
dwz.spec
@ -42,7 +42,7 @@ ExclusiveArch: do_not_build
|
|||||||
%endif
|
%endif
|
||||||
|
|
||||||
Name: dwz%{name_suffix}
|
Name: dwz%{name_suffix}
|
||||||
Version: 0.14
|
Version: 0.15
|
||||||
Release: 0
|
Release: 0
|
||||||
%if %{build_main}
|
%if %{build_main}
|
||||||
Summary: DWARF optimization and duplicate removal tool
|
Summary: DWARF optimization and duplicate removal tool
|
||||||
@ -60,6 +60,7 @@ Source: dwz-%{version}.tar.xz
|
|||||||
URL: https://sourceware.org/dwz/
|
URL: https://sourceware.org/dwz/
|
||||||
BuildRequires: gcc-c++
|
BuildRequires: gcc-c++
|
||||||
BuildRequires: libelf-devel
|
BuildRequires: libelf-devel
|
||||||
|
BuildRequires: xxhash-devel
|
||||||
BuildRequires: xz
|
BuildRequires: xz
|
||||||
%if %{build_testsuite}
|
%if %{build_testsuite}
|
||||||
BuildRequires: dejagnu
|
BuildRequires: dejagnu
|
||||||
@ -78,12 +79,8 @@ NoSource: 0
|
|||||||
Source1: dwz-rpmlintrc
|
Source1: dwz-rpmlintrc
|
||||||
Source2: tramp3d-v4.cpp.xz
|
Source2: tramp3d-v4.cpp.xz
|
||||||
|
|
||||||
Patch1: dwz-fix-another-reference-from-pu-to-cu-for-odr.patch
|
Patch1: dwz-enable-odr-by-default.patch
|
||||||
Patch2: dwz-handle-reordered-dup-chains-in-create-import-tree.patch
|
Patch2: dwz-remove-odr-struct-multifile.sh.patch
|
||||||
Patch3: dwz-enable-odr-by-default.patch
|
|
||||||
Patch4: dwz-testsuite-fix-pr27463.sh-on-riscv64.patch
|
|
||||||
Patch5: dwz-remove-odr-struct-multifile.sh.patch
|
|
||||||
Patch6: dwz-use-grep-E-instead-of-egrep.patch
|
|
||||||
|
|
||||||
%if %{build_main}
|
%if %{build_main}
|
||||||
%description
|
%description
|
||||||
@ -114,10 +111,6 @@ This package contains the testsuite results from DWZ.
|
|||||||
%setup -q -n dwz
|
%setup -q -n dwz
|
||||||
%patch1 -p1
|
%patch1 -p1
|
||||||
%patch2 -p1
|
%patch2 -p1
|
||||||
%patch3 -p1
|
|
||||||
%patch4 -p1
|
|
||||||
%patch5 -p1
|
|
||||||
%patch6 -p1
|
|
||||||
cp ../../SOURCES/tramp3d-v4.cpp.xz .
|
cp ../../SOURCES/tramp3d-v4.cpp.xz .
|
||||||
xz -d tramp3d-v4.cpp.xz
|
xz -d tramp3d-v4.cpp.xz
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user