elf32-avr.h 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. /* AVR-specific support for 32-bit ELF.
  2. Copyright (C) 2006-2015 Free Software Foundation, Inc.
  3. Written by Bjoern Haase <bjoern.m.haase@web.de>
  4. This file is part of BFD, the Binary File Descriptor library.
  5. This program is free software; you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation; either version 3 of the License, or
  8. (at your option) any later version.
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. You should have received a copy of the GNU General Public License
  14. along with this program; if not, write to the Free Software
  15. Foundation, Inc., 51 Franklin Street - Fifth Floor,
  16. Boston, MA 02110-1301, USA. */
  17. /* These four functions will be called from the ld back-end. */
  18. extern void
  19. elf32_avr_setup_params (struct bfd_link_info *, bfd *, asection *,
  20. bfd_boolean, bfd_boolean, bfd_boolean,
  21. bfd_vma, bfd_boolean);
  22. extern int
  23. elf32_avr_setup_section_lists (bfd *, struct bfd_link_info *);
  24. extern bfd_boolean
  25. elf32_avr_size_stubs (bfd *, struct bfd_link_info *, bfd_boolean);
  26. extern bfd_boolean
  27. elf32_avr_build_stubs (struct bfd_link_info *);
  28. /* The name of the section into which the property records are stored. */
  29. #define AVR_PROPERTY_RECORD_SECTION_NAME ".avr.prop"
  30. /* The current version number for the format of the property records. */
  31. #define AVR_PROPERTY_RECORDS_VERSION 1
  32. /* The size of the header that is written to the property record section
  33. before the property records are written out. */
  34. #define AVR_PROPERTY_SECTION_HEADER_SIZE 4
  35. /* This holds a single property record in memory, the structure of this
  36. data when written out to the ELF section is more compressed. */
  37. struct avr_property_record
  38. {
  39. /* The section and offset for this record. */
  40. asection *section;
  41. bfd_vma offset;
  42. /* The type of this record. */
  43. enum {
  44. RECORD_ORG = 0,
  45. RECORD_ORG_AND_FILL = 1,
  46. RECORD_ALIGN = 2,
  47. RECORD_ALIGN_AND_FILL = 3
  48. } type;
  49. /* Type specific data. */
  50. union
  51. {
  52. /* RECORD_ORG and RECORD_ORG_AND_FILL. */
  53. struct
  54. {
  55. unsigned long fill;
  56. } org;
  57. /* RECORD_ALIGN and RECORD_ALIGN_AND_FILL. */
  58. struct
  59. {
  60. unsigned long bytes;
  61. unsigned long fill;
  62. /* This field is used during linker relaxation to track the number of
  63. bytes that have been opened up before this alignment directive.
  64. When we have enough bytes available it is possible to move the
  65. re-align this directive backwards while still maintaining the
  66. alignment requirement. */
  67. unsigned long preceding_deleted;
  68. } align;
  69. } data;
  70. };
  71. struct avr_property_record_list
  72. {
  73. /* The version number tells us the structure of the property record data
  74. within the section. See AVR_PROPERTY_RECORDS_VERSION. */
  75. bfd_byte version;
  76. /* The flags field is currently unused. This should be set to 0. */
  77. bfd_byte flags;
  78. /* The number of property records. This is stored as a 2-byte value in
  79. the section contents. */
  80. unsigned long record_count;
  81. /* The section from which the property records were loaded. This is the
  82. actual section containing the records, not the section(s) to which the
  83. records apply. */
  84. asection *section;
  85. /* The actual property records. */
  86. struct avr_property_record *records;
  87. };
  88. /* Load the property records from ABFD, return NULL if there are non
  89. found, otherwise return pointer to dynamically allocated memory. The
  90. memory for the header and all of the records are allocated in a single
  91. block, as such only the header needs to be freed. */
  92. extern struct avr_property_record_list *avr_elf32_load_property_records (bfd *abfd);
  93. /* Return a string that is the name of the property record pointed to by REC. */
  94. extern const char *avr_elf32_property_record_name (struct avr_property_record *rec);