elf32-ARM-debug.hex2 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. ### Copyright (C) 2016 Jeremiah Orians
  2. ### Copyright (C) 2017 Jan Nieuwenhuizen <janneke@gnu.org>
  3. ### This file is part of stage0.
  4. ###
  5. ### stage0 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. ###
  10. ### stage0 is distributed in the hope that it will be useful,
  11. ### but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. ### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. ### GNU General Public License for more details.
  14. ###
  15. ### You should have received a copy of the GNU General Public License
  16. ### along with stage0. If not, see <http://www.gnu.org/licenses/>.
  17. ### stage0's hex2 format
  18. ### !<label> 1 byte relative
  19. ### $<label> 2 byte address
  20. ### @<label> 2 byte relative
  21. ### &<label> 4 byte address
  22. ### %<label> 4 byte relative
  23. ### elf32.hex2: 32 bit elf header in hex2
  24. ### if you wish to use this header, you need to add :ELF_end to the end of your
  25. ### M1 or hex2 files.
  26. ## ELF Header
  27. :ELF_base
  28. 7F 45 4C 46 # e_ident[EI_MAG0-3] ELF's magic number
  29. 01 # e_ident[EI_CLASS] Indicating 32 bit
  30. 01 # e_ident[EI_DATA] Indicating little endianness
  31. 01 # e_ident[EI_VERSION] Indicating original elf
  32. 03 # e_ident[EI_OSABI] Set at 3 because FreeBSD is strict
  33. 00 # e_ident[EI_ABIVERSION] See above
  34. 00 00 00 00 00 00 00 # e_ident[EI_PAD]
  35. 02 00 # e_type Indicating Executable
  36. 28 00 # e_machine Indicating 32bit ARM
  37. 01 00 00 00 # e_version Indicating original elf
  38. &_start # e_entry Address of the entry point
  39. %ELF_program_headers>ELF_base # e_phoff Address of program header table
  40. %ELF_section_headers>ELF_base # e_shoff Address of section header table
  41. 00 02 00 05 # e_flags
  42. 34 00 # e_ehsize Indicating our 52 Byte header
  43. 20 00 # e_phentsize size of a program header table
  44. 01 00 # e_phnum number of entries in program table
  45. 28 00 # e_shentsize size of a section header table
  46. 05 00 # e_shnum number of entries in section table
  47. 02 00 # e_shstrndx index of the section names
  48. # @40
  49. :ELF_program_headers
  50. :ELF_program_header__text
  51. 01 00 00 00 # ph_type: PT-LOAD = 1
  52. 00 00 00 00 # ph_offset
  53. &ELF_base # ph_vaddr
  54. &ELF_base # ph_physaddr
  55. %ELF_end>ELF_base # ph_filesz
  56. %ELF_end>ELF_base # ph_memsz
  57. 07 00 00 00 # ph_flags: PF-X|PF-W|PF-R = 7
  58. 00 00 01 00 # alignment
  59. :ELF_text