6c2659886f
I'd like to enable the -Wmissing-declarations warning. However, it warns for every _initialize function, for example: CXX dcache.o /home/smarchi/src/binutils-gdb/gdb/dcache.c: In function ‘void _initialize_dcache()’: /home/smarchi/src/binutils-gdb/gdb/dcache.c:688:1: error: no previous declaration for ‘void _initialize_dcache()’ [-Werror=missing-declarations] _initialize_dcache (void) ^~~~~~~~~~~~~~~~~~ The only practical way forward I found is to add back the declarations, which were removed by this commit: commit 481695ed5f6e0a8a9c9c50bfac1cdd2b3151e6c9 Author: John Baldwin <jhb@FreeBSD.org> Date: Sat Sep 9 11:02:37 2017 -0700 Remove unnecessary function prototypes. I don't think it's a big problem to have the declarations for these functions, but if anybody has a better solution for this, I'll be happy to use it. gdb/ChangeLog: * aarch64-fbsd-nat.c (_initialize_aarch64_fbsd_nat): Add declaration. * aarch64-fbsd-tdep.c (_initialize_aarch64_fbsd_tdep): Add declaration. * aarch64-linux-nat.c (_initialize_aarch64_linux_nat): Add declaration. * aarch64-linux-tdep.c (_initialize_aarch64_linux_tdep): Add declaration. * aarch64-newlib-tdep.c (_initialize_aarch64_newlib_tdep): Add declaration. * aarch64-tdep.c (_initialize_aarch64_tdep): Add declaration. * ada-exp.y (_initialize_ada_exp): Add declaration. * ada-lang.c (_initialize_ada_language): Add declaration. * ada-tasks.c (_initialize_tasks): Add declaration. * agent.c (_initialize_agent): Add declaration. * aix-thread.c (_initialize_aix_thread): Add declaration. * alpha-bsd-nat.c (_initialize_alphabsd_nat): Add declaration. * alpha-linux-nat.c (_initialize_alpha_linux_nat): Add declaration. * alpha-linux-tdep.c (_initialize_alpha_linux_tdep): Add declaration. * alpha-nbsd-tdep.c (_initialize_alphanbsd_tdep): Add declaration. * alpha-obsd-tdep.c (_initialize_alphaobsd_tdep): Add declaration. * alpha-tdep.c (_initialize_alpha_tdep): Add declaration. * amd64-darwin-tdep.c (_initialize_amd64_darwin_tdep): Add declaration. * amd64-dicos-tdep.c (_initialize_amd64_dicos_tdep): Add declaration. * amd64-fbsd-nat.c (_initialize_amd64fbsd_nat): Add declaration. * amd64-fbsd-tdep.c (_initialize_amd64fbsd_tdep): Add declaration. * amd64-linux-nat.c (_initialize_amd64_linux_nat): Add declaration. * amd64-linux-tdep.c (_initialize_amd64_linux_tdep): Add declaration. * amd64-nbsd-nat.c (_initialize_amd64nbsd_nat): Add declaration. * amd64-nbsd-tdep.c (_initialize_amd64nbsd_tdep): Add declaration. * amd64-obsd-nat.c (_initialize_amd64obsd_nat): Add declaration. * amd64-obsd-tdep.c (_initialize_amd64obsd_tdep): Add declaration. * amd64-sol2-tdep.c (_initialize_amd64_sol2_tdep): Add declaration. * amd64-tdep.c (_initialize_amd64_tdep): Add declaration. * amd64-windows-nat.c (_initialize_amd64_windows_nat): Add declaration. * amd64-windows-tdep.c (_initialize_amd64_windows_tdep): Add declaration. * annotate.c (_initialize_annotate): Add declaration. * arc-newlib-tdep.c (_initialize_arc_newlib_tdep): Add declaration. * arc-tdep.c (_initialize_arc_tdep): Add declaration. * arch-utils.c (_initialize_gdbarch_utils): Add declaration. * arm-fbsd-nat.c (_initialize_arm_fbsd_nat): Add declaration. * arm-fbsd-tdep.c (_initialize_arm_fbsd_tdep): Add declaration. * arm-linux-nat.c (_initialize_arm_linux_nat): Add declaration. * arm-linux-tdep.c (_initialize_arm_linux_tdep): Add declaration. * arm-nbsd-nat.c (_initialize_arm_netbsd_nat): Add declaration. * arm-nbsd-tdep.c (_initialize_arm_netbsd_tdep): Add declaration. * arm-obsd-tdep.c (_initialize_armobsd_tdep): Add declaration. * arm-pikeos-tdep.c (_initialize_arm_pikeos_tdep): Add declaration. * arm-symbian-tdep.c (_initialize_arm_symbian_tdep): Add declaration. * arm-tdep.c (_initialize_arm_tdep): Add declaration. * arm-wince-tdep.c (_initialize_arm_wince_tdep): Add declaration. * auto-load.c (_initialize_auto_load): Add declaration. * auxv.c (_initialize_auxv): Add declaration. * avr-tdep.c (_initialize_avr_tdep): Add declaration. * ax-gdb.c (_initialize_ax_gdb): Add declaration. * bfin-linux-tdep.c (_initialize_bfin_linux_tdep): Add declaration. * bfin-tdep.c (_initialize_bfin_tdep): Add declaration. * break-catch-sig.c (_initialize_break_catch_sig): Add declaration. * break-catch-syscall.c (_initialize_break_catch_syscall): Add declaration. * break-catch-throw.c (_initialize_break_catch_throw): Add declaration. * breakpoint.c (_initialize_breakpoint): Add declaration. * bsd-uthread.c (_initialize_bsd_uthread): Add declaration. * btrace.c (_initialize_btrace): Add declaration. * charset.c (_initialize_charset): Add declaration. * cli/cli-cmds.c (_initialize_cli_cmds): Add declaration. * cli/cli-dump.c (_initialize_cli_dump): Add declaration. * cli/cli-interp.c (_initialize_cli_interp): Add declaration. * cli/cli-logging.c (_initialize_cli_logging): Add declaration. * cli/cli-script.c (_initialize_cli_script): Add declaration. * cli/cli-style.c (_initialize_cli_style): Add declaration. * coff-pe-read.c (_initialize_coff_pe_read): Add declaration. * coffread.c (_initialize_coffread): Add declaration. * compile/compile-cplus-types.c (_initialize_compile_cplus_types): Add declaration. * compile/compile.c (_initialize_compile): Add declaration. * complaints.c (_initialize_complaints): Add declaration. * completer.c (_initialize_completer): Add declaration. * copying.c (_initialize_copying): Add declaration. * corefile.c (_initialize_core): Add declaration. * corelow.c (_initialize_corelow): Add declaration. * cp-abi.c (_initialize_cp_abi): Add declaration. * cp-namespace.c (_initialize_cp_namespace): Add declaration. * cp-support.c (_initialize_cp_support): Add declaration. * cp-valprint.c (_initialize_cp_valprint): Add declaration. * cris-linux-tdep.c (_initialize_cris_linux_tdep): Add declaration. * cris-tdep.c (_initialize_cris_tdep): Add declaration. * csky-linux-tdep.c (_initialize_csky_linux_tdep): Add declaration. * csky-tdep.c (_initialize_csky_tdep): Add declaration. * ctfread.c (_initialize_ctfread): Add declaration. * d-lang.c (_initialize_d_language): Add declaration. * darwin-nat-info.c (_initialize_darwin_info_commands): Add declaration. * darwin-nat.c (_initialize_darwin_nat): Add declaration. * dbxread.c (_initialize_dbxread): Add declaration. * dcache.c (_initialize_dcache): Add declaration. * disasm-selftests.c (_initialize_disasm_selftests): Add declaration. * disasm.c (_initialize_disasm): Add declaration. * dtrace-probe.c (_initialize_dtrace_probe): Add declaration. * dummy-frame.c (_initialize_dummy_frame): Add declaration. * dwarf-index-cache.c (_initialize_index_cache): Add declaration. * dwarf-index-write.c (_initialize_dwarf_index_write): Add declaration. * dwarf2-frame-tailcall.c (_initialize_tailcall_frame): Add declaration. * dwarf2-frame.c (_initialize_dwarf2_frame): Add declaration. * dwarf2expr.c (_initialize_dwarf2expr): Add declaration. * dwarf2loc.c (_initialize_dwarf2loc): Add declaration. * dwarf2read.c (_initialize_dwarf2_read): Add declaration. * elfread.c (_initialize_elfread): Add declaration. * exec.c (_initialize_exec): Add declaration. * extension.c (_initialize_extension): Add declaration. * f-lang.c (_initialize_f_language): Add declaration. * f-valprint.c (_initialize_f_valprint): Add declaration. * fbsd-nat.c (_initialize_fbsd_nat): Add declaration. * fbsd-tdep.c (_initialize_fbsd_tdep): Add declaration. * filesystem.c (_initialize_filesystem): Add declaration. * findcmd.c (_initialize_mem_search): Add declaration. * findvar.c (_initialize_findvar): Add declaration. * fork-child.c (_initialize_fork_child): Add declaration. * frame-base.c (_initialize_frame_base): Add declaration. * frame-unwind.c (_initialize_frame_unwind): Add declaration. * frame.c (_initialize_frame): Add declaration. * frv-linux-tdep.c (_initialize_frv_linux_tdep): Add declaration. * frv-tdep.c (_initialize_frv_tdep): Add declaration. * ft32-tdep.c (_initialize_ft32_tdep): Add declaration. * gcore.c (_initialize_gcore): Add declaration. * gdb-demangle.c (_initialize_gdb_demangle): Add declaration. * gdb_bfd.c (_initialize_gdb_bfd): Add declaration. * gdbarch-selftests.c (_initialize_gdbarch_selftests): Add declaration. * gdbarch.c (_initialize_gdbarch): Add declaration. * gdbtypes.c (_initialize_gdbtypes): Add declaration. * gnu-nat.c (_initialize_gnu_nat): Add declaration. * gnu-v2-abi.c (_initialize_gnu_v2_abi): Add declaration. * gnu-v3-abi.c (_initialize_gnu_v3_abi): Add declaration. * go-lang.c (_initialize_go_language): Add declaration. * go32-nat.c (_initialize_go32_nat): Add declaration. * guile/guile.c (_initialize_guile): Add declaration. * h8300-tdep.c (_initialize_h8300_tdep): Add declaration. * hppa-linux-nat.c (_initialize_hppa_linux_nat): Add declaration. * hppa-linux-tdep.c (_initialize_hppa_linux_tdep): Add declaration. * hppa-nbsd-nat.c (_initialize_hppanbsd_nat): Add declaration. * hppa-nbsd-tdep.c (_initialize_hppanbsd_tdep): Add declaration. * hppa-obsd-nat.c (_initialize_hppaobsd_nat): Add declaration. * hppa-obsd-tdep.c (_initialize_hppabsd_tdep): Add declaration. * hppa-tdep.c (_initialize_hppa_tdep): Add declaration. * i386-bsd-nat.c (_initialize_i386bsd_nat): Add declaration. * i386-cygwin-tdep.c (_initialize_i386_cygwin_tdep): Add declaration. * i386-darwin-nat.c (_initialize_i386_darwin_nat): Add declaration. * i386-darwin-tdep.c (_initialize_i386_darwin_tdep): Add declaration. * i386-dicos-tdep.c (_initialize_i386_dicos_tdep): Add declaration. * i386-fbsd-nat.c (_initialize_i386fbsd_nat): Add declaration. * i386-fbsd-tdep.c (_initialize_i386fbsd_tdep): Add declaration. * i386-gnu-nat.c (_initialize_i386gnu_nat): Add declaration. * i386-gnu-tdep.c (_initialize_i386gnu_tdep): Add declaration. * i386-go32-tdep.c (_initialize_i386_go32_tdep): Add declaration. * i386-linux-nat.c (_initialize_i386_linux_nat): Add declaration. * i386-linux-tdep.c (_initialize_i386_linux_tdep): Add declaration. * i386-nbsd-nat.c (_initialize_i386nbsd_nat): Add declaration. * i386-nbsd-tdep.c (_initialize_i386nbsd_tdep): Add declaration. * i386-nto-tdep.c (_initialize_i386nto_tdep): Add declaration. * i386-obsd-nat.c (_initialize_i386obsd_nat): Add declaration. * i386-obsd-tdep.c (_initialize_i386obsd_tdep): Add declaration. * i386-sol2-nat.c (_initialize_amd64_sol2_nat): Add declaration. * i386-sol2-tdep.c (_initialize_i386_sol2_tdep): Add declaration. * i386-tdep.c (_initialize_i386_tdep): Add declaration. * i386-windows-nat.c (_initialize_i386_windows_nat): Add declaration. * ia64-libunwind-tdep.c (_initialize_libunwind_frame): Add declaration. * ia64-linux-nat.c (_initialize_ia64_linux_nat): Add declaration. * ia64-linux-tdep.c (_initialize_ia64_linux_tdep): Add declaration. * ia64-tdep.c (_initialize_ia64_tdep): Add declaration. * ia64-vms-tdep.c (_initialize_ia64_vms_tdep): Add declaration. * infcall.c (_initialize_infcall): Add declaration. * infcmd.c (_initialize_infcmd): Add declaration. * inflow.c (_initialize_inflow): Add declaration. * infrun.c (_initialize_infrun): Add declaration. * interps.c (_initialize_interpreter): Add declaration. * iq2000-tdep.c (_initialize_iq2000_tdep): Add declaration. * jit.c (_initialize_jit): Add declaration. * language.c (_initialize_language): Add declaration. * linux-fork.c (_initialize_linux_fork): Add declaration. * linux-nat.c (_initialize_linux_nat): Add declaration. * linux-tdep.c (_initialize_linux_tdep): Add declaration. * linux-thread-db.c (_initialize_thread_db): Add declaration. * lm32-tdep.c (_initialize_lm32_tdep): Add declaration. * m2-lang.c (_initialize_m2_language): Add declaration. * m32c-tdep.c (_initialize_m32c_tdep): Add declaration. * m32r-linux-nat.c (_initialize_m32r_linux_nat): Add declaration. * m32r-linux-tdep.c (_initialize_m32r_linux_tdep): Add declaration. * m32r-tdep.c (_initialize_m32r_tdep): Add declaration. * m68hc11-tdep.c (_initialize_m68hc11_tdep): Add declaration. * m68k-bsd-nat.c (_initialize_m68kbsd_nat): Add declaration. * m68k-bsd-tdep.c (_initialize_m68kbsd_tdep): Add declaration. * m68k-linux-nat.c (_initialize_m68k_linux_nat): Add declaration. * m68k-linux-tdep.c (_initialize_m68k_linux_tdep): Add declaration. * m68k-tdep.c (_initialize_m68k_tdep): Add declaration. * machoread.c (_initialize_machoread): Add declaration. * macrocmd.c (_initialize_macrocmd): Add declaration. * macroscope.c (_initialize_macroscope): Add declaration. * maint-test-options.c (_initialize_maint_test_options): Add declaration. * maint-test-settings.c (_initialize_maint_test_settings): Add declaration. * maint.c (_initialize_maint_cmds): Add declaration. * mdebugread.c (_initialize_mdebugread): Add declaration. * memattr.c (_initialize_mem): Add declaration. * mep-tdep.c (_initialize_mep_tdep): Add declaration. * mi/mi-cmd-env.c (_initialize_mi_cmd_env): Add declaration. * mi/mi-cmds.c (_initialize_mi_cmds): Add declaration. * mi/mi-interp.c (_initialize_mi_interp): Add declaration. * mi/mi-main.c (_initialize_mi_main): Add declaration. * microblaze-linux-tdep.c (_initialize_microblaze_linux_tdep): Add declaration. * microblaze-tdep.c (_initialize_microblaze_tdep): Add declaration. * mips-fbsd-nat.c (_initialize_mips_fbsd_nat): Add declaration. * mips-fbsd-tdep.c (_initialize_mips_fbsd_tdep): Add declaration. * mips-linux-nat.c (_initialize_mips_linux_nat): Add declaration. * mips-linux-tdep.c (_initialize_mips_linux_tdep): Add declaration. * mips-nbsd-nat.c (_initialize_mipsnbsd_nat): Add declaration. * mips-nbsd-tdep.c (_initialize_mipsnbsd_tdep): Add declaration. * mips-sde-tdep.c (_initialize_mips_sde_tdep): Add declaration. * mips-tdep.c (_initialize_mips_tdep): Add declaration. * mips64-obsd-nat.c (_initialize_mips64obsd_nat): Add declaration. * mips64-obsd-tdep.c (_initialize_mips64obsd_tdep): Add declaration. * mipsread.c (_initialize_mipsread): Add declaration. * mn10300-linux-tdep.c (_initialize_mn10300_linux_tdep): Add declaration. * mn10300-tdep.c (_initialize_mn10300_tdep): Add declaration. * moxie-tdep.c (_initialize_moxie_tdep): Add declaration. * msp430-tdep.c (_initialize_msp430_tdep): Add declaration. * nds32-tdep.c (_initialize_nds32_tdep): Add declaration. * nios2-linux-tdep.c (_initialize_nios2_linux_tdep): Add declaration. * nios2-tdep.c (_initialize_nios2_tdep): Add declaration. * nto-procfs.c (_initialize_procfs): Add declaration. * objc-lang.c (_initialize_objc_language): Add declaration. * observable.c (_initialize_observer): Add declaration. * opencl-lang.c (_initialize_opencl_language): Add declaration. * or1k-linux-tdep.c (_initialize_or1k_linux_tdep): Add declaration. * or1k-tdep.c (_initialize_or1k_tdep): Add declaration. * osabi.c (_initialize_gdb_osabi): Add declaration. * osdata.c (_initialize_osdata): Add declaration. * p-valprint.c (_initialize_pascal_valprint): Add declaration. * parse.c (_initialize_parse): Add declaration. * ppc-fbsd-nat.c (_initialize_ppcfbsd_nat): Add declaration. * ppc-fbsd-tdep.c (_initialize_ppcfbsd_tdep): Add declaration. * ppc-linux-nat.c (_initialize_ppc_linux_nat): Add declaration. * ppc-linux-tdep.c (_initialize_ppc_linux_tdep): Add declaration. * ppc-nbsd-nat.c (_initialize_ppcnbsd_nat): Add declaration. * ppc-nbsd-tdep.c (_initialize_ppcnbsd_tdep): Add declaration. * ppc-obsd-nat.c (_initialize_ppcobsd_nat): Add declaration. * ppc-obsd-tdep.c (_initialize_ppcobsd_tdep): Add declaration. * printcmd.c (_initialize_printcmd): Add declaration. * probe.c (_initialize_probe): Add declaration. * proc-api.c (_initialize_proc_api): Add declaration. * proc-events.c (_initialize_proc_events): Add declaration. * proc-service.c (_initialize_proc_service): Add declaration. * procfs.c (_initialize_procfs): Add declaration. * producer.c (_initialize_producer): Add declaration. * psymtab.c (_initialize_psymtab): Add declaration. * python/python.c (_initialize_python): Add declaration. * ravenscar-thread.c (_initialize_ravenscar): Add declaration. * record-btrace.c (_initialize_record_btrace): Add declaration. * record-full.c (_initialize_record_full): Add declaration. * record.c (_initialize_record): Add declaration. * regcache-dump.c (_initialize_regcache_dump): Add declaration. * regcache.c (_initialize_regcache): Add declaration. * reggroups.c (_initialize_reggroup): Add declaration. * remote-notif.c (_initialize_notif): Add declaration. * remote-sim.c (_initialize_remote_sim): Add declaration. * remote.c (_initialize_remote): Add declaration. * reverse.c (_initialize_reverse): Add declaration. * riscv-fbsd-nat.c (_initialize_riscv_fbsd_nat): Add declaration. * riscv-fbsd-tdep.c (_initialize_riscv_fbsd_tdep): Add declaration. * riscv-linux-nat.c (_initialize_riscv_linux_nat): Add declaration. * riscv-linux-tdep.c (_initialize_riscv_linux_tdep): Add declaration. * riscv-tdep.c (_initialize_riscv_tdep): Add declaration. * rl78-tdep.c (_initialize_rl78_tdep): Add declaration. * rs6000-aix-tdep.c (_initialize_rs6000_aix_tdep): Add declaration. * rs6000-lynx178-tdep.c (_initialize_rs6000_lynx178_tdep): Add declaration. * rs6000-nat.c (_initialize_rs6000_nat): Add declaration. * rs6000-tdep.c (_initialize_rs6000_tdep): Add declaration. * run-on-main-thread.c (_initialize_run_on_main_thread): Add declaration. * rust-exp.y (_initialize_rust_exp): Add declaration. * rx-tdep.c (_initialize_rx_tdep): Add declaration. * s12z-tdep.c (_initialize_s12z_tdep): Add declaration. * s390-linux-nat.c (_initialize_s390_nat): Add declaration. * s390-linux-tdep.c (_initialize_s390_linux_tdep): Add declaration. * s390-tdep.c (_initialize_s390_tdep): Add declaration. * score-tdep.c (_initialize_score_tdep): Add declaration. * ser-go32.c (_initialize_ser_dos): Add declaration. * ser-mingw.c (_initialize_ser_windows): Add declaration. * ser-pipe.c (_initialize_ser_pipe): Add declaration. * ser-tcp.c (_initialize_ser_tcp): Add declaration. * ser-uds.c (_initialize_ser_socket): Add declaration. * ser-unix.c (_initialize_ser_hardwire): Add declaration. * serial.c (_initialize_serial): Add declaration. * sh-linux-tdep.c (_initialize_sh_linux_tdep): Add declaration. * sh-nbsd-nat.c (_initialize_shnbsd_nat): Add declaration. * sh-nbsd-tdep.c (_initialize_shnbsd_tdep): Add declaration. * sh-tdep.c (_initialize_sh_tdep): Add declaration. * skip.c (_initialize_step_skip): Add declaration. * sol-thread.c (_initialize_sol_thread): Add declaration. * solib-aix.c (_initialize_solib_aix): Add declaration. * solib-darwin.c (_initialize_darwin_solib): Add declaration. * solib-dsbt.c (_initialize_dsbt_solib): Add declaration. * solib-frv.c (_initialize_frv_solib): Add declaration. * solib-svr4.c (_initialize_svr4_solib): Add declaration. * solib-target.c (_initialize_solib_target): Add declaration. * solib.c (_initialize_solib): Add declaration. * source-cache.c (_initialize_source_cache): Add declaration. * source.c (_initialize_source): Add declaration. * sparc-linux-nat.c (_initialize_sparc_linux_nat): Add declaration. * sparc-linux-tdep.c (_initialize_sparc_linux_tdep): Add declaration. * sparc-nat.c (_initialize_sparc_nat): Add declaration. * sparc-nbsd-nat.c (_initialize_sparcnbsd_nat): Add declaration. * sparc-nbsd-tdep.c (_initialize_sparcnbsd_tdep): Add declaration. * sparc-obsd-tdep.c (_initialize_sparc32obsd_tdep): Add declaration. * sparc-sol2-tdep.c (_initialize_sparc_sol2_tdep): Add declaration. * sparc-tdep.c (_initialize_sparc_tdep): Add declaration. * sparc64-fbsd-nat.c (_initialize_sparc64fbsd_nat): Add declaration. * sparc64-fbsd-tdep.c (_initialize_sparc64fbsd_tdep): Add declaration. * sparc64-linux-nat.c (_initialize_sparc64_linux_nat): Add declaration. * sparc64-linux-tdep.c (_initialize_sparc64_linux_tdep): Add declaration. * sparc64-nat.c (_initialize_sparc64_nat): Add declaration. * sparc64-nbsd-nat.c (_initialize_sparc64nbsd_nat): Add declaration. * sparc64-nbsd-tdep.c (_initialize_sparc64nbsd_tdep): Add declaration. * sparc64-obsd-nat.c (_initialize_sparc64obsd_nat): Add declaration. * sparc64-obsd-tdep.c (_initialize_sparc64obsd_tdep): Add declaration. * sparc64-sol2-tdep.c (_initialize_sparc64_sol2_tdep): Add declaration. * sparc64-tdep.c (_initialize_sparc64_adi_tdep): Add declaration. * stabsread.c (_initialize_stabsread): Add declaration. * stack.c (_initialize_stack): Add declaration. * stap-probe.c (_initialize_stap_probe): Add declaration. * std-regs.c (_initialize_frame_reg): Add declaration. * symfile-debug.c (_initialize_symfile_debug): Add declaration. * symfile-mem.c (_initialize_symfile_mem): Add declaration. * symfile.c (_initialize_symfile): Add declaration. * symmisc.c (_initialize_symmisc): Add declaration. * symtab.c (_initialize_symtab): Add declaration. * target.c (_initialize_target): Add declaration. * target-connection.c (_initialize_target_connection): Add declaration. * target-dcache.c (_initialize_target_dcache): Add declaration. * target-descriptions.c (_initialize_target_descriptions): Add declaration. * thread.c (_initialize_thread): Add declaration. * tic6x-linux-tdep.c (_initialize_tic6x_linux_tdep): Add declaration. * tic6x-tdep.c (_initialize_tic6x_tdep): Add declaration. * tilegx-linux-nat.c (_initialize_tile_linux_nat): Add declaration. * tilegx-linux-tdep.c (_initialize_tilegx_linux_tdep): Add declaration. * tilegx-tdep.c (_initialize_tilegx_tdep): Add declaration. * tracectf.c (_initialize_ctf): Add declaration. * tracefile-tfile.c (_initialize_tracefile_tfile): Add declaration. * tracefile.c (_initialize_tracefile): Add declaration. * tracepoint.c (_initialize_tracepoint): Add declaration. * tui/tui-hooks.c (_initialize_tui_hooks): Add declaration. * tui/tui-interp.c (_initialize_tui_interp): Add declaration. * tui/tui-layout.c (_initialize_tui_layout): Add declaration. * tui/tui-regs.c (_initialize_tui_regs): Add declaration. * tui/tui-stack.c (_initialize_tui_stack): Add declaration. * tui/tui-win.c (_initialize_tui_win): Add declaration. * tui/tui.c (_initialize_tui): Add declaration. * typeprint.c (_initialize_typeprint): Add declaration. * ui-style.c (_initialize_ui_style): Add declaration. * unittests/array-view-selftests.c (_initialize_array_view_selftests): Add declaration. * unittests/child-path-selftests.c (_initialize_child_path_selftests): Add declaration. * unittests/cli-utils-selftests.c (_initialize_cli_utils_selftests): Add declaration. * unittests/common-utils-selftests.c (_initialize_common_utils_selftests): Add declaration. * unittests/copy_bitwise-selftests.c (_initialize_copy_bitwise_utils_selftests): Add declaration. * unittests/environ-selftests.c (_initialize_environ_selftests): Add declaration. * unittests/filtered_iterator-selftests.c (_initialize_filtered_iterator_selftests): Add declaration. * unittests/format_pieces-selftests.c (_initialize_format_pieces_selftests): Add declaration. * unittests/function-view-selftests.c (_initialize_function_view_selftests): Add declaration. * unittests/help-doc-selftests.c (_initialize_help_doc_selftests): Add declaration. * unittests/lookup_name_info-selftests.c (_initialize_lookup_name_info_selftests): Add declaration. * unittests/main-thread-selftests.c (_initialize_main_thread_selftests): Add declaration. * unittests/memory-map-selftests.c (_initialize_memory_map_selftests): Add declaration. * unittests/memrange-selftests.c (_initialize_memrange_selftests): Add declaration. * unittests/mkdir-recursive-selftests.c (_initialize_mkdir_recursive_selftests): Add declaration. * unittests/observable-selftests.c (_initialize_observer_selftest): Add declaration. * unittests/offset-type-selftests.c (_initialize_offset_type_selftests): Add declaration. * unittests/optional-selftests.c (_initialize_optional_selftests): Add declaration. * unittests/parse-connection-spec-selftests.c (_initialize_parse_connection_spec_selftests): Add declaration. * unittests/rsp-low-selftests.c (_initialize_rsp_low_selftests): Add declaration. * unittests/scoped_fd-selftests.c (_initialize_scoped_fd_selftests): Add declaration. * unittests/scoped_mmap-selftests.c (_initialize_scoped_mmap_selftests): Add declaration. * unittests/scoped_restore-selftests.c (_initialize_scoped_restore_selftests): Add declaration. * unittests/string_view-selftests.c (_initialize_string_view_selftests): Add declaration. * unittests/style-selftests.c (_initialize_style_selftest): Add declaration. * unittests/tracepoint-selftests.c (_initialize_tracepoint_selftests): Add declaration. * unittests/tui-selftests.c (_initialize_tui_selftest): Add declaration. * unittests/unpack-selftests.c (_initialize_unpack_selftests): Add declaration. * unittests/utils-selftests.c (_initialize_utils_selftests): Add declaration. * unittests/vec-utils-selftests.c (_initialize_vec_utils_selftests): Add declaration. * unittests/xml-utils-selftests.c (_initialize_xml_utils): Add declaration. * user-regs.c (_initialize_user_regs): Add declaration. * utils.c (_initialize_utils): Add declaration. * v850-tdep.c (_initialize_v850_tdep): Add declaration. * valops.c (_initialize_valops): Add declaration. * valprint.c (_initialize_valprint): Add declaration. * value.c (_initialize_values): Add declaration. * varobj.c (_initialize_varobj): Add declaration. * vax-bsd-nat.c (_initialize_vaxbsd_nat): Add declaration. * vax-nbsd-tdep.c (_initialize_vaxnbsd_tdep): Add declaration. * vax-tdep.c (_initialize_vax_tdep): Add declaration. * windows-nat.c (_initialize_windows_nat): Add declaration. (_initialize_check_for_gdb_ini): Add declaration. (_initialize_loadable): Add declaration. * windows-tdep.c (_initialize_windows_tdep): Add declaration. * x86-bsd-nat.c (_initialize_x86_bsd_nat): Add declaration. * x86-linux-nat.c (_initialize_x86_linux_nat): Add declaration. * xcoffread.c (_initialize_xcoffread): Add declaration. * xml-support.c (_initialize_xml_support): Add declaration. * xstormy16-tdep.c (_initialize_xstormy16_tdep): Add declaration. * xtensa-linux-nat.c (_initialize_xtensa_linux_nat): Add declaration. * xtensa-linux-tdep.c (_initialize_xtensa_linux_tdep): Add declaration. * xtensa-tdep.c (_initialize_xtensa_tdep): Add declaration. Change-Id: I13eec7e0ed2b3c427377a7bdb055cf46da64def9
677 lines
18 KiB
C
677 lines
18 KiB
C
/* IBM RS/6000 native-dependent code for GDB, the GNU debugger.
|
||
|
||
Copyright (C) 1986-2020 Free Software Foundation, Inc.
|
||
|
||
This file is part of GDB.
|
||
|
||
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
|
||
the Free Software Foundation; either version 3 of the License, or
|
||
(at your option) any later version.
|
||
|
||
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.
|
||
|
||
You should have received a copy of the GNU General Public License
|
||
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||
|
||
#include "defs.h"
|
||
#include "inferior.h"
|
||
#include "target.h"
|
||
#include "gdbcore.h"
|
||
#include "symfile.h"
|
||
#include "objfiles.h"
|
||
#include "bfd.h"
|
||
#include "gdb-stabs.h"
|
||
#include "regcache.h"
|
||
#include "arch-utils.h"
|
||
#include "inf-child.h"
|
||
#include "inf-ptrace.h"
|
||
#include "ppc-tdep.h"
|
||
#include "rs6000-tdep.h"
|
||
#include "rs6000-aix-tdep.h"
|
||
#include "exec.h"
|
||
#include "observable.h"
|
||
#include "xcoffread.h"
|
||
|
||
#include <sys/ptrace.h>
|
||
#include <sys/reg.h>
|
||
|
||
#include <sys/dir.h>
|
||
#include <sys/user.h>
|
||
#include <signal.h>
|
||
#include <sys/ioctl.h>
|
||
#include <fcntl.h>
|
||
|
||
#include <a.out.h>
|
||
#include <sys/file.h>
|
||
#include <sys/stat.h>
|
||
#include "gdb_bfd.h"
|
||
#include <sys/core.h>
|
||
#define __LDINFO_PTRACE32__ /* for __ld_info32 */
|
||
#define __LDINFO_PTRACE64__ /* for __ld_info64 */
|
||
#include <sys/ldr.h>
|
||
#include <sys/systemcfg.h>
|
||
|
||
/* On AIX4.3+, sys/ldr.h provides different versions of struct ld_info for
|
||
debugging 32-bit and 64-bit processes. Define a typedef and macros for
|
||
accessing fields in the appropriate structures. */
|
||
|
||
/* In 32-bit compilation mode (which is the only mode from which ptrace()
|
||
works on 4.3), __ld_info32 is #defined as equivalent to ld_info. */
|
||
|
||
#if defined (__ld_info32) || defined (__ld_info64)
|
||
# define ARCH3264
|
||
#endif
|
||
|
||
/* Return whether the current architecture is 64-bit. */
|
||
|
||
#ifndef ARCH3264
|
||
# define ARCH64() 0
|
||
#else
|
||
# define ARCH64() (register_size (target_gdbarch (), 0) == 8)
|
||
#endif
|
||
|
||
class rs6000_nat_target final : public inf_ptrace_target
|
||
{
|
||
public:
|
||
void fetch_registers (struct regcache *, int) override;
|
||
void store_registers (struct regcache *, int) override;
|
||
|
||
enum target_xfer_status xfer_partial (enum target_object object,
|
||
const char *annex,
|
||
gdb_byte *readbuf,
|
||
const gdb_byte *writebuf,
|
||
ULONGEST offset, ULONGEST len,
|
||
ULONGEST *xfered_len) override;
|
||
|
||
void create_inferior (const char *, const std::string &,
|
||
char **, int) override;
|
||
|
||
ptid_t wait (ptid_t, struct target_waitstatus *, int) override;
|
||
|
||
private:
|
||
enum target_xfer_status
|
||
xfer_shared_libraries (enum target_object object,
|
||
const char *annex, gdb_byte *readbuf,
|
||
const gdb_byte *writebuf,
|
||
ULONGEST offset, ULONGEST len,
|
||
ULONGEST *xfered_len);
|
||
};
|
||
|
||
static rs6000_nat_target the_rs6000_nat_target;
|
||
|
||
/* Given REGNO, a gdb register number, return the corresponding
|
||
number suitable for use as a ptrace() parameter. Return -1 if
|
||
there's no suitable mapping. Also, set the int pointed to by
|
||
ISFLOAT to indicate whether REGNO is a floating point register. */
|
||
|
||
static int
|
||
regmap (struct gdbarch *gdbarch, int regno, int *isfloat)
|
||
{
|
||
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
||
|
||
*isfloat = 0;
|
||
if (tdep->ppc_gp0_regnum <= regno
|
||
&& regno < tdep->ppc_gp0_regnum + ppc_num_gprs)
|
||
return regno;
|
||
else if (tdep->ppc_fp0_regnum >= 0
|
||
&& tdep->ppc_fp0_regnum <= regno
|
||
&& regno < tdep->ppc_fp0_regnum + ppc_num_fprs)
|
||
{
|
||
*isfloat = 1;
|
||
return regno - tdep->ppc_fp0_regnum + FPR0;
|
||
}
|
||
else if (regno == gdbarch_pc_regnum (gdbarch))
|
||
return IAR;
|
||
else if (regno == tdep->ppc_ps_regnum)
|
||
return MSR;
|
||
else if (regno == tdep->ppc_cr_regnum)
|
||
return CR;
|
||
else if (regno == tdep->ppc_lr_regnum)
|
||
return LR;
|
||
else if (regno == tdep->ppc_ctr_regnum)
|
||
return CTR;
|
||
else if (regno == tdep->ppc_xer_regnum)
|
||
return XER;
|
||
else if (tdep->ppc_fpscr_regnum >= 0
|
||
&& regno == tdep->ppc_fpscr_regnum)
|
||
return FPSCR;
|
||
else if (tdep->ppc_mq_regnum >= 0 && regno == tdep->ppc_mq_regnum)
|
||
return MQ;
|
||
else
|
||
return -1;
|
||
}
|
||
|
||
/* Call ptrace(REQ, ID, ADDR, DATA, BUF). */
|
||
|
||
static int
|
||
rs6000_ptrace32 (int req, int id, int *addr, int data, int *buf)
|
||
{
|
||
#ifdef HAVE_PTRACE64
|
||
int ret = ptrace64 (req, id, (uintptr_t) addr, data, buf);
|
||
#else
|
||
int ret = ptrace (req, id, (int *)addr, data, buf);
|
||
#endif
|
||
#if 0
|
||
printf ("rs6000_ptrace32 (%d, %d, 0x%x, %08x, 0x%x) = 0x%x\n",
|
||
req, id, (unsigned int)addr, data, (unsigned int)buf, ret);
|
||
#endif
|
||
return ret;
|
||
}
|
||
|
||
/* Call ptracex(REQ, ID, ADDR, DATA, BUF). */
|
||
|
||
static int
|
||
rs6000_ptrace64 (int req, int id, long long addr, int data, void *buf)
|
||
{
|
||
#ifdef ARCH3264
|
||
# ifdef HAVE_PTRACE64
|
||
int ret = ptrace64 (req, id, addr, data, (PTRACE_TYPE_ARG5) buf);
|
||
# else
|
||
int ret = ptracex (req, id, addr, data, (PTRACE_TYPE_ARG5) buf);
|
||
# endif
|
||
#else
|
||
int ret = 0;
|
||
#endif
|
||
#if 0
|
||
printf ("rs6000_ptrace64 (%d, %d, %s, %08x, 0x%x) = 0x%x\n",
|
||
req, id, hex_string (addr), data, (unsigned int)buf, ret);
|
||
#endif
|
||
return ret;
|
||
}
|
||
|
||
/* Fetch register REGNO from the inferior. */
|
||
|
||
static void
|
||
fetch_register (struct regcache *regcache, int regno)
|
||
{
|
||
struct gdbarch *gdbarch = regcache->arch ();
|
||
int addr[PPC_MAX_REGISTER_SIZE];
|
||
int nr, isfloat;
|
||
pid_t pid = regcache->ptid ().pid ();
|
||
|
||
/* Retrieved values may be -1, so infer errors from errno. */
|
||
errno = 0;
|
||
|
||
nr = regmap (gdbarch, regno, &isfloat);
|
||
|
||
/* Floating-point registers. */
|
||
if (isfloat)
|
||
rs6000_ptrace32 (PT_READ_FPR, pid, addr, nr, 0);
|
||
|
||
/* Bogus register number. */
|
||
else if (nr < 0)
|
||
{
|
||
if (regno >= gdbarch_num_regs (gdbarch))
|
||
fprintf_unfiltered (gdb_stderr,
|
||
"gdb error: register no %d not implemented.\n",
|
||
regno);
|
||
return;
|
||
}
|
||
|
||
/* Fixed-point registers. */
|
||
else
|
||
{
|
||
if (!ARCH64 ())
|
||
*addr = rs6000_ptrace32 (PT_READ_GPR, pid, (int *) nr, 0, 0);
|
||
else
|
||
{
|
||
/* PT_READ_GPR requires the buffer parameter to point to long long,
|
||
even if the register is really only 32 bits. */
|
||
long long buf;
|
||
rs6000_ptrace64 (PT_READ_GPR, pid, nr, 0, &buf);
|
||
if (register_size (gdbarch, regno) == 8)
|
||
memcpy (addr, &buf, 8);
|
||
else
|
||
*addr = buf;
|
||
}
|
||
}
|
||
|
||
if (!errno)
|
||
regcache->raw_supply (regno, (char *) addr);
|
||
else
|
||
{
|
||
#if 0
|
||
/* FIXME: this happens 3 times at the start of each 64-bit program. */
|
||
perror (_("ptrace read"));
|
||
#endif
|
||
errno = 0;
|
||
}
|
||
}
|
||
|
||
/* Store register REGNO back into the inferior. */
|
||
|
||
static void
|
||
store_register (struct regcache *regcache, int regno)
|
||
{
|
||
struct gdbarch *gdbarch = regcache->arch ();
|
||
int addr[PPC_MAX_REGISTER_SIZE];
|
||
int nr, isfloat;
|
||
pid_t pid = regcache->ptid ().pid ();
|
||
|
||
/* Fetch the register's value from the register cache. */
|
||
regcache->raw_collect (regno, addr);
|
||
|
||
/* -1 can be a successful return value, so infer errors from errno. */
|
||
errno = 0;
|
||
|
||
nr = regmap (gdbarch, regno, &isfloat);
|
||
|
||
/* Floating-point registers. */
|
||
if (isfloat)
|
||
rs6000_ptrace32 (PT_WRITE_FPR, pid, addr, nr, 0);
|
||
|
||
/* Bogus register number. */
|
||
else if (nr < 0)
|
||
{
|
||
if (regno >= gdbarch_num_regs (gdbarch))
|
||
fprintf_unfiltered (gdb_stderr,
|
||
"gdb error: register no %d not implemented.\n",
|
||
regno);
|
||
}
|
||
|
||
/* Fixed-point registers. */
|
||
else
|
||
{
|
||
/* The PT_WRITE_GPR operation is rather odd. For 32-bit inferiors,
|
||
the register's value is passed by value, but for 64-bit inferiors,
|
||
the address of a buffer containing the value is passed. */
|
||
if (!ARCH64 ())
|
||
rs6000_ptrace32 (PT_WRITE_GPR, pid, (int *) nr, *addr, 0);
|
||
else
|
||
{
|
||
/* PT_WRITE_GPR requires the buffer parameter to point to an 8-byte
|
||
area, even if the register is really only 32 bits. */
|
||
long long buf;
|
||
if (register_size (gdbarch, regno) == 8)
|
||
memcpy (&buf, addr, 8);
|
||
else
|
||
buf = *addr;
|
||
rs6000_ptrace64 (PT_WRITE_GPR, pid, nr, 0, &buf);
|
||
}
|
||
}
|
||
|
||
if (errno)
|
||
{
|
||
perror (_("ptrace write"));
|
||
errno = 0;
|
||
}
|
||
}
|
||
|
||
/* Read from the inferior all registers if REGNO == -1 and just register
|
||
REGNO otherwise. */
|
||
|
||
void
|
||
rs6000_nat_target::fetch_registers (struct regcache *regcache, int regno)
|
||
{
|
||
struct gdbarch *gdbarch = regcache->arch ();
|
||
if (regno != -1)
|
||
fetch_register (regcache, regno);
|
||
|
||
else
|
||
{
|
||
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
||
|
||
/* Read 32 general purpose registers. */
|
||
for (regno = tdep->ppc_gp0_regnum;
|
||
regno < tdep->ppc_gp0_regnum + ppc_num_gprs;
|
||
regno++)
|
||
{
|
||
fetch_register (regcache, regno);
|
||
}
|
||
|
||
/* Read general purpose floating point registers. */
|
||
if (tdep->ppc_fp0_regnum >= 0)
|
||
for (regno = 0; regno < ppc_num_fprs; regno++)
|
||
fetch_register (regcache, tdep->ppc_fp0_regnum + regno);
|
||
|
||
/* Read special registers. */
|
||
fetch_register (regcache, gdbarch_pc_regnum (gdbarch));
|
||
fetch_register (regcache, tdep->ppc_ps_regnum);
|
||
fetch_register (regcache, tdep->ppc_cr_regnum);
|
||
fetch_register (regcache, tdep->ppc_lr_regnum);
|
||
fetch_register (regcache, tdep->ppc_ctr_regnum);
|
||
fetch_register (regcache, tdep->ppc_xer_regnum);
|
||
if (tdep->ppc_fpscr_regnum >= 0)
|
||
fetch_register (regcache, tdep->ppc_fpscr_regnum);
|
||
if (tdep->ppc_mq_regnum >= 0)
|
||
fetch_register (regcache, tdep->ppc_mq_regnum);
|
||
}
|
||
}
|
||
|
||
/* Store our register values back into the inferior.
|
||
If REGNO is -1, do this for all registers.
|
||
Otherwise, REGNO specifies which register (so we can save time). */
|
||
|
||
void
|
||
rs6000_nat_target::store_registers (struct regcache *regcache, int regno)
|
||
{
|
||
struct gdbarch *gdbarch = regcache->arch ();
|
||
if (regno != -1)
|
||
store_register (regcache, regno);
|
||
|
||
else
|
||
{
|
||
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
||
|
||
/* Write general purpose registers first. */
|
||
for (regno = tdep->ppc_gp0_regnum;
|
||
regno < tdep->ppc_gp0_regnum + ppc_num_gprs;
|
||
regno++)
|
||
{
|
||
store_register (regcache, regno);
|
||
}
|
||
|
||
/* Write floating point registers. */
|
||
if (tdep->ppc_fp0_regnum >= 0)
|
||
for (regno = 0; regno < ppc_num_fprs; regno++)
|
||
store_register (regcache, tdep->ppc_fp0_regnum + regno);
|
||
|
||
/* Write special registers. */
|
||
store_register (regcache, gdbarch_pc_regnum (gdbarch));
|
||
store_register (regcache, tdep->ppc_ps_regnum);
|
||
store_register (regcache, tdep->ppc_cr_regnum);
|
||
store_register (regcache, tdep->ppc_lr_regnum);
|
||
store_register (regcache, tdep->ppc_ctr_regnum);
|
||
store_register (regcache, tdep->ppc_xer_regnum);
|
||
if (tdep->ppc_fpscr_regnum >= 0)
|
||
store_register (regcache, tdep->ppc_fpscr_regnum);
|
||
if (tdep->ppc_mq_regnum >= 0)
|
||
store_register (regcache, tdep->ppc_mq_regnum);
|
||
}
|
||
}
|
||
|
||
/* Implement the to_xfer_partial target_ops method. */
|
||
|
||
enum target_xfer_status
|
||
rs6000_nat_target::xfer_partial (enum target_object object,
|
||
const char *annex, gdb_byte *readbuf,
|
||
const gdb_byte *writebuf,
|
||
ULONGEST offset, ULONGEST len,
|
||
ULONGEST *xfered_len)
|
||
{
|
||
pid_t pid = inferior_ptid.pid ();
|
||
int arch64 = ARCH64 ();
|
||
|
||
switch (object)
|
||
{
|
||
case TARGET_OBJECT_LIBRARIES_AIX:
|
||
return xfer_shared_libraries (object, annex,
|
||
readbuf, writebuf,
|
||
offset, len, xfered_len);
|
||
case TARGET_OBJECT_MEMORY:
|
||
{
|
||
union
|
||
{
|
||
PTRACE_TYPE_RET word;
|
||
gdb_byte byte[sizeof (PTRACE_TYPE_RET)];
|
||
} buffer;
|
||
ULONGEST rounded_offset;
|
||
LONGEST partial_len;
|
||
|
||
/* Round the start offset down to the next long word
|
||
boundary. */
|
||
rounded_offset = offset & -(ULONGEST) sizeof (PTRACE_TYPE_RET);
|
||
|
||
/* Since ptrace will transfer a single word starting at that
|
||
rounded_offset the partial_len needs to be adjusted down to
|
||
that (remember this function only does a single transfer).
|
||
Should the required length be even less, adjust it down
|
||
again. */
|
||
partial_len = (rounded_offset + sizeof (PTRACE_TYPE_RET)) - offset;
|
||
if (partial_len > len)
|
||
partial_len = len;
|
||
|
||
if (writebuf)
|
||
{
|
||
/* If OFFSET:PARTIAL_LEN is smaller than
|
||
ROUNDED_OFFSET:WORDSIZE then a read/modify write will
|
||
be needed. Read in the entire word. */
|
||
if (rounded_offset < offset
|
||
|| (offset + partial_len
|
||
< rounded_offset + sizeof (PTRACE_TYPE_RET)))
|
||
{
|
||
/* Need part of initial word -- fetch it. */
|
||
if (arch64)
|
||
buffer.word = rs6000_ptrace64 (PT_READ_I, pid,
|
||
rounded_offset, 0, NULL);
|
||
else
|
||
buffer.word = rs6000_ptrace32 (PT_READ_I, pid,
|
||
(int *) (uintptr_t)
|
||
rounded_offset,
|
||
0, NULL);
|
||
}
|
||
|
||
/* Copy data to be written over corresponding part of
|
||
buffer. */
|
||
memcpy (buffer.byte + (offset - rounded_offset),
|
||
writebuf, partial_len);
|
||
|
||
errno = 0;
|
||
if (arch64)
|
||
rs6000_ptrace64 (PT_WRITE_D, pid,
|
||
rounded_offset, buffer.word, NULL);
|
||
else
|
||
rs6000_ptrace32 (PT_WRITE_D, pid,
|
||
(int *) (uintptr_t) rounded_offset,
|
||
buffer.word, NULL);
|
||
if (errno)
|
||
return TARGET_XFER_EOF;
|
||
}
|
||
|
||
if (readbuf)
|
||
{
|
||
errno = 0;
|
||
if (arch64)
|
||
buffer.word = rs6000_ptrace64 (PT_READ_I, pid,
|
||
rounded_offset, 0, NULL);
|
||
else
|
||
buffer.word = rs6000_ptrace32 (PT_READ_I, pid,
|
||
(int *)(uintptr_t)rounded_offset,
|
||
0, NULL);
|
||
if (errno)
|
||
return TARGET_XFER_EOF;
|
||
|
||
/* Copy appropriate bytes out of the buffer. */
|
||
memcpy (readbuf, buffer.byte + (offset - rounded_offset),
|
||
partial_len);
|
||
}
|
||
|
||
*xfered_len = (ULONGEST) partial_len;
|
||
return TARGET_XFER_OK;
|
||
}
|
||
|
||
default:
|
||
return TARGET_XFER_E_IO;
|
||
}
|
||
}
|
||
|
||
/* Wait for the child specified by PTID to do something. Return the
|
||
process ID of the child, or MINUS_ONE_PTID in case of error; store
|
||
the status in *OURSTATUS. */
|
||
|
||
ptid_t
|
||
rs6000_nat_target::wait (ptid_t ptid, struct target_waitstatus *ourstatus,
|
||
int options)
|
||
{
|
||
pid_t pid;
|
||
int status, save_errno;
|
||
|
||
do
|
||
{
|
||
set_sigint_trap ();
|
||
|
||
do
|
||
{
|
||
pid = waitpid (ptid.pid (), &status, 0);
|
||
save_errno = errno;
|
||
}
|
||
while (pid == -1 && errno == EINTR);
|
||
|
||
clear_sigint_trap ();
|
||
|
||
if (pid == -1)
|
||
{
|
||
fprintf_unfiltered (gdb_stderr,
|
||
_("Child process unexpectedly missing: %s.\n"),
|
||
safe_strerror (save_errno));
|
||
|
||
/* Claim it exited with unknown signal. */
|
||
ourstatus->kind = TARGET_WAITKIND_SIGNALLED;
|
||
ourstatus->value.sig = GDB_SIGNAL_UNKNOWN;
|
||
return inferior_ptid;
|
||
}
|
||
|
||
/* Ignore terminated detached child processes. */
|
||
if (!WIFSTOPPED (status) && pid != inferior_ptid.pid ())
|
||
pid = -1;
|
||
}
|
||
while (pid == -1);
|
||
|
||
/* AIX has a couple of strange returns from wait(). */
|
||
|
||
/* stop after load" status. */
|
||
if (status == 0x57c)
|
||
ourstatus->kind = TARGET_WAITKIND_LOADED;
|
||
/* signal 0. I have no idea why wait(2) returns with this status word. */
|
||
else if (status == 0x7f)
|
||
ourstatus->kind = TARGET_WAITKIND_SPURIOUS;
|
||
/* A normal waitstatus. Let the usual macros deal with it. */
|
||
else
|
||
store_waitstatus (ourstatus, status);
|
||
|
||
return ptid_t (pid);
|
||
}
|
||
|
||
|
||
/* Set the current architecture from the host running GDB. Called when
|
||
starting a child process. */
|
||
|
||
void
|
||
rs6000_nat_target::create_inferior (const char *exec_file,
|
||
const std::string &allargs,
|
||
char **env, int from_tty)
|
||
{
|
||
enum bfd_architecture arch;
|
||
unsigned long mach;
|
||
bfd abfd;
|
||
struct gdbarch_info info;
|
||
|
||
inf_ptrace_target::create_inferior (exec_file, allargs, env, from_tty);
|
||
|
||
if (__power_rs ())
|
||
{
|
||
arch = bfd_arch_rs6000;
|
||
mach = bfd_mach_rs6k;
|
||
}
|
||
else
|
||
{
|
||
arch = bfd_arch_powerpc;
|
||
mach = bfd_mach_ppc;
|
||
}
|
||
|
||
/* FIXME: schauer/2002-02-25:
|
||
We don't know if we are executing a 32 or 64 bit executable,
|
||
and have no way to pass the proper word size to rs6000_gdbarch_init.
|
||
So we have to avoid switching to a new architecture, if the architecture
|
||
matches already.
|
||
Blindly calling rs6000_gdbarch_init used to work in older versions of
|
||
GDB, as rs6000_gdbarch_init incorrectly used the previous tdep to
|
||
determine the wordsize. */
|
||
if (exec_bfd)
|
||
{
|
||
const struct bfd_arch_info *exec_bfd_arch_info;
|
||
|
||
exec_bfd_arch_info = bfd_get_arch_info (exec_bfd);
|
||
if (arch == exec_bfd_arch_info->arch)
|
||
return;
|
||
}
|
||
|
||
bfd_default_set_arch_mach (&abfd, arch, mach);
|
||
|
||
gdbarch_info_init (&info);
|
||
info.bfd_arch_info = bfd_get_arch_info (&abfd);
|
||
info.abfd = exec_bfd;
|
||
|
||
if (!gdbarch_update_p (info))
|
||
internal_error (__FILE__, __LINE__,
|
||
_("rs6000_create_inferior: failed "
|
||
"to select architecture"));
|
||
}
|
||
|
||
|
||
/* Shared Object support. */
|
||
|
||
/* Return the LdInfo data for the given process. Raises an error
|
||
if the data could not be obtained. */
|
||
|
||
static gdb::byte_vector
|
||
rs6000_ptrace_ldinfo (ptid_t ptid)
|
||
{
|
||
const int pid = ptid.pid ();
|
||
gdb::byte_vector ldi (1024);
|
||
int rc = -1;
|
||
|
||
while (1)
|
||
{
|
||
if (ARCH64 ())
|
||
rc = rs6000_ptrace64 (PT_LDINFO, pid, (unsigned long) ldi.data (),
|
||
ldi.size (), NULL);
|
||
else
|
||
rc = rs6000_ptrace32 (PT_LDINFO, pid, (int *) ldi.data (),
|
||
ldi.size (), NULL);
|
||
|
||
if (rc != -1)
|
||
break; /* Success, we got the entire ld_info data. */
|
||
|
||
if (errno != ENOMEM)
|
||
perror_with_name (_("ptrace ldinfo"));
|
||
|
||
/* ldi is not big enough. Double it and try again. */
|
||
ldi.resize (ldi.size () * 2);
|
||
}
|
||
|
||
return ldi;
|
||
}
|
||
|
||
/* Implement the to_xfer_partial target_ops method for
|
||
TARGET_OBJECT_LIBRARIES_AIX objects. */
|
||
|
||
enum target_xfer_status
|
||
rs6000_nat_target::xfer_shared_libraries
|
||
(enum target_object object,
|
||
const char *annex, gdb_byte *readbuf, const gdb_byte *writebuf,
|
||
ULONGEST offset, ULONGEST len, ULONGEST *xfered_len)
|
||
{
|
||
ULONGEST result;
|
||
|
||
/* This function assumes that it is being run with a live process.
|
||
Core files are handled via gdbarch. */
|
||
gdb_assert (target_has_execution);
|
||
|
||
if (writebuf)
|
||
return TARGET_XFER_E_IO;
|
||
|
||
gdb::byte_vector ldi_buf = rs6000_ptrace_ldinfo (inferior_ptid);
|
||
result = rs6000_aix_ld_info_to_xml (target_gdbarch (), ldi_buf.data (),
|
||
readbuf, offset, len, 1);
|
||
|
||
if (result == 0)
|
||
return TARGET_XFER_EOF;
|
||
else
|
||
{
|
||
*xfered_len = result;
|
||
return TARGET_XFER_OK;
|
||
}
|
||
}
|
||
|
||
void _initialize_rs6000_nat ();
|
||
void
|
||
_initialize_rs6000_nat ()
|
||
{
|
||
add_inf_child_target (&the_rs6000_nat_target);
|
||
}
|