From: Roland McGrath Date: Thu, 15 Mar 2012 18:20:22 +0000 (+0000) Subject: * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Use X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a4456d242dd59e4f0ccad3020667df19be2202e8;p=binutils-gdb.git * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Use elf_x86_64_backend_data parameters for plt_eh_frame. Change-Id: I4e1a7c2787ed1276765e269f50fc8ba89bab41d5 --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 0a674b8d2de..f967d452d50 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,8 @@ 2012-03-15 Roland McGrath + * elf64-x86-64.c (elf_x86_64_create_dynamic_sections): Use + elf_x86_64_backend_data parameters for plt_eh_frame. + * elf64-x86-64.c (struct elf_x86_64_backend_data): New type. (get_elf_x86_64_backend_data, GET_PLT_ENTRY_SIZE): New macros. (elf_x86_64_arch_bed): New variable. diff --git a/bfd/elf64-x86-64.c b/bfd/elf64-x86-64.c index c0a449342cf..51204a5cf82 100644 --- a/bfd/elf64-x86-64.c +++ b/bfd/elf64-x86-64.c @@ -981,6 +981,8 @@ elf_x86_64_create_dynamic_sections (bfd *dynobj, && bfd_get_section_by_name (dynobj, ".eh_frame") == NULL && htab->elf.splt != NULL) { + const struct elf_x86_64_backend_data *const abed + = get_elf_x86_64_backend_data (dynobj); flagword flags = get_elf_backend_data (dynobj)->dynamic_sec_flags; htab->plt_eh_frame = bfd_make_section_with_flags (dynobj, ".eh_frame", @@ -989,11 +991,11 @@ elf_x86_64_create_dynamic_sections (bfd *dynobj, || !bfd_set_section_alignment (dynobj, htab->plt_eh_frame, 3)) return FALSE; - htab->plt_eh_frame->size = sizeof (elf_x86_64_eh_frame_plt); + htab->plt_eh_frame->size = abed->eh_frame_plt_size; htab->plt_eh_frame->contents - = bfd_alloc (dynobj, htab->plt_eh_frame->size); - memcpy (htab->plt_eh_frame->contents, elf_x86_64_eh_frame_plt, - sizeof (elf_x86_64_eh_frame_plt)); + = bfd_alloc (dynobj, htab->plt_eh_frame->size); + memcpy (htab->plt_eh_frame->contents, + abed->eh_frame_plt, abed->eh_frame_plt_size); } return TRUE; }