fbsd-tdep.h 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /* Target-dependent code for FreeBSD, architecture independent.
  2. Copyright (C) 2009-2022 Free Software Foundation, Inc.
  3. This file is part of GDB.
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 3 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program. If not, see <http://www.gnu.org/licenses/>. */
  14. #ifndef FBSD_TDEP_H
  15. #define FBSD_TDEP_H
  16. extern void fbsd_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch);
  17. /* Output the header for "info proc files". */
  18. extern void fbsd_info_proc_files_header ();
  19. /* Output description of a single file descriptor for "info proc
  20. files". The KF_TYPE, KF_FD, KF_FLAGS, KF_OFFSET, KF_VNODE_TYPE,
  21. KF_SOCK_DOMAIN, KF_SOCK_TYPE, and KF_SOCK_PROTOCOL parameters
  22. should contain the value of the corresponding fields in a 'struct
  23. kinfo_file'. The KF_SA_LOCAL, KF_SA_PEER, and KF_PATH parameters
  24. should contain pointers to the corresponding fields in a 'struct
  25. kinfo_file'. */
  26. extern void fbsd_info_proc_files_entry (int kf_type, int kf_fd, int kf_flags,
  27. LONGEST kf_offset, int kf_vnode_type,
  28. int kf_sock_domain, int kf_sock_type,
  29. int kf_sock_protocol,
  30. const void *kf_sa_local,
  31. const void *kf_sa_peer,
  32. const void *kf_path);
  33. /* Output the header for "info proc mappings". ADDR_BIT is the size
  34. of a virtual address in bits. */
  35. extern void fbsd_info_proc_mappings_header (int addr_bit);
  36. /* Output description of a single memory range for "info proc
  37. mappings". ADDR_BIT is the size of a virtual address in bits. The
  38. KVE_START, KVE_END, KVE_OFFSET, KVE_FLAGS, and KVE_PROTECTION
  39. parameters should contain the value of the corresponding fields in
  40. a 'struct kinfo_vmentry'. The KVE_PATH parameter should contain a
  41. pointer to the 'kve_path' field in a 'struct kinfo_vmentry'. */
  42. extern void fbsd_info_proc_mappings_entry (int addr_bit, ULONGEST kve_start,
  43. ULONGEST kve_end,
  44. ULONGEST kve_offset,
  45. int kve_flags, int kve_protection,
  46. const void *kve_path);
  47. /* Helper function to fetch the address of a thread-local variable.
  48. DTV_ADDR is the base address of the thread's dtv array. LM_ADDR is
  49. the address of the link_map structure for the associated object
  50. file. OFFSET is the offset of the variable in the object file's
  51. thread-local variable block. */
  52. extern CORE_ADDR fbsd_get_thread_local_address (struct gdbarch *gdbarch,
  53. CORE_ADDR dtv_addr,
  54. CORE_ADDR lm_addr,
  55. CORE_ADDR offset);
  56. /* Implement the "skip_solib_resolver" gdbarch method. */
  57. extern CORE_ADDR fbsd_skip_solib_resolver (struct gdbarch *gdbarch,
  58. CORE_ADDR pc);
  59. #endif /* fbsd-tdep.h */