elfutils 0.182
This commit is contained in:
parent
6f09752649
commit
cc0257826c
1
.gitignore
vendored
1
.gitignore
vendored
@ -22,3 +22,4 @@
|
||||
/elfutils-0.179.tar.bz2
|
||||
/elfutils-0.180.tar.bz2
|
||||
/elfutils-0.181.tar.bz2
|
||||
/elfutils-0.182.tar.bz2
|
||||
|
@ -1,472 +0,0 @@
|
||||
commit 09b034419ef16cf39abcd7a2df9d0fe704176d13
|
||||
Author: Mark Wielaard <mark@klomp.org>
|
||||
Date: Sat Oct 17 21:22:22 2020 +0200
|
||||
|
||||
libebl: Remove unused ebl_syscall_abi.
|
||||
|
||||
GCC11 -Warray-parameter warned about ebl_syscall_abi being inconsistently
|
||||
declared (once with a pointer to int, once with an array of 6 int elements).
|
||||
Since ebl_syscall_abi isn't actually used and was only implemented for
|
||||
3 backends without any tests just remove it.
|
||||
|
||||
Signed-off-by: Mark Wielaard <mark@klomp.org>
|
||||
|
||||
diff --git a/backends/Makefile.am b/backends/Makefile.am
|
||||
index f4052125..3849f457 100644
|
||||
--- a/backends/Makefile.am
|
||||
+++ b/backends/Makefile.am
|
||||
@@ -40,13 +40,13 @@ modules = i386 sh x86_64 ia64 alpha arm aarch64 sparc ppc ppc64 s390 \
|
||||
tilegx m68k bpf riscv csky
|
||||
|
||||
i386_SRCS = i386_init.c i386_symbol.c i386_corenote.c i386_cfi.c \
|
||||
- i386_retval.c i386_regs.c i386_auxv.c i386_syscall.c \
|
||||
+ i386_retval.c i386_regs.c i386_auxv.c \
|
||||
i386_initreg.c i386_unwind.c
|
||||
|
||||
sh_SRCS = sh_init.c sh_symbol.c sh_corenote.c sh_regs.c sh_retval.c
|
||||
|
||||
x86_64_SRCS = x86_64_init.c x86_64_symbol.c x86_64_corenote.c x86_64_cfi.c \
|
||||
- x86_64_retval.c x86_64_regs.c x86_64_syscall.c x86_64_initreg.c \
|
||||
+ x86_64_retval.c x86_64_regs.c x86_64_initreg.c \
|
||||
x86_64_unwind.c x32_corenote.c
|
||||
|
||||
|
||||
@@ -67,7 +67,7 @@ sparc_SRCS = sparc_init.c sparc_symbol.c sparc_regs.c sparc_retval.c \
|
||||
sparc_cfi.c sparc_initreg.c
|
||||
|
||||
ppc_SRCS = ppc_init.c ppc_symbol.c ppc_retval.c ppc_regs.c \
|
||||
- ppc_corenote.c ppc_auxv.c ppc_attrs.c ppc_syscall.c \
|
||||
+ ppc_corenote.c ppc_auxv.c ppc_attrs.c \
|
||||
ppc_cfi.c ppc_initreg.c
|
||||
|
||||
ppc64_SRCS = ppc64_init.c ppc64_symbol.c ppc64_retval.c ppc64_corenote.c \
|
||||
diff --git a/backends/i386_init.c b/backends/i386_init.c
|
||||
index 3f6b9ed1..579e5fad 100644
|
||||
--- a/backends/i386_init.c
|
||||
+++ b/backends/i386_init.c
|
||||
@@ -52,7 +52,6 @@ i386_init (Elf *elf __attribute__ ((unused)),
|
||||
HOOK (eh, debugscn_p);
|
||||
HOOK (eh, return_value_location);
|
||||
HOOK (eh, register_info);
|
||||
- HOOK (eh, syscall_abi);
|
||||
HOOK (eh, auxv_info);
|
||||
HOOK (eh, disasm);
|
||||
HOOK (eh, abi_cfi);
|
||||
diff --git a/backends/i386_syscall.c b/backends/i386_syscall.c
|
||||
deleted file mode 100644
|
||||
index 535dcd86..00000000
|
||||
--- a/backends/i386_syscall.c
|
||||
+++ /dev/null
|
||||
@@ -1,50 +0,0 @@
|
||||
-/* Linux/i386 system call ABI in DWARF register numbers.
|
||||
- Copyright (C) 2008 Red Hat, Inc.
|
||||
- This file is part of elfutils.
|
||||
-
|
||||
- This file is free software; you can redistribute it and/or modify
|
||||
- it under the terms of either
|
||||
-
|
||||
- * the GNU Lesser General Public License as published by the Free
|
||||
- Software Foundation; either version 3 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or
|
||||
-
|
||||
- * the GNU General Public License as published by the Free
|
||||
- Software Foundation; either version 2 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or both in parallel, as here.
|
||||
-
|
||||
- elfutils is distributed in the hope that it will be useful, but
|
||||
- WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
- General Public License for more details.
|
||||
-
|
||||
- You should have received copies of the GNU General Public License and
|
||||
- the GNU Lesser General Public License along with this program. If
|
||||
- not, see <http://www.gnu.org/licenses/>. */
|
||||
-
|
||||
-#ifdef HAVE_CONFIG_H
|
||||
-# include <config.h>
|
||||
-#endif
|
||||
-
|
||||
-#define BACKEND i386_
|
||||
-#include "libebl_CPU.h"
|
||||
-
|
||||
-int
|
||||
-i386_syscall_abi (Ebl *ebl __attribute__ ((unused)),
|
||||
- int *sp, int *pc, int *callno, int args[6])
|
||||
-{
|
||||
- *sp = 4; /* %esp */
|
||||
- *pc = 8; /* %eip */
|
||||
- *callno = 0; /* %eax */
|
||||
- args[0] = 3; /* %ebx */
|
||||
- args[1] = 1; /* %ecx */
|
||||
- args[2] = 2; /* %edx */
|
||||
- args[3] = 6; /* %esi */
|
||||
- args[4] = 7; /* %edi */
|
||||
- args[5] = 5; /* %ebp */
|
||||
- return 0;
|
||||
-}
|
||||
diff --git a/backends/ppc64_init.c b/backends/ppc64_init.c
|
||||
index f509aef6..ffc9842c 100644
|
||||
--- a/backends/ppc64_init.c
|
||||
+++ b/backends/ppc64_init.c
|
||||
@@ -58,7 +58,6 @@ ppc64_init (Elf *elf __attribute__ ((unused)),
|
||||
HOOK (eh, bss_plt_p);
|
||||
HOOK (eh, return_value_location);
|
||||
HOOK (eh, register_info);
|
||||
- HOOK (eh, syscall_abi);
|
||||
HOOK (eh, core_note);
|
||||
HOOK (eh, auxv_info);
|
||||
HOOK (eh, check_object_attribute);
|
||||
diff --git a/backends/ppc_init.c b/backends/ppc_init.c
|
||||
index ac440ab2..08468f8f 100644
|
||||
--- a/backends/ppc_init.c
|
||||
+++ b/backends/ppc_init.c
|
||||
@@ -54,7 +54,6 @@ ppc_init (Elf *elf __attribute__ ((unused)),
|
||||
HOOK (eh, bss_plt_p);
|
||||
HOOK (eh, return_value_location);
|
||||
HOOK (eh, register_info);
|
||||
- HOOK (eh, syscall_abi);
|
||||
HOOK (eh, core_note);
|
||||
HOOK (eh, auxv_info);
|
||||
HOOK (eh, check_object_attribute);
|
||||
diff --git a/backends/ppc_syscall.c b/backends/ppc_syscall.c
|
||||
deleted file mode 100644
|
||||
index b1b9c52b..00000000
|
||||
--- a/backends/ppc_syscall.c
|
||||
+++ /dev/null
|
||||
@@ -1,53 +0,0 @@
|
||||
-/* Linux/PPC system call ABI in DWARF register numbers.
|
||||
- Copyright (C) 2008 Red Hat, Inc.
|
||||
- This file is part of elfutils.
|
||||
-
|
||||
- This file is free software; you can redistribute it and/or modify
|
||||
- it under the terms of either
|
||||
-
|
||||
- * the GNU Lesser General Public License as published by the Free
|
||||
- Software Foundation; either version 3 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or
|
||||
-
|
||||
- * the GNU General Public License as published by the Free
|
||||
- Software Foundation; either version 2 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or both in parallel, as here.
|
||||
-
|
||||
- elfutils is distributed in the hope that it will be useful, but
|
||||
- WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
- General Public License for more details.
|
||||
-
|
||||
- You should have received copies of the GNU General Public License and
|
||||
- the GNU Lesser General Public License along with this program. If
|
||||
- not, see <http://www.gnu.org/licenses/>. */
|
||||
-
|
||||
-#ifdef HAVE_CONFIG_H
|
||||
-# include <config.h>
|
||||
-#endif
|
||||
-
|
||||
-#define BACKEND ppc_
|
||||
-#include "libebl_CPU.h"
|
||||
-
|
||||
-int
|
||||
-ppc_syscall_abi (Ebl *ebl __attribute__ ((unused)),
|
||||
- int *sp, int *pc, int *callno, int args[6])
|
||||
-{
|
||||
- *sp = 1;
|
||||
- *pc = -1;
|
||||
- *callno = 0;
|
||||
- args[0] = 3;
|
||||
- args[1] = 4;
|
||||
- args[2] = 5;
|
||||
- args[3] = 6;
|
||||
- args[4] = 7;
|
||||
- args[5] = 8;
|
||||
- return 0;
|
||||
-}
|
||||
-
|
||||
-__typeof (ppc_syscall_abi)
|
||||
-ppc64_syscall_abi __attribute__ ((alias ("ppc_syscall_abi")));
|
||||
diff --git a/backends/x86_64_init.c b/backends/x86_64_init.c
|
||||
index 44c1ad28..8db9b643 100644
|
||||
--- a/backends/x86_64_init.c
|
||||
+++ b/backends/x86_64_init.c
|
||||
@@ -56,7 +56,6 @@ x86_64_init (Elf *elf __attribute__ ((unused)),
|
||||
HOOK (eh, core_note);
|
||||
HOOK (eh, return_value_location);
|
||||
HOOK (eh, register_info);
|
||||
- HOOK (eh, syscall_abi);
|
||||
HOOK (eh, auxv_info);
|
||||
HOOK (eh, disasm);
|
||||
HOOK (eh, abi_cfi);
|
||||
diff --git a/backends/x86_64_syscall.c b/backends/x86_64_syscall.c
|
||||
deleted file mode 100644
|
||||
index 0deb8bad..00000000
|
||||
--- a/backends/x86_64_syscall.c
|
||||
+++ /dev/null
|
||||
@@ -1,50 +0,0 @@
|
||||
-/* Linux/x86-64 system call ABI in DWARF register numbers.
|
||||
- Copyright (C) 2008 Red Hat, Inc.
|
||||
- This file is part of elfutils.
|
||||
-
|
||||
- This file is free software; you can redistribute it and/or modify
|
||||
- it under the terms of either
|
||||
-
|
||||
- * the GNU Lesser General Public License as published by the Free
|
||||
- Software Foundation; either version 3 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or
|
||||
-
|
||||
- * the GNU General Public License as published by the Free
|
||||
- Software Foundation; either version 2 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or both in parallel, as here.
|
||||
-
|
||||
- elfutils is distributed in the hope that it will be useful, but
|
||||
- WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
- General Public License for more details.
|
||||
-
|
||||
- You should have received copies of the GNU General Public License and
|
||||
- the GNU Lesser General Public License along with this program. If
|
||||
- not, see <http://www.gnu.org/licenses/>. */
|
||||
-
|
||||
-#ifdef HAVE_CONFIG_H
|
||||
-# include <config.h>
|
||||
-#endif
|
||||
-
|
||||
-#define BACKEND x86_64_
|
||||
-#include "libebl_CPU.h"
|
||||
-
|
||||
-int
|
||||
-x86_64_syscall_abi (Ebl *ebl __attribute__ ((unused)),
|
||||
- int *sp, int *pc, int *callno, int args[6])
|
||||
-{
|
||||
- *sp = 7; /* %rsp */
|
||||
- *pc = 16; /* %rip */
|
||||
- *callno = 0; /* %rax */
|
||||
- args[0] = 5; /* %rdi */
|
||||
- args[1] = 4; /* %rsi */
|
||||
- args[2] = 1; /* %rdx */
|
||||
- args[3] = 10; /* %r10 */
|
||||
- args[4] = 8; /* %r8 */
|
||||
- args[5] = 9; /* %r9 */
|
||||
- return 0;
|
||||
-}
|
||||
diff --git a/libebl/Makefile.am b/libebl/Makefile.am
|
||||
index d0d475b8..d84e7ee2 100644
|
||||
--- a/libebl/Makefile.am
|
||||
+++ b/libebl/Makefile.am
|
||||
@@ -51,7 +51,7 @@ libebl_a_SOURCES = eblopenbackend.c eblclosebackend.c eblreloctypename.c \
|
||||
eblbsspltp.c eblretval.c eblreginfo.c eblnonerelocp.c \
|
||||
eblrelativerelocp.c eblsysvhashentrysize.c eblauxvinfo.c \
|
||||
eblcheckobjattr.c ebl_check_special_section.c \
|
||||
- ebl_syscall_abi.c eblabicfi.c eblstother.c eblinitreg.c \
|
||||
+ eblabicfi.c eblstother.c eblinitreg.c \
|
||||
ebldwarftoregno.c eblnormalizepc.c eblunwind.c \
|
||||
eblresolvesym.c eblcheckreloctargettype.c \
|
||||
ebl_data_marker_symbol.c
|
||||
diff --git a/libebl/ebl-hooks.h b/libebl/ebl-hooks.h
|
||||
index 1e7960b8..1214bb84 100644
|
||||
--- a/libebl/ebl-hooks.h
|
||||
+++ b/libebl/ebl-hooks.h
|
||||
@@ -142,10 +142,6 @@ ssize_t EBLHOOK(register_info) (Ebl *ebl,
|
||||
const char **prefix, const char **setname,
|
||||
int *bits, int *type);
|
||||
|
||||
-/* Return system call ABI registers. */
|
||||
-int EBLHOOK(syscall_abi) (Ebl *ebl, int *sp, int *pc,
|
||||
- int *callno, int args[6]);
|
||||
-
|
||||
/* Disassembler function. */
|
||||
int EBLHOOK(disasm) (Ebl *ebl, const uint8_t **startp, const uint8_t *end,
|
||||
GElf_Addr addr, const char *fmt, DisasmOutputCB_t outcb,
|
||||
diff --git a/libebl/ebl_syscall_abi.c b/libebl/ebl_syscall_abi.c
|
||||
deleted file mode 100644
|
||||
index a25369d2..00000000
|
||||
--- a/libebl/ebl_syscall_abi.c
|
||||
+++ /dev/null
|
||||
@@ -1,40 +0,0 @@
|
||||
-/* Return system call ABI mapped to DWARF register numbers.
|
||||
- Copyright (C) 2008 Red Hat, Inc.
|
||||
- This file is part of elfutils.
|
||||
-
|
||||
- This file is free software; you can redistribute it and/or modify
|
||||
- it under the terms of either
|
||||
-
|
||||
- * the GNU Lesser General Public License as published by the Free
|
||||
- Software Foundation; either version 3 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or
|
||||
-
|
||||
- * the GNU General Public License as published by the Free
|
||||
- Software Foundation; either version 2 of the License, or (at
|
||||
- your option) any later version
|
||||
-
|
||||
- or both in parallel, as here.
|
||||
-
|
||||
- elfutils is distributed in the hope that it will be useful, but
|
||||
- WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
- General Public License for more details.
|
||||
-
|
||||
- You should have received copies of the GNU General Public License and
|
||||
- the GNU Lesser General Public License along with this program. If
|
||||
- not, see <http://www.gnu.org/licenses/>. */
|
||||
-
|
||||
-#ifdef HAVE_CONFIG_H
|
||||
-# include <config.h>
|
||||
-#endif
|
||||
-
|
||||
-#include <libeblP.h>
|
||||
-
|
||||
-
|
||||
-int
|
||||
-ebl_syscall_abi (Ebl *ebl, int *sp, int *pc, int *callno, int *args)
|
||||
-{
|
||||
- return ebl != NULL ? ebl->syscall_abi (ebl, sp, pc, callno, args) : -1;
|
||||
-}
|
||||
diff --git a/libebl/eblopenbackend.c b/libebl/eblopenbackend.c
|
||||
index b3b6fc01..90a83f26 100644
|
||||
--- a/libebl/eblopenbackend.c
|
||||
+++ b/libebl/eblopenbackend.c
|
||||
@@ -214,8 +214,6 @@ static ssize_t default_register_info (Ebl *ebl,
|
||||
const char **prefix,
|
||||
const char **setname,
|
||||
int *bits, int *type);
|
||||
-static int default_syscall_abi (Ebl *ebl, int *sp, int *pc,
|
||||
- int *callno, int args[6]);
|
||||
static bool default_check_object_attribute (Ebl *ebl, const char *vendor,
|
||||
int tag, uint64_t value,
|
||||
const char **tag_name,
|
||||
@@ -259,7 +257,6 @@ fill_defaults (Ebl *result)
|
||||
result->bss_plt_p = default_bss_plt_p;
|
||||
result->return_value_location = default_return_value_location;
|
||||
result->register_info = default_register_info;
|
||||
- result->syscall_abi = default_syscall_abi;
|
||||
result->check_object_attribute = default_check_object_attribute;
|
||||
result->check_reloc_target_type = default_check_reloc_target_type;
|
||||
result->disasm = NULL;
|
||||
@@ -690,20 +687,6 @@ default_register_info (Ebl *ebl __attribute__ ((unused)),
|
||||
return snprintf (name, namelen, "reg%d", regno);
|
||||
}
|
||||
|
||||
-static int
|
||||
-default_syscall_abi (Ebl *ebl __attribute__ ((unused)),
|
||||
- int *sp, int *pc, int *callno, int args[6])
|
||||
-{
|
||||
- *sp = *pc = *callno = -1;
|
||||
- args[0] = -1;
|
||||
- args[1] = -1;
|
||||
- args[2] = -1;
|
||||
- args[3] = -1;
|
||||
- args[4] = -1;
|
||||
- args[5] = -1;
|
||||
- return -1;
|
||||
-}
|
||||
-
|
||||
static bool
|
||||
default_check_object_attribute (Ebl *ebl __attribute__ ((unused)),
|
||||
const char *vendor __attribute__ ((unused)),
|
||||
diff --git a/libebl/libebl.h b/libebl/libebl.h
|
||||
index 23c0e950..731001d3 100644
|
||||
--- a/libebl/libebl.h
|
||||
+++ b/libebl/libebl.h
|
||||
@@ -241,14 +241,6 @@ extern ssize_t ebl_register_info (Ebl *ebl,
|
||||
const char **prefix, const char **setname,
|
||||
int *bits, int *type);
|
||||
|
||||
-/* Fill in the DWARF register numbers for the registers used in system calls.
|
||||
- The SP and PC are what kernel reports call the user stack pointer and PC.
|
||||
- The CALLNO and ARGS are the system call number and incoming arguments.
|
||||
- Each of these is filled with the DWARF register number corresponding,
|
||||
- or -1 if there is none. Returns zero when the information is available. */
|
||||
-extern int ebl_syscall_abi (Ebl *ebl, int *sp, int *pc,
|
||||
- int *callno, int args[6]);
|
||||
-
|
||||
/* Supply the ABI-specified state of DWARF CFI before CIE initial programs.
|
||||
|
||||
The DWARF 3.0 spec says that the default initial states of all registers
|
||||
commit 4b2edc1161e6786b09b65da3a62ef24078324d4c
|
||||
Author: Mark Wielaard <mark@klomp.org>
|
||||
Date: Mon Oct 19 10:17:59 2020 +0200
|
||||
|
||||
libdw: dwarf_frame_register takes an array of at least 3 Dwarf_Ops
|
||||
|
||||
GCC11 will warn about a mismatch in the declaration of dwarf_frame_register:
|
||||
|
||||
dwarf_frame_register.c:37:61: error: argument 3 of type ‘Dwarf_Op *’
|
||||
declared as a pointer [-Werror=array-parameter=]
|
||||
37 | dwarf_frame_register (Dwarf_Frame *fs, int regno, Dwarf_Op *ops_mem,
|
||||
| ~~~~~~~~~~^~~~~~~
|
||||
libdw.h:1068:43: note: previously declared as an array ‘Dwarf_Op[3]’
|
||||
1068 | Dwarf_Op ops_mem[3],
|
||||
| ~~~~~~~~~^~~~~~~~~~
|
||||
|
||||
When fixing that it will show an actual bug in the addrcfi testcase:
|
||||
|
||||
addrcfi.c:98:16: error: ‘dwarf_frame_register’ accessing 96 bytes in a
|
||||
region of size 64 [-Werror=stringop-overflow=]
|
||||
98 | int result = dwarf_frame_register (stuff->frame, regno, ops_mem, &ops, &nops);
|
||||
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
addrcfi.c:98:16: note: referencing argument 3 of type ‘Dwarf_Op *’
|
||||
1069 | extern int dwarf_frame_register (Dwarf_Frame *frame, int regno,
|
||||
| ^~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
Fix the declaration, fix the bug and add an extra comment to the description
|
||||
in libdw.h.
|
||||
|
||||
Signed-off-by: Mark Wielaard <mark@klomp.org>
|
||||
|
||||
diff --git a/libdw/dwarf_frame_register.c b/libdw/dwarf_frame_register.c
|
||||
index d0159fb8..bcf3fa03 100644
|
||||
--- a/libdw/dwarf_frame_register.c
|
||||
+++ b/libdw/dwarf_frame_register.c
|
||||
@@ -34,7 +34,7 @@
|
||||
#include <dwarf.h>
|
||||
|
||||
int
|
||||
-dwarf_frame_register (Dwarf_Frame *fs, int regno, Dwarf_Op *ops_mem,
|
||||
+dwarf_frame_register (Dwarf_Frame *fs, int regno, Dwarf_Op ops_mem[3],
|
||||
Dwarf_Op **ops, size_t *nops)
|
||||
{
|
||||
/* Maybe there was a previous error. */
|
||||
diff --git a/libdw/libdw.h b/libdw/libdw.h
|
||||
index 1a4e15a1..ad4fa6ea 100644
|
||||
--- a/libdw/libdw.h
|
||||
+++ b/libdw/libdw.h
|
||||
@@ -1061,9 +1061,11 @@ extern int dwarf_frame_cfa (Dwarf_Frame *frame, Dwarf_Op **ops, size_t *nops)
|
||||
caller's REGNO is "same_value", i.e. this frame did not change it;
|
||||
ask the caller frame where to find it.
|
||||
|
||||
- For common simple expressions *OPS is OPS_MEM. For arbitrary DWARF
|
||||
- expressions in the CFI, *OPS is an internal pointer that can be used as
|
||||
- long as the Dwarf_CFI used to create FRAME remains alive. */
|
||||
+ For common simple expressions *OPS is OPS_MEM (which is a caller
|
||||
+ owned array for for at least 3 Dwarf_Ops). For arbitrary DWARF
|
||||
+ expressions in the CFI, *OPS is an internal pointer that can be
|
||||
+ used as long as the Dwarf_CFI used to create FRAME remains
|
||||
+ alive. */
|
||||
extern int dwarf_frame_register (Dwarf_Frame *frame, int regno,
|
||||
Dwarf_Op ops_mem[3],
|
||||
Dwarf_Op **ops, size_t *nops)
|
||||
diff --git a/tests/addrcfi.c b/tests/addrcfi.c
|
||||
index 589b8513..2b7d7bd0 100644
|
||||
--- a/tests/addrcfi.c
|
||||
+++ b/tests/addrcfi.c
|
||||
@@ -92,7 +92,7 @@ print_register (void *arg,
|
||||
|
||||
printf ("\t%s reg%u (%s%s): ", setname, regno, prefix, regname);
|
||||
|
||||
- Dwarf_Op ops_mem[2];
|
||||
+ Dwarf_Op ops_mem[3];
|
||||
Dwarf_Op *ops;
|
||||
size_t nops;
|
||||
int result = dwarf_frame_register (stuff->frame, regno, ops_mem, &ops, &nops);
|
@ -1,348 +0,0 @@
|
||||
commit c5b0a640f0f7d2a195b822bcd88bb379476dbb97
|
||||
Author: Mark Wielaard <mark@klomp.org>
|
||||
Date: Fri Sep 18 12:49:29 2020 +0200
|
||||
|
||||
zstd support
|
||||
|
||||
diff --git a/config/elfutils.spec.in b/config/elfutils.spec.in
|
||||
index 95f63f5a..37af1b07 100644
|
||||
--- a/config/elfutils.spec.in
|
||||
+++ b/config/elfutils.spec.in
|
||||
@@ -24,6 +24,7 @@ BuildRequires: flex
|
||||
BuildRequires: zlib-devel
|
||||
BuildRequires: bzip2-devel
|
||||
BuildRequires: xz-devel
|
||||
+BuildRequires: libzstd-devel
|
||||
|
||||
# For debuginfod
|
||||
BuildRequires: pkgconfig(libmicrohttpd) >= 0.9.33
|
||||
@@ -33,6 +34,7 @@ BuildRequires: pkgconfig(libarchive) >= 3.1.2
|
||||
|
||||
# For tests need to bunzip2 test files.
|
||||
BuildRequires: bzip2
|
||||
+BuildRequires: zstd
|
||||
# For the run-debuginfod-find.sh test case in %check for /usr/sbin/ss
|
||||
BuildRequires: iproute
|
||||
BuildRequires: bsdtar
|
||||
diff --git a/config/libdw.pc.in b/config/libdw.pc.in
|
||||
index 3fc283db..2e83a432 100644
|
||||
--- a/config/libdw.pc.in
|
||||
+++ b/config/libdw.pc.in
|
||||
@@ -17,6 +17,6 @@ Requires: libelf = @VERSION@
|
||||
|
||||
# We support various compressed ELF images, but don't export any of the
|
||||
# data structures or functions. zlib (gz) is always required, bzip2 (bz2)
|
||||
-# and lzma (xz) are optional. But bzip2 doesn't have a pkg-config file.
|
||||
-Requires.private: zlib @LIBLZMA@
|
||||
+# lzma (xz) and zstd () are optional. But bzip2 doesn't have a pkg-config file.
|
||||
+Requires.private: zlib @LIBLZMA@ @LIBZSTD@
|
||||
Libs.private: @BZ2_LIB@
|
||||
diff --git a/configure.ac b/configure.ac
|
||||
index bf833872..1b794df3 100644
|
||||
--- a/configure.ac
|
||||
+++ b/configure.ac
|
||||
@@ -397,8 +397,8 @@ eu_ZIPLIB(zlib,ZLIB,z,gzdirect,gzip)
|
||||
AS_IF([test "x$with_zlib" = xno], [AC_MSG_ERROR([zlib not found but is required])])
|
||||
LIBS="$save_LIBS"
|
||||
|
||||
-dnl Test for bzlib and xz/lzma, gives BZLIB/LZMALIB .am
|
||||
-dnl conditional and config.h USE_BZLIB/USE_LZMALIB #define.
|
||||
+dnl Test for bzlib and xz/lzma/zstd, gives BZLIB/LZMALIB/ZSTD .am
|
||||
+dnl conditional and config.h USE_BZLIB/USE_LZMALIB/USE_ZSTD #define.
|
||||
save_LIBS="$LIBS"
|
||||
LIBS=
|
||||
eu_ZIPLIB(bzlib,BZLIB,bz2,BZ2_bzdopen,bzip2)
|
||||
@@ -408,6 +408,9 @@ AC_SUBST([BZ2_LIB])
|
||||
eu_ZIPLIB(lzma,LZMA,lzma,lzma_auto_decoder,[LZMA (xz)])
|
||||
AS_IF([test "x$with_lzma" = xyes], [LIBLZMA="liblzma"], [LIBLZMA=""])
|
||||
AC_SUBST([LIBLZMA])
|
||||
+eu_ZIPLIB(zstd,ZSTD,zstd,ZSTD_decompress,[ZSTD (zst)])
|
||||
+AS_IF([test "x$with_zstd" = xyes], [LIBZSTD="libzstd"], [LIBLZSTD=""])
|
||||
+AC_SUBST([LIBZSTD])
|
||||
zip_LIBS="$LIBS"
|
||||
LIBS="$save_LIBS"
|
||||
AC_SUBST([zip_LIBS])
|
||||
@@ -677,6 +680,10 @@ if test "$HAVE_BUNZIP2" = "no"; then
|
||||
AC_MSG_WARN([No bunzip2, needed to run make check])
|
||||
fi
|
||||
|
||||
+# For tests that need to use zstd compression
|
||||
+AC_CHECK_PROG(HAVE_ZSTD, zstd, yes, no)
|
||||
+AM_CONDITIONAL([HAVE_ZSTD],[test "x$HAVE_ZSTD" = "xyes"])
|
||||
+
|
||||
# Look for libcurl for libdebuginfod minimum version as per rhel7.
|
||||
AC_ARG_ENABLE([libdebuginfod],AC_HELP_STRING([--enable-libdebuginfod], [Build debuginfod client library (can be =dummy)]))
|
||||
AS_IF([test "x$enable_libdebuginfod" != "xno"], [
|
||||
@@ -742,6 +749,7 @@ AC_MSG_NOTICE([
|
||||
gzip support : ${with_zlib}
|
||||
bzip2 support : ${with_bzlib}
|
||||
lzma/xz support : ${with_lzma}
|
||||
+ zstd support : ${with_zstd}
|
||||
libstdc++ demangle support : ${enable_demangler}
|
||||
File textrel check : ${enable_textrelcheck}
|
||||
Symbol versioning : ${enable_symbol_versioning}
|
||||
@@ -759,6 +767,7 @@ AC_MSG_NOTICE([
|
||||
|
||||
EXTRA TEST FEATURES (used with make check)
|
||||
have bunzip2 installed (required) : ${HAVE_BUNZIP2}
|
||||
+ have zstd installed : ${HAVE_ZSTD}
|
||||
debug branch prediction : ${use_debugpred}
|
||||
gprof support : ${use_gprof}
|
||||
gcov support : ${use_gcov}
|
||||
diff --git a/libdwfl/Makefile.am b/libdwfl/Makefile.am
|
||||
index 1de05492..a0013e41 100644
|
||||
--- a/libdwfl/Makefile.am
|
||||
+++ b/libdwfl/Makefile.am
|
||||
@@ -78,6 +78,9 @@ endif
|
||||
if LZMA
|
||||
libdwfl_a_SOURCES += lzma.c
|
||||
endif
|
||||
+if ZSTD
|
||||
+libdwfl_a_SOURCES += zstd.c
|
||||
+endif
|
||||
if LIBDEBUGINFOD
|
||||
libdwfl_a_SOURCES += debuginfod-client.c
|
||||
endif
|
||||
diff --git a/libdwfl/gzip.c b/libdwfl/gzip.c
|
||||
index e9988cc2..ba8ecfba 100644
|
||||
--- a/libdwfl/gzip.c
|
||||
+++ b/libdwfl/gzip.c
|
||||
@@ -48,6 +48,12 @@
|
||||
# define inflateInit(z) lzma_auto_decoder (z, 1 << 30, 0)
|
||||
# define do_inflate(z) lzma_code (z, LZMA_RUN)
|
||||
# define inflateEnd(z) lzma_end (z)
|
||||
+#elif defined ZSTD
|
||||
+# define USE_INFLATE 1
|
||||
+# include <zstd.h>
|
||||
+# define unzip __libdw_unzstd
|
||||
+# define DWFL_E_ZLIB DWFL_E_ZSTD
|
||||
+# define MAGIC "\x28\xb5\x2f\xfd"
|
||||
#elif defined BZLIB
|
||||
# define USE_INFLATE 1
|
||||
# include <bzlib.h>
|
||||
@@ -119,6 +125,7 @@ fail (struct unzip_state *state, Dwfl_Error failure)
|
||||
return failure;
|
||||
}
|
||||
|
||||
+#ifndef ZSTD
|
||||
static inline Dwfl_Error
|
||||
zlib_fail (struct unzip_state *state, int result)
|
||||
{
|
||||
@@ -132,6 +139,7 @@ zlib_fail (struct unzip_state *state, int result)
|
||||
return fail (state, DWFL_E_ZLIB);
|
||||
}
|
||||
}
|
||||
+#endif
|
||||
|
||||
#if !USE_INFLATE
|
||||
static Dwfl_Error
|
||||
@@ -197,7 +205,7 @@ unzip (int fd, off_t start_offset,
|
||||
|
||||
ssize_t n = pread_retry (fd, state.input_buffer, READ_SIZE, start_offset);
|
||||
if (unlikely (n < 0))
|
||||
- return zlib_fail (&state, Z (ERRNO));
|
||||
+ return fail (&state, DWFL_E_ERRNO);
|
||||
|
||||
state.input_pos = n;
|
||||
mapped = state.input_buffer;
|
||||
@@ -223,7 +231,74 @@ unzip (int fd, off_t start_offset,
|
||||
/* Not a compressed file. */
|
||||
return DWFL_E_BADELF;
|
||||
|
||||
-#if USE_INFLATE
|
||||
+#ifdef ZSTD
|
||||
+ /* special case for libzstd since it is slightly different from the
|
||||
+ API provided by bzlib and liblzma. */
|
||||
+
|
||||
+ void *next_in = mapped;
|
||||
+ size_t avail_in = state.mapped_size;
|
||||
+ void *next_out = NULL;
|
||||
+ size_t avail_out = 0;
|
||||
+ size_t total_out = 0;
|
||||
+
|
||||
+ size_t result;
|
||||
+ ZSTD_DCtx *dctx = ZSTD_createDCtx();
|
||||
+ if (dctx == NULL)
|
||||
+ return fail (&state, DWFL_E_NOMEM);
|
||||
+
|
||||
+ do
|
||||
+ {
|
||||
+ if (avail_in == 0 && state.input_buffer != NULL)
|
||||
+ {
|
||||
+ ssize_t n = pread_retry (fd, state.input_buffer, READ_SIZE,
|
||||
+ start_offset + state.input_pos);
|
||||
+ if (unlikely (n < 0))
|
||||
+ {
|
||||
+ ZSTD_freeDCtx (dctx);
|
||||
+ return fail (&state, DWFL_E_ERRNO);
|
||||
+ }
|
||||
+ next_in = state.input_buffer;
|
||||
+ avail_in = n;
|
||||
+ state.input_pos += n;
|
||||
+ }
|
||||
+ if (avail_out == 0)
|
||||
+ {
|
||||
+ ptrdiff_t pos = (void *) next_out - state.buffer;
|
||||
+ if (!bigger_buffer (&state, avail_in))
|
||||
+ {
|
||||
+ ZSTD_freeDCtx (dctx);
|
||||
+ return fail (&state, DWFL_E_NOMEM);
|
||||
+ }
|
||||
+ next_out = state.buffer + pos;
|
||||
+ avail_out = state.size - pos;
|
||||
+ }
|
||||
+
|
||||
+ ZSTD_inBuffer input = { next_in, avail_in, 0 };
|
||||
+ ZSTD_outBuffer output = { next_out, avail_out, 0 };
|
||||
+ result = ZSTD_decompressStream (dctx, &output, &input);
|
||||
+
|
||||
+ if (! ZSTD_isError (result))
|
||||
+ {
|
||||
+ total_out += output.pos;
|
||||
+ next_out += output.pos;
|
||||
+ avail_out -= output.pos;
|
||||
+ next_in += input.pos;
|
||||
+ avail_in -= input.pos;
|
||||
+ }
|
||||
+
|
||||
+ if (result == 0)
|
||||
+ break;
|
||||
+ }
|
||||
+ while (avail_in > 0 && ! ZSTD_isError (result));
|
||||
+
|
||||
+ ZSTD_freeDCtx (dctx);
|
||||
+
|
||||
+ if (ZSTD_isError (result))
|
||||
+ return fail (&state, DWFL_E_ZSTD);
|
||||
+
|
||||
+ smaller_buffer (&state, total_out);
|
||||
+
|
||||
+#elif USE_INFLATE
|
||||
|
||||
/* This style actually only works with bzlib and liblzma.
|
||||
The stupid zlib interface has nothing to grok the
|
||||
diff --git a/libdwfl/libdwflP.h b/libdwfl/libdwflP.h
|
||||
index ad6779ad..4c6fcb28 100644
|
||||
--- a/libdwfl/libdwflP.h
|
||||
+++ b/libdwfl/libdwflP.h
|
||||
@@ -61,6 +61,7 @@ typedef struct Dwfl_Process Dwfl_Process;
|
||||
DWFL_ERROR (ZLIB, N_("gzip decompression failed")) \
|
||||
DWFL_ERROR (BZLIB, N_("bzip2 decompression failed")) \
|
||||
DWFL_ERROR (LZMA, N_("LZMA decompression failed")) \
|
||||
+ DWFL_ERROR (ZSTD, N_("zstd decompression failed")) \
|
||||
DWFL_ERROR (UNKNOWN_MACHINE, N_("no support library found for machine")) \
|
||||
DWFL_ERROR (NOREL, N_("Callbacks missing for ET_REL file")) \
|
||||
DWFL_ERROR (BADRELTYPE, N_("Unsupported relocation type")) \
|
||||
@@ -612,6 +613,10 @@ extern Dwfl_Error __libdw_unlzma (int fd, off_t start_offset,
|
||||
void *mapped, size_t mapped_size,
|
||||
void **whole, size_t *whole_size)
|
||||
internal_function;
|
||||
+extern Dwfl_Error __libdw_unzstd (int fd, off_t start_offset,
|
||||
+ void *mapped, size_t mapped_size,
|
||||
+ void **whole, size_t *whole_size)
|
||||
+ internal_function;
|
||||
|
||||
/* Skip the image header before a file image: updates *START_OFFSET. */
|
||||
extern Dwfl_Error __libdw_image_header (int fd, off_t *start_offset,
|
||||
diff --git a/libdwfl/open.c b/libdwfl/open.c
|
||||
index 35fc5283..77bd2bd9 100644
|
||||
--- a/libdwfl/open.c
|
||||
+++ b/libdwfl/open.c
|
||||
@@ -44,6 +44,10 @@
|
||||
# define __libdw_unlzma(...) DWFL_E_BADELF
|
||||
#endif
|
||||
|
||||
+#if !USE_ZSTD
|
||||
+# define __libdw_unzstd(...) DWFL_E_BADELF
|
||||
+#endif
|
||||
+
|
||||
/* Consumes and replaces *ELF only on success. */
|
||||
static Dwfl_Error
|
||||
decompress (int fd __attribute__ ((unused)), Elf **elf)
|
||||
@@ -64,6 +68,8 @@ decompress (int fd __attribute__ ((unused)), Elf **elf)
|
||||
error = __libdw_bunzip2 (fd, offset, mapped, mapped_size, &buffer, &size);
|
||||
if (error == DWFL_E_BADELF)
|
||||
error = __libdw_unlzma (fd, offset, mapped, mapped_size, &buffer, &size);
|
||||
+ if (error == DWFL_E_BADELF)
|
||||
+ error = __libdw_unzstd (fd, offset, mapped, mapped_size, &buffer, &size);
|
||||
|
||||
if (error == DWFL_E_NOERROR)
|
||||
{
|
||||
diff --git a/libdwfl/zstd.c b/libdwfl/zstd.c
|
||||
new file mode 100644
|
||||
index 00000000..dc4d5238
|
||||
--- /dev/null
|
||||
+++ b/libdwfl/zstd.c
|
||||
@@ -0,0 +1,4 @@
|
||||
+/* libzstd is pretty close to zlib and bzlib. */
|
||||
+
|
||||
+#define ZSTD
|
||||
+#include "gzip.c"
|
||||
diff --git a/tests/Makefile.am b/tests/Makefile.am
|
||||
index 4629ce64..9d0707da 100644
|
||||
--- a/tests/Makefile.am
|
||||
+++ b/tests/Makefile.am
|
||||
@@ -204,6 +204,10 @@ if LZMA
|
||||
TESTS += run-readelf-s.sh run-dwflsyms.sh
|
||||
endif
|
||||
|
||||
+if HAVE_ZSTD
|
||||
+TESTS += run-readelf-compressed-zstd.sh
|
||||
+endif
|
||||
+
|
||||
if HAVE_LIBASM
|
||||
check_PROGRAMS += $(asm_TESTS)
|
||||
TESTS += $(asm_TESTS) run-disasm-bpf.sh
|
||||
@@ -256,6 +260,7 @@ EXTRA_DIST = run-arextract.sh run-arsymtest.sh run-ar.sh \
|
||||
run-nm-syms.sh testfilesyms32.bz2 testfilesyms64.bz2 \
|
||||
run-nm-self.sh run-readelf-self.sh run-readelf-info-plus.sh \
|
||||
run-readelf-compressed.sh \
|
||||
+ run-readelf-compressed-zstd.sh \
|
||||
run-readelf-const-values.sh testfile-const-values.debug.bz2 \
|
||||
run-addrcfi.sh run-dwarfcfi.sh \
|
||||
testfile11-debugframe.bz2 testfile12-debugframe.bz2 \
|
||||
diff --git a/tests/run-readelf-compressed-zstd.sh b/tests/run-readelf-compressed-zstd.sh
|
||||
new file mode 100755
|
||||
index 00000000..96208092
|
||||
--- /dev/null
|
||||
+++ b/tests/run-readelf-compressed-zstd.sh
|
||||
@@ -0,0 +1,39 @@
|
||||
+#! /bin/sh
|
||||
+# Copyright (C) 2018 Red Hat, Inc.
|
||||
+# This file is part of elfutils.
|
||||
+#
|
||||
+# This file is free software; you can redistribute it and/or modify
|
||||
+# it under the terms of the GNU General Public License as published by
|
||||
+# the Free Software Foundation; either version 3 of the License, or
|
||||
+# (at your option) any later version.
|
||||
+#
|
||||
+# elfutils is distributed in the hope that it will be useful, but
|
||||
+# WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+# GNU General Public License for more details.
|
||||
+#
|
||||
+# You should have received a copy of the GNU General Public License
|
||||
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
+
|
||||
+. $srcdir/test-subr.sh
|
||||
+
|
||||
+if ! grep -q -F '#define USE_ZSTD' ${abs_top_builddir}/config.h; then
|
||||
+ echo "elfutils built without zstd support"
|
||||
+ exit 77
|
||||
+fi
|
||||
+
|
||||
+# See run-strip-reloc.sh
|
||||
+testfiles hello_i386.ko
|
||||
+
|
||||
+tempfiles hello_i386.ko.zst readelf.out.1 readelf.out.2
|
||||
+
|
||||
+testrun ${abs_top_builddir}/src/readelf -a hello_i386.ko > readelf.out.1
|
||||
+zstd hello_i386.ko
|
||||
+testrun ${abs_top_builddir}/src/readelf -a hello_i386.ko.zst > readelf.out.2
|
||||
+
|
||||
+diff -u readelf.out.1 readelf.out.2
|
||||
+if [ $? != 0 ]; then
|
||||
+ exit 1;
|
||||
+fi
|
||||
+
|
||||
+exit 0
|
@ -1,6 +1,6 @@
|
||||
Name: elfutils
|
||||
Version: 0.181
|
||||
%global baserelease 3
|
||||
Version: 0.182
|
||||
%global baserelease 1
|
||||
Release: %{baserelease}%{?dist}
|
||||
URL: http://elfutils.org/
|
||||
%global source_url ftp://sourceware.org/pub/elfutils/%{version}/
|
||||
@ -60,8 +60,6 @@ BuildRequires: autoconf
|
||||
%endif
|
||||
|
||||
# Patches
|
||||
Patch1: elfutils-0.181-zstd.patch
|
||||
Patch2: elfutils-0.181-array-param.patch
|
||||
|
||||
%description
|
||||
Elfutils is a collection of utilities, including stack (to show
|
||||
@ -230,8 +228,6 @@ such servers to download those files on demand.
|
||||
%setup -q
|
||||
|
||||
# Apply patches
|
||||
%patch1 -p1 -b .zstd
|
||||
%patch2 -p1 -b .array_param
|
||||
|
||||
autoreconf -f -v -i
|
||||
|
||||
@ -270,6 +266,9 @@ chmod +x ${RPM_BUILD_ROOT}%{_prefix}/%{_lib}/lib*.so*
|
||||
# We don't want the static libraries
|
||||
rm ${RPM_BUILD_ROOT}%{_prefix}/%{_lib}/lib{elf,dw,asm}.a
|
||||
|
||||
# We don't have standard DEBUGINFOD_URLS yet.
|
||||
rm ${RPM_BUILD_ROOT}%{_sysconfdir}/profile.d/debuginfod.sh
|
||||
rm ${RPM_BUILD_ROOT}%{_sysconfdir}/profile.d/debuginfod.csh
|
||||
|
||||
%find_lang %{name}
|
||||
|
||||
@ -393,12 +392,13 @@ fi
|
||||
%files debuginfod
|
||||
%defattr(-,root,root)
|
||||
%{_bindir}/debuginfod
|
||||
%config(noreplace) %verify(not md5 size mtime) %{_sysconfdir}/sysconfig/debuginfod
|
||||
%config(noreplace) %{_sysconfdir}/sysconfig/debuginfod
|
||||
%{_unitdir}/debuginfod.service
|
||||
%{_sysconfdir}/sysconfig/debuginfod
|
||||
%{_mandir}/man8/debuginfod.8*
|
||||
|
||||
%dir %attr(0700,debuginfod,debuginfod) %{_localstatedir}/cache/debuginfod
|
||||
%verify(not md5 size mtime) %attr(0600,debuginfod,debuginfod) %{_localstatedir}/cache/debuginfod/debuginfod.sqlite
|
||||
%ghost %attr(0600,debuginfod,debuginfod) %{_localstatedir}/cache/debuginfod/debuginfod.sqlite
|
||||
|
||||
%pre debuginfod
|
||||
getent group debuginfod >/dev/null || groupadd -r debuginfod
|
||||
@ -414,6 +414,16 @@ exit 0
|
||||
%systemd_postun_with_restart debuginfod.service
|
||||
|
||||
%changelog
|
||||
* Sat Oct 31 2020 Mark Wielaard <mjw@fedoraproject.org> - 0.182-1
|
||||
- Upgrade to upstream 0.182
|
||||
- backends: Support for tilegx has been removed.
|
||||
- config: New /etc/profile.d files to provide default $DEBUGINFOD_URLS.
|
||||
- debuginfod: More efficient package traversal, tolerate various
|
||||
errors during scanning, grooming progress is more visible and
|
||||
interruptible, more prometheus metrics.
|
||||
- debuginfod-client: Now supports compressed (kernel) ELF images.
|
||||
- libdwfl: Add ZSTD compression support.
|
||||
|
||||
* Mon Oct 19 2020 Mark Wielaard <mjw@fedoraproject.org> - 0.181-3
|
||||
- Add elfutils-0.181-array-param.patch.
|
||||
|
||||
|
2
sources
2
sources
@ -1 +1 @@
|
||||
SHA512 (elfutils-0.181.tar.bz2) = d565541d5817f409dc89ebb1ee593366f69c371a1531308eeb67ff934b14a0fab0c9009fd7c23240efbaa1b4e04edac5c425e47d80e3e66ba03dcaf000afea36
|
||||
SHA512 (elfutils-0.182.tar.bz2) = 8ab0735bbe11b4383169341bf674ace360038b6ae5239f1d5a991c46260cd4bce545e078735b7de3b8fab132bb5da41f60689ff1b1d7ebccfada117a954a2c81
|
||||
|
Loading…
Reference in New Issue
Block a user