1999-05-03 15:29:11 +08:00
|
|
|
/* ELF core file support for BFD.
|
2020-01-01 15:57:01 +08:00
|
|
|
Copyright (C) 1995-2020 Free Software Foundation, Inc.
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2003-02-14 17:21:21 +08:00
|
|
|
This file is part of BFD, the Binary File Descriptor library.
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2003-02-14 17:21:21 +08:00
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
2007-07-03 22:26:43 +08:00
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
2003-02-14 17:21:21 +08:00
|
|
|
(at your option) any later version.
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2003-02-14 17:21:21 +08:00
|
|
|
This program 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.
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2003-02-14 17:21:21 +08:00
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
2007-07-03 22:26:43 +08:00
|
|
|
Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
|
|
|
|
MA 02110-1301, USA. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
char*
|
2003-08-04 17:39:46 +08:00
|
|
|
elf_core_file_failing_command (bfd *abfd)
|
1999-05-03 15:29:11 +08:00
|
|
|
{
|
* elf-bfd.h (struct core_elf_obj_tdata): New.
(struct elf_obj_tdata): Delete core_signal, core_pid, core_lwpid,
core_program, and core_command. Add "core".
* elf.c (bfd_elf_mkcorefile): Allocate "core" struct.
Update all refs to tdata core fields.
* elf32-am33lin.c, * elf32-arm.c, * elf32-cris.c, * elf32-frv.c,
* elf32-hppa.c, * elf32-i386.c, * elf32-m68k.c, * elf32-mips.c,
* elf32-nios2.c, * elf32-ppc.c, * elf32-s390.c, * elf32-score.c,
* elf32-score7.c, * elf32-sh.c, * elf32-sparc.c, * elf32-tilegx.c,
* elf32-tilepro.c, * elf32-xtensa.c, * elf64-aarch64.c,
* elf64-hppa.c, * elf64-mips.c, * elf64-ppc.c, * elf64-tilegx.c,
* elf64-x86-64.c, * elfcore.h, * elfn32-mips.c: Update all refs
to tdata core fields.
2013-02-21 11:02:30 +08:00
|
|
|
return elf_tdata (abfd)->core->command;
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2003-08-04 17:39:46 +08:00
|
|
|
elf_core_file_failing_signal (bfd *abfd)
|
1999-05-03 15:29:11 +08:00
|
|
|
{
|
* elf-bfd.h (struct core_elf_obj_tdata): New.
(struct elf_obj_tdata): Delete core_signal, core_pid, core_lwpid,
core_program, and core_command. Add "core".
* elf.c (bfd_elf_mkcorefile): Allocate "core" struct.
Update all refs to tdata core fields.
* elf32-am33lin.c, * elf32-arm.c, * elf32-cris.c, * elf32-frv.c,
* elf32-hppa.c, * elf32-i386.c, * elf32-m68k.c, * elf32-mips.c,
* elf32-nios2.c, * elf32-ppc.c, * elf32-s390.c, * elf32-score.c,
* elf32-score7.c, * elf32-sh.c, * elf32-sparc.c, * elf32-tilegx.c,
* elf32-tilepro.c, * elf32-xtensa.c, * elf64-aarch64.c,
* elf64-hppa.c, * elf64-mips.c, * elf64-ppc.c, * elf64-tilegx.c,
* elf64-x86-64.c, * elfcore.h, * elfn32-mips.c: Update all refs
to tdata core fields.
2013-02-21 11:02:30 +08:00
|
|
|
return elf_tdata (abfd)->core->signal;
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
|
|
|
|
2010-08-18 20:24:13 +08:00
|
|
|
int
|
|
|
|
elf_core_file_pid (bfd *abfd)
|
|
|
|
{
|
* elf-bfd.h (struct core_elf_obj_tdata): New.
(struct elf_obj_tdata): Delete core_signal, core_pid, core_lwpid,
core_program, and core_command. Add "core".
* elf.c (bfd_elf_mkcorefile): Allocate "core" struct.
Update all refs to tdata core fields.
* elf32-am33lin.c, * elf32-arm.c, * elf32-cris.c, * elf32-frv.c,
* elf32-hppa.c, * elf32-i386.c, * elf32-m68k.c, * elf32-mips.c,
* elf32-nios2.c, * elf32-ppc.c, * elf32-s390.c, * elf32-score.c,
* elf32-score7.c, * elf32-sh.c, * elf32-sparc.c, * elf32-tilegx.c,
* elf32-tilepro.c, * elf32-xtensa.c, * elf64-aarch64.c,
* elf64-hppa.c, * elf64-mips.c, * elf64-ppc.c, * elf64-tilegx.c,
* elf64-x86-64.c, * elfcore.h, * elfn32-mips.c: Update all refs
to tdata core fields.
2013-02-21 11:02:30 +08:00
|
|
|
return elf_tdata (abfd)->core->pid;
|
2010-08-18 20:24:13 +08:00
|
|
|
}
|
|
|
|
|
2002-11-30 16:39:46 +08:00
|
|
|
bfd_boolean
|
2003-08-04 17:39:46 +08:00
|
|
|
elf_core_file_matches_executable_p (bfd *core_bfd, bfd *exec_bfd)
|
1999-05-03 15:29:11 +08:00
|
|
|
{
|
|
|
|
char* corename;
|
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* xvecs must match if both are ELF files for the same target. */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
if (core_bfd->xvec != exec_bfd->xvec)
|
|
|
|
{
|
|
|
|
bfd_set_error (bfd_error_system_call);
|
2002-11-30 16:39:46 +08:00
|
|
|
return FALSE;
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
|
|
|
|
2019-10-30 20:23:16 +08:00
|
|
|
/* If both BFDs have identical build-ids, then they match. */
|
|
|
|
if (core_bfd->build_id != NULL
|
|
|
|
&& exec_bfd->build_id != NULL
|
|
|
|
&& core_bfd->build_id->size == exec_bfd->build_id->size
|
|
|
|
&& memcmp (core_bfd->build_id->data, exec_bfd->build_id->data,
|
|
|
|
core_bfd->build_id->size) == 0)
|
|
|
|
return TRUE;
|
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* See if the name in the corefile matches the executable name. */
|
* elf-bfd.h (struct core_elf_obj_tdata): New.
(struct elf_obj_tdata): Delete core_signal, core_pid, core_lwpid,
core_program, and core_command. Add "core".
* elf.c (bfd_elf_mkcorefile): Allocate "core" struct.
Update all refs to tdata core fields.
* elf32-am33lin.c, * elf32-arm.c, * elf32-cris.c, * elf32-frv.c,
* elf32-hppa.c, * elf32-i386.c, * elf32-m68k.c, * elf32-mips.c,
* elf32-nios2.c, * elf32-ppc.c, * elf32-s390.c, * elf32-score.c,
* elf32-score7.c, * elf32-sh.c, * elf32-sparc.c, * elf32-tilegx.c,
* elf32-tilepro.c, * elf32-xtensa.c, * elf64-aarch64.c,
* elf64-hppa.c, * elf64-mips.c, * elf64-ppc.c, * elf64-tilegx.c,
* elf64-x86-64.c, * elfcore.h, * elfn32-mips.c: Update all refs
to tdata core fields.
2013-02-21 11:02:30 +08:00
|
|
|
corename = elf_tdata (core_bfd)->core->program;
|
1999-05-03 15:29:11 +08:00
|
|
|
if (corename != NULL)
|
|
|
|
{
|
Use bfd_get_filename throughout bfd
* aix5ppc-core.c (xcoff64_core_file_matches_executable_p): Use
bfd_get_filename rather than accessing bfd->filename directly.
* aout-target.h (MY (object_p)): Likewise.
* aoutx.h (aout_find_nearest_line, aout_link_write_symbols): Likewise.
* archive.c (find_nested_archive, _bfd_generic_read_ar_hdr_mag),
(_bfd_construct_extended_name_table, _bfd_bsd44_write_ar_hdr),
(_bfd_archive_bsd44_construct_extended_name_table),
(_bfd_write_archive_contents, _bfd_compute_and_write_armap),
(_bfd_bsd_write_armap): Likewise.
* bfd.c (bfd_errmsg, _bfd_doprnt): Likewise.
* cache.c (bfd_open_file): Likewise.
* ecoff.c (_bfd_ecoff_write_armap): Likewise.
* ecofflink.c (bfd_ecoff_debug_accumulate_other): Likewise.
* elf32-bfin.c (bfinfdpic_relocate_section): Likewise.
* elf32-frv.c (elf32_frv_relocate_section): Likewise.
* elf32-hppa.c (elf32_hppa_final_link): Likewise.
* elf32-nds32.c (nds32_elf_output_symbol_hook),
(patch_tls_desc_to_ie): Likewise.
* elf32-spu.c (sort_bfds, print_one_overlay_section),
(spu_elf_auto_overlay): Likewise.
* elf64-hppa.c (elf_hppa_final_link): Likewise.
* elf64-ia64-vms.c (elf64_ia64_size_dynamic_sections): Likewise.
* elfcore.h (elf_core_file_matches_executable_p): Likewise.
* elflink.c (bfd_elf_size_dynamic_sections),
(elf_link_input_bfd): Likewise.
* linker.c (_bfd_generic_link_output_symbols): Likewise.
* mach-o.c (bfd_mach_o_follow_dsym),
(bfd_mach_o_close_and_cleanup): Likewise.
* opncls.c (_bfd_delete_bfd, _maybe_make_executable),
(find_separate_debug_file, get_build_id_name): Likewise.
* pdp11.c (aout_find_nearest_line, aout_link_write_symbols): Likewise.
* plugin.c (bfd_plugin_open_input): Likewise.
* rs6000-core.c (rs6000coff_core_file_matches_executable_p): Likewise.
* som.c (som_write_armap): Likewise.
* srec.c (srec_write_record, srec_write_symbols): Likewise.
* vms-lib.c (_bfd_vms_lib_get_imagelib_file),
(_bfd_vms_lib_write_archive_contents): Likewise.
* xcofflink.c (xcoff_link_add_dynamic_symbols): Likewise.
2020-05-19 11:05:03 +08:00
|
|
|
const char* execname = strrchr (bfd_get_filename (exec_bfd), '/');
|
2003-02-14 17:21:21 +08:00
|
|
|
|
Use bfd_get_filename throughout bfd
* aix5ppc-core.c (xcoff64_core_file_matches_executable_p): Use
bfd_get_filename rather than accessing bfd->filename directly.
* aout-target.h (MY (object_p)): Likewise.
* aoutx.h (aout_find_nearest_line, aout_link_write_symbols): Likewise.
* archive.c (find_nested_archive, _bfd_generic_read_ar_hdr_mag),
(_bfd_construct_extended_name_table, _bfd_bsd44_write_ar_hdr),
(_bfd_archive_bsd44_construct_extended_name_table),
(_bfd_write_archive_contents, _bfd_compute_and_write_armap),
(_bfd_bsd_write_armap): Likewise.
* bfd.c (bfd_errmsg, _bfd_doprnt): Likewise.
* cache.c (bfd_open_file): Likewise.
* ecoff.c (_bfd_ecoff_write_armap): Likewise.
* ecofflink.c (bfd_ecoff_debug_accumulate_other): Likewise.
* elf32-bfin.c (bfinfdpic_relocate_section): Likewise.
* elf32-frv.c (elf32_frv_relocate_section): Likewise.
* elf32-hppa.c (elf32_hppa_final_link): Likewise.
* elf32-nds32.c (nds32_elf_output_symbol_hook),
(patch_tls_desc_to_ie): Likewise.
* elf32-spu.c (sort_bfds, print_one_overlay_section),
(spu_elf_auto_overlay): Likewise.
* elf64-hppa.c (elf_hppa_final_link): Likewise.
* elf64-ia64-vms.c (elf64_ia64_size_dynamic_sections): Likewise.
* elfcore.h (elf_core_file_matches_executable_p): Likewise.
* elflink.c (bfd_elf_size_dynamic_sections),
(elf_link_input_bfd): Likewise.
* linker.c (_bfd_generic_link_output_symbols): Likewise.
* mach-o.c (bfd_mach_o_follow_dsym),
(bfd_mach_o_close_and_cleanup): Likewise.
* opncls.c (_bfd_delete_bfd, _maybe_make_executable),
(find_separate_debug_file, get_build_id_name): Likewise.
* pdp11.c (aout_find_nearest_line, aout_link_write_symbols): Likewise.
* plugin.c (bfd_plugin_open_input): Likewise.
* rs6000-core.c (rs6000coff_core_file_matches_executable_p): Likewise.
* som.c (som_write_armap): Likewise.
* srec.c (srec_write_record, srec_write_symbols): Likewise.
* vms-lib.c (_bfd_vms_lib_get_imagelib_file),
(_bfd_vms_lib_write_archive_contents): Likewise.
* xcofflink.c (xcoff_link_add_dynamic_symbols): Likewise.
2020-05-19 11:05:03 +08:00
|
|
|
execname = execname ? execname + 1 : bfd_get_filename (exec_bfd);
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2003-08-04 17:39:46 +08:00
|
|
|
if (strcmp (execname, corename) != 0)
|
2002-11-30 16:39:46 +08:00
|
|
|
return FALSE;
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
|
|
|
|
2002-11-30 16:39:46 +08:00
|
|
|
return TRUE;
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Core files are simply standard ELF formatted files that partition
|
|
|
|
the file using the execution view of the file (program header table)
|
|
|
|
rather than the linking view. In fact, there is no section header
|
|
|
|
table in a core file.
|
|
|
|
|
|
|
|
The process status information (including the contents of the general
|
|
|
|
register set) and the floating point register set are stored in a
|
|
|
|
segment of type PT_NOTE. We handcraft a couple of extra bfd sections
|
|
|
|
that allow standard bfd access to the general registers (.reg) and the
|
2003-02-14 17:21:21 +08:00
|
|
|
floating point registers (.reg2). */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
bfd_cleanup for object_p
The object_p (and archive_p, core_file_p) functions are not supposed
to have any target specific malloc'd memory attached to the bfd on
their return. This should be obvious on a failure return, but it's
also true for a successful return. The reason is that even though the
object_p recognises the file, that particular target may not be used
and thus the bfd won't be closed calling close_and_cleanup for the
target that allocated the memory.
It turns out that the object_p bfd_target* return value isn't needed.
In all cases except ld/plugin.c the target is abfd->xvec and with
ld/plugin.c the target isn't used. So this patch returns a cleanup
function from object_p instead, called in bfd_check_format_matches to
tidy the bfd before trying a different target match. The only cleanup
that does anything at this stage is the alpha-vms one.
bfd/
* targets.c (bfd_cleanup): New typedef.
(struct bfd <_bfd_check_format>): Return a bfd_cleanup.
* libbfd-in.h (_bfd_no_cleanup): Define.
* format.c (bfd_reinit): Add cleanup parameter, call it.
(bfd_check_format_matches): Set cleanup from _bfd_check_format
call and pass to bfd_reinit. Delete temp, use abfd->xvec instead.
* aout-target.h (callback, object_p): Return bfd_cleanup.
* aout-tic30.c (tic30_aout_callback, tic30_aout_object_p): Likewise.
* archive.c (bfd_generic_archive_p): Likewise.
* binary.c (binary_object_p): Likewise.
* coff-alpha.c (alpha_ecoff_object_p): Likewise.
* coff-ia64.c (ia64coff_object_p): Likewise.
* coff-rs6000.c (_bfd_xcoff_archive_p, rs6000coff_core_p): Likewise.
* coff-sh.c (coff_small_object_p): Likewise.
* coff-stgo32.c (go32_check_format): Likewise.
* coff64-rs6000.c (xcoff64_archive_p, rs6000coff_core_p),
(xcoff64_core_p): Likewise.
* coffgen.c (coff_real_object_p, coff_object_p): Likewise.
* elf-bfd.h (bfd_elf32_object_p, bfd_elf32_core_file_p),
(bfd_elf64_object_p, bfd_elf64_core_file_p): Likewise.
* elfcode.h (elf_object_p): Likewise.
* elfcore.h (elf_core_file_p): Likewise.
* i386msdos.c (msdos_object_p): Likewise.
* ihex.c (ihex_object_p): Likewise.
* libaout.h (some_aout_object_p): Likewise.
* libbfd-in.h (bfd_generic_archive_p, _bfd_dummy_target),
(_bfd_vms_lib_alpha_archive_p, _bfd_vms_lib_ia64_archive_p): Likewise.
* libbfd.c (_bfd_dummy_target): Likewise.
* libcoff-in.h (coff_object_p): Likewise.
* mach-o-aarch64.c (bfd_mach_o_arm64_object_p),
(bfd_mach_o_arm64_core_p): Likewise.
* mach-o-arm.c (bfd_mach_o_arm_object_p),
(bfd_mach_o_arm_core_p): Likewise.
* mach-o-i386.c (bfd_mach_o_i386_object_p),
(bfd_mach_o_i386_core_p): Likewise.
* mach-o-x86-64.c (bfd_mach_o_x86_64_object_p),
(bfd_mach_o_x86_64_core_p): Likewise.
* mach-o.c (bfd_mach_o_header_p, bfd_mach_o_gen_object_p),
(bfd_mach_o_gen_core_p, bfd_mach_o_fat_archive_p): Likewise.
* mach-o.h (bfd_mach_o_object_p, bfd_mach_o_core_p),
(bfd_mach_o_fat_archive_p, bfd_mach_o_header_p): Likewise.
* mmo.c (mmo_object_p): Likewise.
* pef.c (bfd_pef_object_p, bfd_pef_xlib_object_p): Likewise.
* peicode.h (coff_real_object_p, pe_ILF_object_p),
(pe_bfd_object_p): Likewise.
* plugin.c (ld_plugin_object_p, bfd_plugin_object_p): Likewise.
* ppcboot.c (ppcboot_object_p): Likewise.
* rs6000-core.c (rs6000coff_core_p): Likewise.
* som.c (som_object_setup, som_object_p): Likewise.
* srec.c (srec_object_p, symbolsrec_object_p): Likewise.
* tekhex.c (tekhex_object_p): Likewise.
* vms-alpha.c (alpha_vms_object_p): Likewise.
* vms-lib.c (_bfd_vms_lib_archive_p, _bfd_vms_lib_alpha_archive_p),
(_bfd_vms_lib_ia64_archive_p, _bfd_vms_lib_txt_archive_p): Likewise.
* wasm-module.c (wasm_object_p): Likewise.
* xsym.c (bfd_sym_object_p): Likewise.
* xsym.h (bfd_sym_object_p): Likewise.
* aoutx.h (some_aout_object_p): Likewise, and callback parameter
return type.
* pdp11.c (some_aout_object_p): Likewise.
* plugin.c (register_ld_plugin_object_p): Update object_p
parameter type.
* plugin.h (register_ld_plugin_object_p): Likewise.
* bfd-in2.h: Regenerate.
* libbfd.h: Regenerate.
* libcoff.h: Regenerate.
ld/
* plugin.c (plugin_object_p): Return a bfd_cleanup.
(plugin_cleanup): New function.
2020-03-02 12:51:09 +08:00
|
|
|
bfd_cleanup
|
2003-08-04 17:39:46 +08:00
|
|
|
elf_core_file_p (bfd *abfd)
|
1999-05-03 15:29:11 +08:00
|
|
|
{
|
2003-02-14 17:21:21 +08:00
|
|
|
Elf_External_Ehdr x_ehdr; /* Elf file header, external form. */
|
|
|
|
Elf_Internal_Ehdr *i_ehdrp; /* Elf file header, internal form. */
|
|
|
|
Elf_Internal_Phdr *i_phdrp; /* Elf program header, internal form. */
|
1999-05-03 15:29:11 +08:00
|
|
|
unsigned int phindex;
|
2003-08-07 16:38:11 +08:00
|
|
|
const struct elf_backend_data *ebd;
|
Touches most files in bfd/, so likely will be blamed for everything..
o bfd_read and bfd_write lose an unnecessary param and become
bfd_bread and bfd_bwrite.
o bfd_*alloc now all take a bfd_size_type arg, and will error if
size_t is too small. eg. 32 bit host, 64 bit bfd, verrry big files
or bugs in linker scripts etc.
o file_ptr becomes a bfd_signed_vma. Besides matching sizes with
various other types involved in handling sections, this should make
it easier for bfd to support a 64 bit off_t on 32 bit hosts that
provide it.
o I've made the H_GET_* and H_PUT_* macros (which invoke bfd_h_{get,put}_*)
generally available. They now cast their args to bfd_vma and
bfd_byte * as appropriate, which removes a swag of casts from the
source.
o Bug fixes to bfd_get8, aix386_core_vec, elf32_h8_relax_section, and
aout-encap.c.
o Zillions of formatting and -Wconversion fixes.
2001-09-18 17:57:26 +08:00
|
|
|
bfd_size_type amt;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
/* Read in the ELF header in external format. */
|
2003-08-04 17:39:46 +08:00
|
|
|
if (bfd_bread (&x_ehdr, sizeof (x_ehdr), abfd) != sizeof (x_ehdr))
|
1999-05-03 15:29:11 +08:00
|
|
|
{
|
|
|
|
if (bfd_get_error () != bfd_error_system_call)
|
2002-11-13 07:25:42 +08:00
|
|
|
goto wrong;
|
|
|
|
else
|
|
|
|
goto fail;
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* Check the magic number. */
|
2002-06-25 14:21:54 +08:00
|
|
|
if (! elf_file_p (&x_ehdr))
|
2000-06-19 09:22:44 +08:00
|
|
|
goto wrong;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2003-02-14 17:21:21 +08:00
|
|
|
/* FIXME: Check EI_VERSION here ! */
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* Check the address size ("class"). */
|
1999-05-03 15:29:11 +08:00
|
|
|
if (x_ehdr.e_ident[EI_CLASS] != ELFCLASS)
|
|
|
|
goto wrong;
|
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* Check the byteorder. */
|
1999-05-03 15:29:11 +08:00
|
|
|
switch (x_ehdr.e_ident[EI_DATA])
|
|
|
|
{
|
2003-02-14 17:21:21 +08:00
|
|
|
case ELFDATA2MSB: /* Big-endian. */
|
1999-05-03 15:29:11 +08:00
|
|
|
if (! bfd_big_endian (abfd))
|
|
|
|
goto wrong;
|
|
|
|
break;
|
2003-02-14 17:21:21 +08:00
|
|
|
case ELFDATA2LSB: /* Little-endian. */
|
1999-05-03 15:29:11 +08:00
|
|
|
if (! bfd_little_endian (abfd))
|
|
|
|
goto wrong;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
goto wrong;
|
|
|
|
}
|
|
|
|
|
2003-07-08 16:08:00 +08:00
|
|
|
/* Give abfd an elf_obj_tdata. */
|
|
|
|
if (! (*abfd->xvec->_bfd_set_format[bfd_core]) (abfd))
|
|
|
|
goto fail;
|
2002-11-13 07:25:42 +08:00
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* Swap in the rest of the header, now that we have the byte order. */
|
1999-05-03 15:29:11 +08:00
|
|
|
i_ehdrp = elf_elfheader (abfd);
|
|
|
|
elf_swap_ehdr_in (abfd, &x_ehdr, i_ehdrp);
|
|
|
|
|
|
|
|
#if DEBUG & 1
|
|
|
|
elf_debug_file (i_ehdrp);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
ebd = get_elf_backend_data (abfd);
|
|
|
|
|
|
|
|
/* Check that the ELF e_machine field matches what this particular
|
|
|
|
BFD format expects. */
|
|
|
|
|
|
|
|
if (ebd->elf_machine_code != i_ehdrp->e_machine
|
|
|
|
&& (ebd->elf_machine_alt1 == 0
|
|
|
|
|| i_ehdrp->e_machine != ebd->elf_machine_alt1)
|
|
|
|
&& (ebd->elf_machine_alt2 == 0
|
|
|
|
|| i_ehdrp->e_machine != ebd->elf_machine_alt2))
|
|
|
|
{
|
|
|
|
const bfd_target * const *target_ptr;
|
|
|
|
|
|
|
|
if (ebd->elf_machine_code != EM_NONE)
|
|
|
|
goto wrong;
|
|
|
|
|
|
|
|
/* This is the generic ELF target. Let it match any ELF target
|
|
|
|
for which we do not have a specific backend. */
|
|
|
|
|
|
|
|
for (target_ptr = bfd_target_vector; *target_ptr != NULL; target_ptr++)
|
|
|
|
{
|
2003-08-07 16:38:11 +08:00
|
|
|
const struct elf_backend_data *back;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
if ((*target_ptr)->flavour != bfd_target_elf_flavour)
|
|
|
|
continue;
|
2007-08-05 00:31:00 +08:00
|
|
|
back = xvec_get_elf_backend_data (*target_ptr);
|
2008-08-01 20:21:28 +08:00
|
|
|
if (back->s->arch_size != ARCH_SIZE)
|
|
|
|
continue;
|
2003-02-14 17:21:21 +08:00
|
|
|
if (back->elf_machine_code == i_ehdrp->e_machine
|
|
|
|
|| (back->elf_machine_alt1 != 0
|
BFD whitespace fixes
Binutils is supposed to use tabs. In my git config I have
whitespace = indent-with-non-tab,space-before-tab,trailing-space
and I got annoyed enough seeing red in "git diff" output to fix
the problems.
* doc/header.sed: Trim trailing space when splitting lines.
* aix386-core.c, * aout-adobe.c, * aout-arm.c, * aout-cris.c,
* aout-ns32k.c, * aout-target.h, * aout-tic30.c, * aoutf1.h, * aoutx.h,
* arc-got.h, * arc-plt.def, * arc-plt.h, * archive.c, * archive64.c,
* archures.c, * armnetbsd.c, * bfd-in.h, * bfd.c, * bfdio.c, * binary.c,
* bout.c, * cache.c, * cisco-core.c, * coff-alpha.c, * coff-apollo.c,
* coff-arm.c, * coff-h8300.c, * coff-i386.c, * coff-i860.c,
* coff-i960.c, * coff-m68k.c, * coff-m88k.c, * coff-mcore.c,
* coff-mips.c, * coff-ppc.c, * coff-rs6000.c, * coff-sh.c,
* coff-stgo32.c, * coff-tic4x.c, * coff-tic54x.c, * coff-tic80.c,
* coff-we32k.c, * coff-x86_64.c, * coff-z80.c, * coff-z8k.c,
* coff64-rs6000.c, * coffcode.h, * coffgen.c, * cofflink.c,
* coffswap.h, * compress.c, * corefile.c, * cpu-alpha.c, * cpu-arm.c,
* cpu-avr.c, * cpu-bfin.c, * cpu-cr16.c, * cpu-cr16c.c, * cpu-crx.c,
* cpu-d10v.c, * cpu-frv.c, * cpu-ft32.c, * cpu-i370.c, * cpu-i960.c,
* cpu-ia64-opc.c, * cpu-ip2k.c, * cpu-lm32.c, * cpu-m32r.c,
* cpu-mcore.c, * cpu-microblaze.c, * cpu-mips.c, * cpu-moxie.c,
* cpu-mt.c, * cpu-nios2.c, * cpu-ns32k.c, * cpu-or1k.c, * cpu-powerpc.c,
* cpu-pru.c, * cpu-sh.c, * cpu-spu.c, * cpu-v850.c, * cpu-v850_rh850.c,
* cpu-xgate.c, * cpu-z80.c, * dwarf1.c, * dwarf2.c, * ecoff.c,
* ecofflink.c, * ecoffswap.h, * elf-bfd.h, * elf-eh-frame.c,
* elf-hppa.h, * elf-m10200.c, * elf-m10300.c, * elf-s390-common.c,
* elf-strtab.c, * elf-vxworks.c, * elf.c, * elf32-am33lin.c,
* elf32-arc.c, * elf32-arm.c, * elf32-avr.c, * elf32-avr.h,
* elf32-bfin.c, * elf32-cr16.c, * elf32-cr16c.c, * elf32-cris.c,
* elf32-crx.c, * elf32-d10v.c, * elf32-d30v.c, * elf32-dlx.c,
* elf32-epiphany.c, * elf32-fr30.c, * elf32-frv.c, * elf32-ft32.c,
* elf32-h8300.c, * elf32-hppa.c, * elf32-i386.c, * elf32-i860.c,
* elf32-i960.c, * elf32-ip2k.c, * elf32-lm32.c, * elf32-m32c.c,
* elf32-m32r.c, * elf32-m68hc11.c, * elf32-m68hc12.c, * elf32-m68hc1x.c,
* elf32-m68hc1x.h, * elf32-m68k.c, * elf32-m88k.c, * elf32-mcore.c,
* elf32-mep.c, * elf32-metag.c, * elf32-microblaze.c, * elf32-mips.c,
* elf32-moxie.c, * elf32-msp430.c, * elf32-mt.c, * elf32-nds32.c,
* elf32-nds32.h, * elf32-nios2.c, * elf32-or1k.c, * elf32-pj.c,
* elf32-ppc.c, * elf32-ppc.h, * elf32-pru.c, * elf32-rl78.c,
* elf32-rx.c, * elf32-s390.c, * elf32-score.c, * elf32-score.h,
* elf32-score7.c, * elf32-sh-symbian.c, * elf32-sh.c, * elf32-sh64.c,
* elf32-sparc.c, * elf32-spu.c, * elf32-tic6x.c, * elf32-tilegx.c,
* elf32-tilegx.h, * elf32-tilepro.c, * elf32-tilepro.h, * elf32-v850.c,
* elf32-vax.c, * elf32-wasm32.c, * elf32-xc16x.c, * elf32-xgate.c,
* elf32-xgate.h, * elf32-xstormy16.c, * elf32-xtensa.c, * elf64-alpha.c,
* elf64-hppa.c, * elf64-ia64-vms.c, * elf64-mips.c, * elf64-mmix.c,
* elf64-ppc.c, * elf64-s390.c, * elf64-sh64.c, * elf64-sparc.c,
* elf64-tilegx.c, * elf64-tilegx.h, * elf64-x86-64.c, * elfcore.h,
* elflink.c, * elfn32-mips.c, * elfnn-aarch64.c, * elfnn-ia64.c,
* elfnn-riscv.c, * elfxx-aarch64.c, * elfxx-aarch64.h, * elfxx-ia64.c,
* elfxx-ia64.h, * elfxx-mips.c, * elfxx-riscv.c, * elfxx-sparc.c,
* elfxx-tilegx.c, * elfxx-x86.c, * elfxx-x86.h, * freebsd.h, * hash.c,
* host-aout.c, * hp300hpux.c, * hppabsd-core.c, * hpux-core.c,
* i386aout.c, * i386linux.c, * i386lynx.c, * i386mach3.c, * i386msdos.c,
* i386netbsd.c, * ieee.c, * ihex.c, * irix-core.c, * libaout.h,
* libbfd-in.h, * libbfd.c, * libcoff-in.h, * libnlm.h, * libpei.h,
* libxcoff.h, * linker.c, * lynx-core.c, * m68k4knetbsd.c,
* m68klinux.c, * m68knetbsd.c, * m88kmach3.c, * mach-o-aarch64.c,
* mach-o-arm.c, * mach-o-i386.c, * mach-o-target.c, * mach-o-x86-64.c,
* mach-o.c, * mach-o.h, * merge.c, * mipsbsd.c, * mmo.c, * netbsd.h,
* netbsd-core.c, * newsos3.c, * nlm-target.h, * nlm32-ppc.c,
* nlm32-sparc.c, * nlmcode.h, * ns32k.h, * ns32knetbsd.c, * oasys.c,
* opncls.c, * pc532-mach.c, * pdp11.c, * pe-arm.c, * pe-i386.c,
* pe-mcore.c, * pe-mips.c, * pe-x86_64.c, * peXXigen.c, * pef.c,
* pef.h, * pei-arm.c, * pei-i386.c, * pei-mcore.c, * pei-x86_64.c,
* peicode.h, * plugin.c, * ppcboot.c, * ptrace-core.c, * reloc.c,
* riscix.c, * rs6000-core.c, * section.c, * som.c, * som.h,
* sparclinux.c, * sparcnetbsd.c, * srec.c, * stabs.c, * sunos.c,
* syms.c, * targets.c, * tekhex.c, * trad-core.c, * vax1knetbsd.c,
* vaxnetbsd.c, * verilog.c, * versados.c, * vms-alpha.c, * vms-lib.c,
* vms-misc.c, * wasm-module.c, * wasm-module.h, * xcofflink.c,
* xsym.c, * xsym.h: Whitespace fixes.
* bfd-in2.h, * libbfd.h, * libcoff.h: Regenerate.
2017-12-06 06:56:00 +08:00
|
|
|
&& i_ehdrp->e_machine == back->elf_machine_alt1)
|
2003-02-14 17:21:21 +08:00
|
|
|
|| (back->elf_machine_alt2 != 0
|
BFD whitespace fixes
Binutils is supposed to use tabs. In my git config I have
whitespace = indent-with-non-tab,space-before-tab,trailing-space
and I got annoyed enough seeing red in "git diff" output to fix
the problems.
* doc/header.sed: Trim trailing space when splitting lines.
* aix386-core.c, * aout-adobe.c, * aout-arm.c, * aout-cris.c,
* aout-ns32k.c, * aout-target.h, * aout-tic30.c, * aoutf1.h, * aoutx.h,
* arc-got.h, * arc-plt.def, * arc-plt.h, * archive.c, * archive64.c,
* archures.c, * armnetbsd.c, * bfd-in.h, * bfd.c, * bfdio.c, * binary.c,
* bout.c, * cache.c, * cisco-core.c, * coff-alpha.c, * coff-apollo.c,
* coff-arm.c, * coff-h8300.c, * coff-i386.c, * coff-i860.c,
* coff-i960.c, * coff-m68k.c, * coff-m88k.c, * coff-mcore.c,
* coff-mips.c, * coff-ppc.c, * coff-rs6000.c, * coff-sh.c,
* coff-stgo32.c, * coff-tic4x.c, * coff-tic54x.c, * coff-tic80.c,
* coff-we32k.c, * coff-x86_64.c, * coff-z80.c, * coff-z8k.c,
* coff64-rs6000.c, * coffcode.h, * coffgen.c, * cofflink.c,
* coffswap.h, * compress.c, * corefile.c, * cpu-alpha.c, * cpu-arm.c,
* cpu-avr.c, * cpu-bfin.c, * cpu-cr16.c, * cpu-cr16c.c, * cpu-crx.c,
* cpu-d10v.c, * cpu-frv.c, * cpu-ft32.c, * cpu-i370.c, * cpu-i960.c,
* cpu-ia64-opc.c, * cpu-ip2k.c, * cpu-lm32.c, * cpu-m32r.c,
* cpu-mcore.c, * cpu-microblaze.c, * cpu-mips.c, * cpu-moxie.c,
* cpu-mt.c, * cpu-nios2.c, * cpu-ns32k.c, * cpu-or1k.c, * cpu-powerpc.c,
* cpu-pru.c, * cpu-sh.c, * cpu-spu.c, * cpu-v850.c, * cpu-v850_rh850.c,
* cpu-xgate.c, * cpu-z80.c, * dwarf1.c, * dwarf2.c, * ecoff.c,
* ecofflink.c, * ecoffswap.h, * elf-bfd.h, * elf-eh-frame.c,
* elf-hppa.h, * elf-m10200.c, * elf-m10300.c, * elf-s390-common.c,
* elf-strtab.c, * elf-vxworks.c, * elf.c, * elf32-am33lin.c,
* elf32-arc.c, * elf32-arm.c, * elf32-avr.c, * elf32-avr.h,
* elf32-bfin.c, * elf32-cr16.c, * elf32-cr16c.c, * elf32-cris.c,
* elf32-crx.c, * elf32-d10v.c, * elf32-d30v.c, * elf32-dlx.c,
* elf32-epiphany.c, * elf32-fr30.c, * elf32-frv.c, * elf32-ft32.c,
* elf32-h8300.c, * elf32-hppa.c, * elf32-i386.c, * elf32-i860.c,
* elf32-i960.c, * elf32-ip2k.c, * elf32-lm32.c, * elf32-m32c.c,
* elf32-m32r.c, * elf32-m68hc11.c, * elf32-m68hc12.c, * elf32-m68hc1x.c,
* elf32-m68hc1x.h, * elf32-m68k.c, * elf32-m88k.c, * elf32-mcore.c,
* elf32-mep.c, * elf32-metag.c, * elf32-microblaze.c, * elf32-mips.c,
* elf32-moxie.c, * elf32-msp430.c, * elf32-mt.c, * elf32-nds32.c,
* elf32-nds32.h, * elf32-nios2.c, * elf32-or1k.c, * elf32-pj.c,
* elf32-ppc.c, * elf32-ppc.h, * elf32-pru.c, * elf32-rl78.c,
* elf32-rx.c, * elf32-s390.c, * elf32-score.c, * elf32-score.h,
* elf32-score7.c, * elf32-sh-symbian.c, * elf32-sh.c, * elf32-sh64.c,
* elf32-sparc.c, * elf32-spu.c, * elf32-tic6x.c, * elf32-tilegx.c,
* elf32-tilegx.h, * elf32-tilepro.c, * elf32-tilepro.h, * elf32-v850.c,
* elf32-vax.c, * elf32-wasm32.c, * elf32-xc16x.c, * elf32-xgate.c,
* elf32-xgate.h, * elf32-xstormy16.c, * elf32-xtensa.c, * elf64-alpha.c,
* elf64-hppa.c, * elf64-ia64-vms.c, * elf64-mips.c, * elf64-mmix.c,
* elf64-ppc.c, * elf64-s390.c, * elf64-sh64.c, * elf64-sparc.c,
* elf64-tilegx.c, * elf64-tilegx.h, * elf64-x86-64.c, * elfcore.h,
* elflink.c, * elfn32-mips.c, * elfnn-aarch64.c, * elfnn-ia64.c,
* elfnn-riscv.c, * elfxx-aarch64.c, * elfxx-aarch64.h, * elfxx-ia64.c,
* elfxx-ia64.h, * elfxx-mips.c, * elfxx-riscv.c, * elfxx-sparc.c,
* elfxx-tilegx.c, * elfxx-x86.c, * elfxx-x86.h, * freebsd.h, * hash.c,
* host-aout.c, * hp300hpux.c, * hppabsd-core.c, * hpux-core.c,
* i386aout.c, * i386linux.c, * i386lynx.c, * i386mach3.c, * i386msdos.c,
* i386netbsd.c, * ieee.c, * ihex.c, * irix-core.c, * libaout.h,
* libbfd-in.h, * libbfd.c, * libcoff-in.h, * libnlm.h, * libpei.h,
* libxcoff.h, * linker.c, * lynx-core.c, * m68k4knetbsd.c,
* m68klinux.c, * m68knetbsd.c, * m88kmach3.c, * mach-o-aarch64.c,
* mach-o-arm.c, * mach-o-i386.c, * mach-o-target.c, * mach-o-x86-64.c,
* mach-o.c, * mach-o.h, * merge.c, * mipsbsd.c, * mmo.c, * netbsd.h,
* netbsd-core.c, * newsos3.c, * nlm-target.h, * nlm32-ppc.c,
* nlm32-sparc.c, * nlmcode.h, * ns32k.h, * ns32knetbsd.c, * oasys.c,
* opncls.c, * pc532-mach.c, * pdp11.c, * pe-arm.c, * pe-i386.c,
* pe-mcore.c, * pe-mips.c, * pe-x86_64.c, * peXXigen.c, * pef.c,
* pef.h, * pei-arm.c, * pei-i386.c, * pei-mcore.c, * pei-x86_64.c,
* peicode.h, * plugin.c, * ppcboot.c, * ptrace-core.c, * reloc.c,
* riscix.c, * rs6000-core.c, * section.c, * som.c, * som.h,
* sparclinux.c, * sparcnetbsd.c, * srec.c, * stabs.c, * sunos.c,
* syms.c, * targets.c, * tekhex.c, * trad-core.c, * vax1knetbsd.c,
* vaxnetbsd.c, * verilog.c, * versados.c, * vms-alpha.c, * vms-lib.c,
* vms-misc.c, * wasm-module.c, * wasm-module.h, * xcofflink.c,
* xsym.c, * xsym.h: Whitespace fixes.
* bfd-in2.h, * libbfd.h, * libcoff.h: Regenerate.
2017-12-06 06:56:00 +08:00
|
|
|
&& i_ehdrp->e_machine == back->elf_machine_alt2))
|
1999-05-03 15:29:11 +08:00
|
|
|
{
|
|
|
|
/* target_ptr is an ELF backend which matches this
|
|
|
|
object file, so reject the generic ELF target. */
|
|
|
|
goto wrong;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* If there is no program header, or the type is not a core file, then
|
2001-01-04 06:53:39 +08:00
|
|
|
we are hosed. */
|
1999-05-03 15:29:11 +08:00
|
|
|
if (i_ehdrp->e_phoff == 0 || i_ehdrp->e_type != ET_CORE)
|
|
|
|
goto wrong;
|
|
|
|
|
|
|
|
/* Does BFD's idea of the phdr size match the size
|
|
|
|
recorded in the file? */
|
|
|
|
if (i_ehdrp->e_phentsize != sizeof (Elf_External_Phdr))
|
|
|
|
goto wrong;
|
|
|
|
|
2010-01-19 21:50:55 +08:00
|
|
|
/* If the program header count is PN_XNUM(0xffff), the actual
|
|
|
|
count is in the first section header. */
|
|
|
|
if (i_ehdrp->e_shoff != 0 && i_ehdrp->e_phnum == PN_XNUM)
|
|
|
|
{
|
|
|
|
Elf_External_Shdr x_shdr;
|
|
|
|
Elf_Internal_Shdr i_shdr;
|
2015-10-15 19:56:55 +08:00
|
|
|
file_ptr where = (file_ptr) i_ehdrp->e_shoff;
|
2010-01-19 21:50:55 +08:00
|
|
|
|
|
|
|
/* Seek to the section header table in the file. */
|
2015-10-15 19:56:55 +08:00
|
|
|
if (bfd_seek (abfd, where, SEEK_SET) != 0)
|
2010-01-19 21:50:55 +08:00
|
|
|
goto fail;
|
|
|
|
|
|
|
|
/* Read the first section header at index 0, and convert to internal
|
|
|
|
form. */
|
|
|
|
if (bfd_bread (&x_shdr, sizeof (x_shdr), abfd) != sizeof (x_shdr))
|
|
|
|
goto fail;
|
|
|
|
elf_swap_shdr_in (abfd, &x_shdr, &i_shdr);
|
|
|
|
|
|
|
|
if (i_shdr.sh_info != 0)
|
|
|
|
{
|
|
|
|
i_ehdrp->e_phnum = i_shdr.sh_info;
|
|
|
|
if (i_ehdrp->e_phnum != i_shdr.sh_info)
|
|
|
|
goto wrong;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Sanity check that we can read all of the program headers.
|
|
|
|
It ought to be good enough to just read the last one. */
|
|
|
|
if (i_ehdrp->e_phnum > 1)
|
|
|
|
{
|
|
|
|
Elf_External_Phdr x_phdr;
|
|
|
|
Elf_Internal_Phdr i_phdr;
|
2015-10-15 19:56:55 +08:00
|
|
|
file_ptr where;
|
2010-01-19 21:50:55 +08:00
|
|
|
|
|
|
|
/* Check that we don't have a totally silly number of
|
|
|
|
program headers. */
|
|
|
|
if (i_ehdrp->e_phnum > (unsigned int) -1 / sizeof (x_phdr)
|
|
|
|
|| i_ehdrp->e_phnum > (unsigned int) -1 / sizeof (i_phdr))
|
|
|
|
goto wrong;
|
|
|
|
|
2015-10-15 19:56:55 +08:00
|
|
|
where = (file_ptr)(i_ehdrp->e_phoff + (i_ehdrp->e_phnum - 1) * sizeof (x_phdr));
|
2010-01-19 21:50:55 +08:00
|
|
|
if ((bfd_size_type) where <= i_ehdrp->e_phoff)
|
|
|
|
goto wrong;
|
|
|
|
|
2015-10-15 19:56:55 +08:00
|
|
|
if (bfd_seek (abfd, where, SEEK_SET) != 0)
|
2010-01-19 21:50:55 +08:00
|
|
|
goto fail;
|
|
|
|
if (bfd_bread (&x_phdr, sizeof (x_phdr), abfd) != sizeof (x_phdr))
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
|
2000-12-16 02:53:04 +08:00
|
|
|
/* Move to the start of the program headers. */
|
Touches most files in bfd/, so likely will be blamed for everything..
o bfd_read and bfd_write lose an unnecessary param and become
bfd_bread and bfd_bwrite.
o bfd_*alloc now all take a bfd_size_type arg, and will error if
size_t is too small. eg. 32 bit host, 64 bit bfd, verrry big files
or bugs in linker scripts etc.
o file_ptr becomes a bfd_signed_vma. Besides matching sizes with
various other types involved in handling sections, this should make
it easier for bfd to support a 64 bit off_t on 32 bit hosts that
provide it.
o I've made the H_GET_* and H_PUT_* macros (which invoke bfd_h_{get,put}_*)
generally available. They now cast their args to bfd_vma and
bfd_byte * as appropriate, which removes a swag of casts from the
source.
o Bug fixes to bfd_get8, aix386_core_vec, elf32_h8_relax_section, and
aout-encap.c.
o Zillions of formatting and -Wconversion fixes.
2001-09-18 17:57:26 +08:00
|
|
|
if (bfd_seek (abfd, (file_ptr) i_ehdrp->e_phoff, SEEK_SET) != 0)
|
2000-12-16 02:53:04 +08:00
|
|
|
goto wrong;
|
2001-01-04 06:53:39 +08:00
|
|
|
|
|
|
|
/* Allocate space for the program headers. */
|
Touches most files in bfd/, so likely will be blamed for everything..
o bfd_read and bfd_write lose an unnecessary param and become
bfd_bread and bfd_bwrite.
o bfd_*alloc now all take a bfd_size_type arg, and will error if
size_t is too small. eg. 32 bit host, 64 bit bfd, verrry big files
or bugs in linker scripts etc.
o file_ptr becomes a bfd_signed_vma. Besides matching sizes with
various other types involved in handling sections, this should make
it easier for bfd to support a 64 bit off_t on 32 bit hosts that
provide it.
o I've made the H_GET_* and H_PUT_* macros (which invoke bfd_h_{get,put}_*)
generally available. They now cast their args to bfd_vma and
bfd_byte * as appropriate, which removes a swag of casts from the
source.
o Bug fixes to bfd_get8, aix386_core_vec, elf32_h8_relax_section, and
aout-encap.c.
o Zillions of formatting and -Wconversion fixes.
2001-09-18 17:57:26 +08:00
|
|
|
amt = sizeof (*i_phdrp) * i_ehdrp->e_phnum;
|
2009-09-10 05:38:59 +08:00
|
|
|
i_phdrp = (Elf_Internal_Phdr *) bfd_alloc (abfd, amt);
|
1999-05-03 15:29:11 +08:00
|
|
|
if (!i_phdrp)
|
2000-04-08 04:27:29 +08:00
|
|
|
goto fail;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
elf_tdata (abfd)->phdr = i_phdrp;
|
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* Read and convert to internal form. */
|
1999-05-03 15:29:11 +08:00
|
|
|
for (phindex = 0; phindex < i_ehdrp->e_phnum; ++phindex)
|
|
|
|
{
|
|
|
|
Elf_External_Phdr x_phdr;
|
2003-02-14 17:21:21 +08:00
|
|
|
|
2003-08-04 17:39:46 +08:00
|
|
|
if (bfd_bread (&x_phdr, sizeof (x_phdr), abfd) != sizeof (x_phdr))
|
2000-04-08 04:27:29 +08:00
|
|
|
goto fail;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
elf_swap_phdr_in (abfd, &x_phdr, i_phdrp + phindex);
|
|
|
|
}
|
|
|
|
|
2002-01-29 00:48:52 +08:00
|
|
|
/* Set the machine architecture. Do this before processing the
|
|
|
|
program headers since we need to know the architecture type
|
|
|
|
when processing the notes of some systems' core files. */
|
2005-02-15 00:17:04 +08:00
|
|
|
if (! bfd_default_set_arch_mach (abfd, ebd->arch, 0)
|
1999-05-03 15:29:11 +08:00
|
|
|
/* It's OK if this fails for the generic target. */
|
2005-02-15 00:17:04 +08:00
|
|
|
&& ebd->elf_machine_code != EM_NONE)
|
|
|
|
goto fail;
|
|
|
|
|
|
|
|
/* Let the backend double check the format and override global
|
|
|
|
information. We do this before processing the program headers
|
|
|
|
to allow the correct machine (as opposed to just the default
|
|
|
|
machine) to be set, making it possible for grok_prstatus and
|
|
|
|
grok_psinfo to rely on the mach setting. */
|
|
|
|
if (ebd->elf_backend_object_p != NULL
|
|
|
|
&& ! ebd->elf_backend_object_p (abfd))
|
|
|
|
goto wrong;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2002-01-28 07:27:23 +08:00
|
|
|
/* Process each program header. */
|
|
|
|
for (phindex = 0; phindex < i_ehdrp->e_phnum; ++phindex)
|
2003-02-14 17:21:21 +08:00
|
|
|
if (! bfd_section_from_phdr (abfd, i_phdrp + phindex, (int) phindex))
|
|
|
|
goto fail;
|
2002-01-28 07:27:23 +08:00
|
|
|
|
2008-05-10 09:58:17 +08:00
|
|
|
/* Check for core truncation. */
|
|
|
|
{
|
|
|
|
bfd_size_type high = 0;
|
|
|
|
struct stat statbuf;
|
2013-01-11 04:03:55 +08:00
|
|
|
for (phindex = 0; phindex < i_ehdrp->e_phnum; ++phindex)
|
2008-05-10 09:58:17 +08:00
|
|
|
{
|
|
|
|
Elf_Internal_Phdr *p = i_phdrp + phindex;
|
|
|
|
if (p->p_filesz)
|
|
|
|
{
|
|
|
|
bfd_size_type current = p->p_offset + p->p_filesz;
|
|
|
|
if (high < current)
|
|
|
|
high = current;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (bfd_stat (abfd, &statbuf) == 0)
|
|
|
|
{
|
|
|
|
if ((bfd_size_type) statbuf.st_size < high)
|
|
|
|
{
|
Remove syntactic sugar
Now that _bfd_error_handler is not a function pointer.
* aout-adobe.c: Replace (*_bfd_error_handler) (...) with
_bfd_error_handler (...) throughout.
* aout-cris.c, * aoutx.h, * archive.c, * bfd.c, * binary.c,
* cache.c, * coff-alpha.c, * coff-arm.c, * coff-h8300.c,
* coff-i860.c, * coff-mcore.c, * coff-ppc.c, * coff-rs6000.c,
* coff-sh.c, * coff-tic4x.c, * coff-tic54x.c, * coff-tic80.c,
* coff64-rs6000.c, * coffcode.h, * coffgen.c, * cofflink.c,
* coffswap.h, * cpu-arm.c, * cpu-m68k.c, * cpu-sh.c, * dwarf2.c,
* ecoff.c, * elf-eh-frame.c, * elf-m10300.c, * elf.c, * elf32-arc.c,
* elf32-arm.c, * elf32-avr.c, * elf32-bfin.c, * elf32-cr16.c,
* elf32-cris.c, * elf32-crx.c, * elf32-dlx.c, * elf32-frv.c,
* elf32-hppa.c, * elf32-i370.c, * elf32-i386.c, * elf32-lm32.c,
* elf32-m32c.c, * elf32-m32r.c, * elf32-m68hc1x.c, * elf32-m68k.c,
* elf32-mcore.c, * elf32-mep.c, * elf32-metag.c, * elf32-microblaze.c,
* elf32-mips.c, * elf32-nds32.c, * elf32-nios2.c, * elf32-or1k.c,
* elf32-pj.c, * elf32-ppc.c, * elf32-rl78.c, * elf32-s390.c,
* elf32-score.c, * elf32-score7.c, * elf32-sh.c, * elf32-sh64.c,
* elf32-sparc.c, * elf32-spu.c, * elf32-tic6x.c, * elf32-tilepro.c,
* elf32-v850.c, * elf32-vax.c, * elf32-xtensa.c, * elf64-alpha.c,
* elf64-hppa.c, * elf64-ia64-vms.c, * elf64-mips.c, * elf64-mmix.c,
* elf64-ppc.c, * elf64-s390.c, * elf64-sh64.c, * elf64-sparc.c,
* elf64-x86-64.c, * elfcode.h, * elfcore.h, * elflink.c,
* elfn32-mips.c, * elfnn-aarch64.c, * elfnn-ia64.c, * elfxx-mips.c,
* elfxx-sparc.c, * elfxx-tilegx.c, * hpux-core.c, * i386linux.c,
* ieee.c, * ihex.c, * libbfd.c, * linker.c, * m68klinux.c,
* mach-o.c, * merge.c, * mmo.c, * oasys.c, * osf-core.c, * pdp11.c,
* pe-mips.c, * peXXigen.c, * pef.c, * plugin.c, * reloc.c,
* rs6000-core.c, * sco5-core.c, * som.c, * sparclinux.c, * srec.c,
* stabs.c, * syms.c, * vms-alpha.c, * vms-lib.c, * vms-misc.c,
* xcofflink.c: Likewise.
2016-09-30 11:30:18 +08:00
|
|
|
_bfd_error_handler
|
2016-10-19 21:04:34 +08:00
|
|
|
/* xgettext:c-format */
|
2018-02-19 12:51:40 +08:00
|
|
|
(_("warning: %pB is truncated: expected core file "
|
2018-02-19 16:18:15 +08:00
|
|
|
"size >= %" PRIu64 ", found: %" PRIu64),
|
|
|
|
abfd, (uint64_t) high, (uint64_t) statbuf.st_size);
|
2008-05-10 09:58:17 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-01-11 04:03:55 +08:00
|
|
|
|
2001-01-04 06:53:39 +08:00
|
|
|
/* Save the entry point from the ELF header. */
|
2019-09-18 13:37:33 +08:00
|
|
|
abfd->start_address = i_ehdrp->e_entry;
|
bfd_cleanup for object_p
The object_p (and archive_p, core_file_p) functions are not supposed
to have any target specific malloc'd memory attached to the bfd on
their return. This should be obvious on a failure return, but it's
also true for a successful return. The reason is that even though the
object_p recognises the file, that particular target may not be used
and thus the bfd won't be closed calling close_and_cleanup for the
target that allocated the memory.
It turns out that the object_p bfd_target* return value isn't needed.
In all cases except ld/plugin.c the target is abfd->xvec and with
ld/plugin.c the target isn't used. So this patch returns a cleanup
function from object_p instead, called in bfd_check_format_matches to
tidy the bfd before trying a different target match. The only cleanup
that does anything at this stage is the alpha-vms one.
bfd/
* targets.c (bfd_cleanup): New typedef.
(struct bfd <_bfd_check_format>): Return a bfd_cleanup.
* libbfd-in.h (_bfd_no_cleanup): Define.
* format.c (bfd_reinit): Add cleanup parameter, call it.
(bfd_check_format_matches): Set cleanup from _bfd_check_format
call and pass to bfd_reinit. Delete temp, use abfd->xvec instead.
* aout-target.h (callback, object_p): Return bfd_cleanup.
* aout-tic30.c (tic30_aout_callback, tic30_aout_object_p): Likewise.
* archive.c (bfd_generic_archive_p): Likewise.
* binary.c (binary_object_p): Likewise.
* coff-alpha.c (alpha_ecoff_object_p): Likewise.
* coff-ia64.c (ia64coff_object_p): Likewise.
* coff-rs6000.c (_bfd_xcoff_archive_p, rs6000coff_core_p): Likewise.
* coff-sh.c (coff_small_object_p): Likewise.
* coff-stgo32.c (go32_check_format): Likewise.
* coff64-rs6000.c (xcoff64_archive_p, rs6000coff_core_p),
(xcoff64_core_p): Likewise.
* coffgen.c (coff_real_object_p, coff_object_p): Likewise.
* elf-bfd.h (bfd_elf32_object_p, bfd_elf32_core_file_p),
(bfd_elf64_object_p, bfd_elf64_core_file_p): Likewise.
* elfcode.h (elf_object_p): Likewise.
* elfcore.h (elf_core_file_p): Likewise.
* i386msdos.c (msdos_object_p): Likewise.
* ihex.c (ihex_object_p): Likewise.
* libaout.h (some_aout_object_p): Likewise.
* libbfd-in.h (bfd_generic_archive_p, _bfd_dummy_target),
(_bfd_vms_lib_alpha_archive_p, _bfd_vms_lib_ia64_archive_p): Likewise.
* libbfd.c (_bfd_dummy_target): Likewise.
* libcoff-in.h (coff_object_p): Likewise.
* mach-o-aarch64.c (bfd_mach_o_arm64_object_p),
(bfd_mach_o_arm64_core_p): Likewise.
* mach-o-arm.c (bfd_mach_o_arm_object_p),
(bfd_mach_o_arm_core_p): Likewise.
* mach-o-i386.c (bfd_mach_o_i386_object_p),
(bfd_mach_o_i386_core_p): Likewise.
* mach-o-x86-64.c (bfd_mach_o_x86_64_object_p),
(bfd_mach_o_x86_64_core_p): Likewise.
* mach-o.c (bfd_mach_o_header_p, bfd_mach_o_gen_object_p),
(bfd_mach_o_gen_core_p, bfd_mach_o_fat_archive_p): Likewise.
* mach-o.h (bfd_mach_o_object_p, bfd_mach_o_core_p),
(bfd_mach_o_fat_archive_p, bfd_mach_o_header_p): Likewise.
* mmo.c (mmo_object_p): Likewise.
* pef.c (bfd_pef_object_p, bfd_pef_xlib_object_p): Likewise.
* peicode.h (coff_real_object_p, pe_ILF_object_p),
(pe_bfd_object_p): Likewise.
* plugin.c (ld_plugin_object_p, bfd_plugin_object_p): Likewise.
* ppcboot.c (ppcboot_object_p): Likewise.
* rs6000-core.c (rs6000coff_core_p): Likewise.
* som.c (som_object_setup, som_object_p): Likewise.
* srec.c (srec_object_p, symbolsrec_object_p): Likewise.
* tekhex.c (tekhex_object_p): Likewise.
* vms-alpha.c (alpha_vms_object_p): Likewise.
* vms-lib.c (_bfd_vms_lib_archive_p, _bfd_vms_lib_alpha_archive_p),
(_bfd_vms_lib_ia64_archive_p, _bfd_vms_lib_txt_archive_p): Likewise.
* wasm-module.c (wasm_object_p): Likewise.
* xsym.c (bfd_sym_object_p): Likewise.
* xsym.h (bfd_sym_object_p): Likewise.
* aoutx.h (some_aout_object_p): Likewise, and callback parameter
return type.
* pdp11.c (some_aout_object_p): Likewise.
* plugin.c (register_ld_plugin_object_p): Update object_p
parameter type.
* plugin.h (register_ld_plugin_object_p): Likewise.
* bfd-in2.h: Regenerate.
* libbfd.h: Regenerate.
* libcoff.h: Regenerate.
ld/
* plugin.c (plugin_object_p): Return a bfd_cleanup.
(plugin_cleanup): New function.
2020-03-02 12:51:09 +08:00
|
|
|
return _bfd_no_cleanup;
|
2000-04-08 04:27:29 +08:00
|
|
|
|
2020-02-25 13:04:46 +08:00
|
|
|
wrong:
|
2000-04-08 04:27:29 +08:00
|
|
|
bfd_set_error (bfd_error_wrong_format);
|
2020-02-25 13:04:46 +08:00
|
|
|
fail:
|
2000-04-08 04:27:29 +08:00
|
|
|
return NULL;
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
2019-10-30 20:23:16 +08:00
|
|
|
|
|
|
|
/* Attempt to find a build-id in a core file from the core file BFD.
|
|
|
|
OFFSET is the file offset to a PT_LOAD segment that may contain
|
|
|
|
the build-id note. Returns TRUE upon success, FALSE otherwise. */
|
|
|
|
|
|
|
|
bfd_boolean
|
|
|
|
NAME(_bfd_elf, core_find_build_id)
|
|
|
|
(bfd *abfd,
|
|
|
|
bfd_vma offset)
|
|
|
|
{
|
|
|
|
Elf_External_Ehdr x_ehdr; /* Elf file header, external form. */
|
|
|
|
Elf_Internal_Ehdr i_ehdr; /* Elf file header, internal form. */
|
|
|
|
Elf_Internal_Phdr *i_phdr;
|
|
|
|
unsigned int i;
|
_bfd_mul_overflow
This patch removes the bfd_alloc2 series of memory allocation functions,
replacing them with __builtin_mul_overflow followed by bfd_alloc. Why
do that? Well, a followup patch will implement _bfd_alloc_and_read
and I don't want to implement alloc2 variants as well.
* coffcode.h (buy_and_read, coff_slurp_line_table),
(coff_slurp_symbol_table, coff_slurp_reloc_table): Replace
bfd_[z][m]alloc2 calls with _bfd_mul_overflow followed by the
corresponding bfd_alloc call. Adjust variables to suit.
* coffgen.c (_bfd_coff_get_external_symbols): Likewise.
* ecoff.c (_bfd_ecoff_slurp_symbolic_info),
(_bfd_ecoff_slurp_symbol_table, READ): Likewise.
* elf.c (bfd_elf_get_elf_syms, setup_group, bfd_section_from_shdr),
(swap_out_syms, _bfd_elf_slurp_version_tables): Likewise.
* elf32-m32c.c (m32c_elf_relax_section): Likewise.
* elf32-rl78.c (rl78_elf_relax_section): Likewise.
* elf32-rx.c (elf32_rx_relax_section): Likewise.
* elf64-alpha.c (READ): Likewise.
* elfcode.h (elf_object_p, elf_write_relocs, elf_write_shdrs_and_ehdr),
(elf_slurp_symbol_table, elf_slurp_reloc_table),
(bfd_from_remote_memory): Likewise.
* elfcore.h (core_find_build_id): Likewise.
* elfxx-mips.c (READ): Likewise.
* mach-o.c (bfd_mach_o_mangle_sections),
(bfd_mach_o_read_symtab_symbols, bfd_mach_o_read_thread),
(bfd_mach_o_read_dysymtab, bfd_mach_o_flatten_sections),
(bfd_mach_o_scan, bfd_mach_o_fat_archive_p): Likewise.
* som.c (setup_sections, som_prep_for_fixups)
(som_build_and_write_symbol_table, som_slurp_symbol_table),
(som_slurp_reloc_table, som_bfd_count_ar_symbols),
(som_bfd_fill_in_ar_symbols, som_slurp_armap),
(som_bfd_ar_write_symbol_stuff): Likewise.
* vms-alpha.c (vector_grow1): Likewise.
* vms-lib.c (vms_add_index): Likewise.
* wasm-module.c (wasm_scan_name_function_section): Likewise.
* libbfd.c (bfd_malloc2, bfd_realloc2, bfd_zmalloc2): Delete.
* opncls.c (bfd_alloc2, bfd_zalloc2): Delete.
* libbfd-in.h (bfd_malloc2, bfd_realloc2, bfd_zmalloc2),
(bfd_alloc2, bfd_zalloc2): Delete.
(_bfd_mul_overflow): Define.
* libbfd.h: Regenerate.
2020-02-19 10:45:06 +08:00
|
|
|
size_t amt;
|
2019-10-30 20:23:16 +08:00
|
|
|
|
|
|
|
/* Seek to the position of the segment at OFFSET. */
|
|
|
|
if (bfd_seek (abfd, offset, SEEK_SET) != 0)
|
|
|
|
goto fail;
|
|
|
|
|
|
|
|
/* Read in the ELF header in external format. */
|
|
|
|
if (bfd_bread (&x_ehdr, sizeof (x_ehdr), abfd) != sizeof (x_ehdr))
|
|
|
|
{
|
|
|
|
if (bfd_get_error () != bfd_error_system_call)
|
|
|
|
goto wrong;
|
|
|
|
else
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Now check to see if we have a valid ELF file, and one that BFD can
|
|
|
|
make use of. The magic number must match, the address size ('class')
|
|
|
|
and byte-swapping must match our XVEC entry, and it must have a
|
|
|
|
section header table (FIXME: See comments re sections at top of this
|
|
|
|
file). */
|
|
|
|
if (! elf_file_p (&x_ehdr)
|
|
|
|
|| x_ehdr.e_ident[EI_VERSION] != EV_CURRENT
|
|
|
|
|| x_ehdr.e_ident[EI_CLASS] != ELFCLASS)
|
|
|
|
goto wrong;
|
|
|
|
|
|
|
|
/* Check that file's byte order matches xvec's. */
|
|
|
|
switch (x_ehdr.e_ident[EI_DATA])
|
|
|
|
{
|
|
|
|
case ELFDATA2MSB: /* Big-endian. */
|
|
|
|
if (! bfd_header_big_endian (abfd))
|
|
|
|
goto wrong;
|
|
|
|
break;
|
|
|
|
case ELFDATA2LSB: /* Little-endian. */
|
|
|
|
if (! bfd_header_little_endian (abfd))
|
|
|
|
goto wrong;
|
|
|
|
break;
|
|
|
|
case ELFDATANONE: /* No data encoding specified. */
|
|
|
|
default: /* Unknown data encoding specified . */
|
|
|
|
goto wrong;
|
|
|
|
}
|
|
|
|
|
|
|
|
elf_swap_ehdr_in (abfd, &x_ehdr, &i_ehdr);
|
|
|
|
#if DEBUG
|
|
|
|
elf_debug_file (&i_ehdr);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (i_ehdr.e_phentsize != sizeof (Elf_External_Phdr) || i_ehdr.e_phnum == 0)
|
|
|
|
goto fail;
|
|
|
|
|
|
|
|
/* Read in program headers. */
|
_bfd_mul_overflow
This patch removes the bfd_alloc2 series of memory allocation functions,
replacing them with __builtin_mul_overflow followed by bfd_alloc. Why
do that? Well, a followup patch will implement _bfd_alloc_and_read
and I don't want to implement alloc2 variants as well.
* coffcode.h (buy_and_read, coff_slurp_line_table),
(coff_slurp_symbol_table, coff_slurp_reloc_table): Replace
bfd_[z][m]alloc2 calls with _bfd_mul_overflow followed by the
corresponding bfd_alloc call. Adjust variables to suit.
* coffgen.c (_bfd_coff_get_external_symbols): Likewise.
* ecoff.c (_bfd_ecoff_slurp_symbolic_info),
(_bfd_ecoff_slurp_symbol_table, READ): Likewise.
* elf.c (bfd_elf_get_elf_syms, setup_group, bfd_section_from_shdr),
(swap_out_syms, _bfd_elf_slurp_version_tables): Likewise.
* elf32-m32c.c (m32c_elf_relax_section): Likewise.
* elf32-rl78.c (rl78_elf_relax_section): Likewise.
* elf32-rx.c (elf32_rx_relax_section): Likewise.
* elf64-alpha.c (READ): Likewise.
* elfcode.h (elf_object_p, elf_write_relocs, elf_write_shdrs_and_ehdr),
(elf_slurp_symbol_table, elf_slurp_reloc_table),
(bfd_from_remote_memory): Likewise.
* elfcore.h (core_find_build_id): Likewise.
* elfxx-mips.c (READ): Likewise.
* mach-o.c (bfd_mach_o_mangle_sections),
(bfd_mach_o_read_symtab_symbols, bfd_mach_o_read_thread),
(bfd_mach_o_read_dysymtab, bfd_mach_o_flatten_sections),
(bfd_mach_o_scan, bfd_mach_o_fat_archive_p): Likewise.
* som.c (setup_sections, som_prep_for_fixups)
(som_build_and_write_symbol_table, som_slurp_symbol_table),
(som_slurp_reloc_table, som_bfd_count_ar_symbols),
(som_bfd_fill_in_ar_symbols, som_slurp_armap),
(som_bfd_ar_write_symbol_stuff): Likewise.
* vms-alpha.c (vector_grow1): Likewise.
* vms-lib.c (vms_add_index): Likewise.
* wasm-module.c (wasm_scan_name_function_section): Likewise.
* libbfd.c (bfd_malloc2, bfd_realloc2, bfd_zmalloc2): Delete.
* opncls.c (bfd_alloc2, bfd_zalloc2): Delete.
* libbfd-in.h (bfd_malloc2, bfd_realloc2, bfd_zmalloc2),
(bfd_alloc2, bfd_zalloc2): Delete.
(_bfd_mul_overflow): Define.
* libbfd.h: Regenerate.
2020-02-19 10:45:06 +08:00
|
|
|
if (_bfd_mul_overflow (i_ehdr.e_phnum, sizeof (*i_phdr), &amt))
|
|
|
|
{
|
|
|
|
bfd_set_error (bfd_error_file_too_big);
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
i_phdr = (Elf_Internal_Phdr *) bfd_alloc (abfd, amt);
|
2019-10-30 20:23:16 +08:00
|
|
|
if (i_phdr == NULL)
|
|
|
|
goto fail;
|
|
|
|
|
|
|
|
if (bfd_seek (abfd, (file_ptr) (offset + i_ehdr.e_phoff), SEEK_SET) != 0)
|
|
|
|
goto fail;
|
|
|
|
|
|
|
|
/* Read in program headers and parse notes. */
|
|
|
|
for (i = 0; i < i_ehdr.e_phnum; ++i, ++i_phdr)
|
|
|
|
{
|
|
|
|
Elf_External_Phdr x_phdr;
|
|
|
|
|
|
|
|
if (bfd_bread (&x_phdr, sizeof (x_phdr), abfd) != sizeof (x_phdr))
|
|
|
|
goto fail;
|
|
|
|
elf_swap_phdr_in (abfd, &x_phdr, i_phdr);
|
|
|
|
|
|
|
|
if (i_phdr->p_type == PT_NOTE && i_phdr->p_filesz > 0)
|
|
|
|
{
|
|
|
|
elf_read_notes (abfd, offset + i_phdr->p_offset,
|
|
|
|
i_phdr->p_filesz, i_phdr->p_align);
|
|
|
|
if (abfd->build_id != NULL)
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Having gotten this far, we have a valid ELF section, but no
|
|
|
|
build-id was found. */
|
|
|
|
goto fail;
|
|
|
|
|
2020-02-25 13:04:46 +08:00
|
|
|
wrong:
|
2019-10-30 20:23:16 +08:00
|
|
|
bfd_set_error (bfd_error_wrong_format);
|
2020-02-25 13:04:46 +08:00
|
|
|
fail:
|
2019-10-30 20:23:16 +08:00
|
|
|
return FALSE;
|
|
|
|
}
|