adjust patch
OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=321
This commit is contained in:
parent
be501ec5b6
commit
d6d76202e8
@ -5,23 +5,17 @@ input files contains a section named .ulp.track.
|
|||||||
Index: bfd/elflink.c
|
Index: bfd/elflink.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- bfd/elflink.c.orig 2019-09-09 15:19:43.000000000 +0200
|
--- bfd/elflink.c.orig 2019-09-09 15:19:43.000000000 +0200
|
||||||
+++ bfd/elflink.c 2019-11-18 18:02:54.000000000 +0100
|
+++ bfd/elflink.c 2019-11-18 18:50:53.000000000 +0100
|
||||||
@@ -22,6 +22,7 @@
|
@@ -7070,6 +7070,13 @@ bfd_elf_size_dynamic_sections (bfd *outp
|
||||||
#include "bfd.h"
|
|
||||||
#include "bfdlink.h"
|
|
||||||
#include "libbfd.h"
|
|
||||||
+#include "ulp.h"
|
|
||||||
#define ARCH_SIZE 0
|
|
||||||
#include "elf-bfd.h"
|
|
||||||
#include "safe-ctype.h"
|
|
||||||
@@ -7070,6 +7071,11 @@ bfd_elf_size_dynamic_sections (bfd *outp
|
|
||||||
s = bfd_get_linker_section (dynobj, ".gnu.version");
|
s = bfd_get_linker_section (dynobj, ".gnu.version");
|
||||||
s->flags |= SEC_EXCLUDE;
|
s->flags |= SEC_EXCLUDE;
|
||||||
}
|
}
|
||||||
+
|
+
|
||||||
+ if (bfd_is_ulp_enabled(output_bfd))
|
+ if (bed->elf_backend_is_ulp_enabled != NULL
|
||||||
|
+ && bed->elf_backend_setup_ulp != NULL
|
||||||
|
+ && (*bed->elf_backend_is_ulp_enabled) (output_bfd))
|
||||||
+ {
|
+ {
|
||||||
+ bfd_setup_ulp(info);
|
+ (*bed->elf_backend_setup_ulp)(info);
|
||||||
+ }
|
+ }
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -29,23 +23,24 @@ Index: bfd/elflink.c
|
|||||||
Index: bfd/elfxx-x86.c
|
Index: bfd/elfxx-x86.c
|
||||||
===================================================================
|
===================================================================
|
||||||
--- bfd/elfxx-x86.c.orig 2019-09-09 15:19:43.000000000 +0200
|
--- bfd/elfxx-x86.c.orig 2019-09-09 15:19:43.000000000 +0200
|
||||||
+++ bfd/elfxx-x86.c 2019-11-18 18:02:54.000000000 +0100
|
+++ bfd/elfxx-x86.c 2019-11-18 18:51:01.000000000 +0100
|
||||||
@@ -23,6 +23,7 @@
|
@@ -31,6 +31,8 @@
|
||||||
#include "objalloc.h"
|
#define ELF64_DYNAMIC_INTERPRETER "/lib/ld64.so.1"
|
||||||
#include "elf/i386.h"
|
#define ELFX32_DYNAMIC_INTERPRETER "/lib/ldx32.so.1"
|
||||||
#include "elf/x86-64.h"
|
|
||||||
+#include "ulp.h"
|
|
||||||
|
|
||||||
/* The name of the dynamic interpreter. This is put in the .interp
|
+#define ULP_ENTRY_LEN 16
|
||||||
section. */
|
+
|
||||||
@@ -952,6 +953,64 @@ _bfd_x86_elf_link_check_relocs (bfd *abf
|
bfd_boolean
|
||||||
|
_bfd_x86_elf_mkobject (bfd *abfd)
|
||||||
|
{
|
||||||
|
@@ -952,6 +954,64 @@ _bfd_x86_elf_link_check_relocs (bfd *abf
|
||||||
return _bfd_elf_link_check_relocs (abfd, info);
|
return _bfd_elf_link_check_relocs (abfd, info);
|
||||||
}
|
}
|
||||||
|
|
||||||
+/* Check if input bfds are ulp-enabled by containing .ulp.track section */
|
+/* Check if input bfds are ulp-enabled by containing .ulp.track section */
|
||||||
+
|
+
|
||||||
+bfd_boolean
|
+bfd_boolean
|
||||||
+bfd_x86_elf_is_ulp_enabled (struct bfd *input_bfd)
|
+_bfd_x86_elf_is_ulp_enabled (struct bfd *input_bfd)
|
||||||
+{
|
+{
|
||||||
+ while (input_bfd != NULL)
|
+ while (input_bfd != NULL)
|
||||||
+ for (; input_bfd != NULL; input_bfd = input_bfd->link.next)
|
+ for (; input_bfd != NULL; input_bfd = input_bfd->link.next)
|
||||||
@ -73,7 +68,7 @@ Index: bfd/elfxx-x86.c
|
|||||||
+/* Fill the user-space live patching section */
|
+/* Fill the user-space live patching section */
|
||||||
+
|
+
|
||||||
+bfd_boolean
|
+bfd_boolean
|
||||||
+bfd_x86_elf_setup_ulp (struct bfd_link_info *info)
|
+_bfd_x86_elf_setup_ulp (struct bfd_link_info *info)
|
||||||
+{
|
+{
|
||||||
+ struct elf_x86_link_hash_table *htab;
|
+ struct elf_x86_link_hash_table *htab;
|
||||||
+ asection *ulp;
|
+ asection *ulp;
|
||||||
@ -103,7 +98,7 @@ Index: bfd/elfxx-x86.c
|
|||||||
/* Set the sizes of the dynamic sections. */
|
/* Set the sizes of the dynamic sections. */
|
||||||
|
|
||||||
bfd_boolean
|
bfd_boolean
|
||||||
@@ -2935,7 +2994,26 @@ error_alignment:
|
@@ -2935,7 +2995,26 @@ error_alignment:
|
||||||
|
|
||||||
htab->plt_second = sec;
|
htab->plt_second = sec;
|
||||||
}
|
}
|
||||||
@ -134,7 +129,7 @@ Index: bfd/elfxx-x86.c
|
|||||||
Index: bfd/elfxx-x86.h
|
Index: bfd/elfxx-x86.h
|
||||||
===================================================================
|
===================================================================
|
||||||
--- bfd/elfxx-x86.h.orig 2019-09-09 15:19:43.000000000 +0200
|
--- bfd/elfxx-x86.h.orig 2019-09-09 15:19:43.000000000 +0200
|
||||||
+++ bfd/elfxx-x86.h 2019-11-18 18:02:54.000000000 +0100
|
+++ bfd/elfxx-x86.h 2019-11-18 18:47:32.000000000 +0100
|
||||||
@@ -447,6 +447,7 @@ struct elf_x86_link_hash_table
|
@@ -447,6 +447,7 @@ struct elf_x86_link_hash_table
|
||||||
asection *plt_second_eh_frame;
|
asection *plt_second_eh_frame;
|
||||||
asection *plt_got;
|
asection *plt_got;
|
||||||
@ -143,20 +138,67 @@ Index: bfd/elfxx-x86.h
|
|||||||
|
|
||||||
/* Parameters describing PLT generation, lazy or non-lazy. */
|
/* Parameters describing PLT generation, lazy or non-lazy. */
|
||||||
struct elf_x86_plt_layout plt;
|
struct elf_x86_plt_layout plt;
|
||||||
Index: bfd/ulp.h
|
@@ -708,6 +709,12 @@ extern void _bfd_x86_elf_link_fixup_ifun
|
||||||
===================================================================
|
(struct bfd_link_info *, struct elf_x86_link_hash_table *,
|
||||||
--- /dev/null 1970-01-01 00:00:00.000000000 +0000
|
struct elf_link_hash_entry *, Elf_Internal_Sym *sym);
|
||||||
+++ bfd/ulp.h 2019-11-18 18:02:54.000000000 +0100
|
|
||||||
@@ -0,0 +1,12 @@
|
+extern bfd_boolean _bfd_x86_elf_is_ulp_enabled
|
||||||
+extern bfd_boolean bfd_x86_elf_is_ulp_enabled
|
|
||||||
+ (struct bfd *);
|
+ (struct bfd *);
|
||||||
+
|
+
|
||||||
+extern bfd_boolean bfd_x86_elf_setup_ulp
|
+extern bfd_boolean _bfd_x86_elf_setup_ulp
|
||||||
+ (struct bfd_link_info *);
|
+ (struct bfd_link_info *);
|
||||||
+
|
+
|
||||||
+#define bfd_is_ulp_enabled bfd_x86_elf_is_ulp_enabled
|
#define bfd_elf64_mkobject \
|
||||||
|
_bfd_x86_elf_mkobject
|
||||||
|
#define bfd_elf32_mkobject \
|
||||||
|
@@ -745,3 +752,7 @@ extern void _bfd_x86_elf_link_fixup_ifun
|
||||||
|
_bfd_x86_elf_merge_gnu_properties
|
||||||
|
#define elf_backend_fixup_gnu_properties \
|
||||||
|
_bfd_x86_elf_link_fixup_gnu_properties
|
||||||
|
+#define elf_backend_is_ulp_enabled \
|
||||||
|
+ _bfd_x86_elf_is_ulp_enabled
|
||||||
|
+#define elf_backend_setup_ulp \
|
||||||
|
+ _bfd_x86_elf_setup_ulp
|
||||||
|
Index: bfd/elf-bfd.h
|
||||||
|
===================================================================
|
||||||
|
--- bfd/elf-bfd.h.orig 2019-09-09 15:19:43.000000000 +0200
|
||||||
|
+++ bfd/elf-bfd.h 2019-11-18 18:47:43.000000000 +0100
|
||||||
|
@@ -1423,6 +1423,10 @@ struct elf_backend_data
|
||||||
|
(const bfd *ibfd, bfd *obfd, const Elf_Internal_Shdr *isection,
|
||||||
|
Elf_Internal_Shdr *osection);
|
||||||
|
|
||||||
|
+ bfd_boolean (*elf_backend_is_ulp_enabled) (bfd *abfd);
|
||||||
+
|
+
|
||||||
+#define bfd_setup_ulp bfd_x86_elf_setup_ulp
|
+ bfd_boolean (*elf_backend_setup_ulp) (struct bfd_link_info *);
|
||||||
+
|
+
|
||||||
+#define ULP_ENTRY_LEN 16
|
/* Used to handle bad SHF_LINK_ORDER input. */
|
||||||
|
void (*link_order_error_handler) (const char *, ...);
|
||||||
|
|
||||||
|
Index: bfd/elfxx-target.h
|
||||||
|
===================================================================
|
||||||
|
--- bfd/elfxx-target.h.orig 2019-09-09 15:19:43.000000000 +0200
|
||||||
|
+++ bfd/elfxx-target.h 2019-11-18 18:50:34.000000000 +0100
|
||||||
|
@@ -754,6 +754,14 @@
|
||||||
|
#define elf_backend_copy_special_section_fields NULL
|
||||||
|
#endif
|
||||||
|
|
||||||
|
+#ifndef elf_backend_is_ulp_enabled
|
||||||
|
+#define elf_backend_is_ulp_enabled NULL
|
||||||
|
+#endif
|
||||||
+
|
+
|
||||||
|
+#ifndef elf_backend_setup_ulp
|
||||||
|
+#define elf_backend_setup_ulp NULL
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
#ifndef elf_backend_compact_eh_encoding
|
||||||
|
#define elf_backend_compact_eh_encoding NULL
|
||||||
|
#endif
|
||||||
|
@@ -867,6 +875,8 @@ static struct elf_backend_data elfNN_bed
|
||||||
|
elf_backend_maybe_function_sym,
|
||||||
|
elf_backend_get_reloc_section,
|
||||||
|
elf_backend_copy_special_section_fields,
|
||||||
|
+ elf_backend_is_ulp_enabled,
|
||||||
|
+ elf_backend_setup_ulp,
|
||||||
|
elf_backend_link_order_error_handler,
|
||||||
|
elf_backend_relplt_name,
|
||||||
|
ELF_MACHINE_ALT1,
|
||||||
|
Loading…
Reference in New Issue
Block a user