u-boot-spl.lds 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /*
  2. * (C) Copyright 2002
  3. * Daniel Engström, Omicron Ceti AB, daniel@omicron.se.
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #include <config.h>
  8. OUTPUT_FORMAT("elf32-i386", "elf32-i386", "elf32-i386")
  9. OUTPUT_ARCH(i386)
  10. ENTRY(_start)
  11. SECTIONS
  12. {
  13. #ifndef CONFIG_CMDLINE
  14. /DISCARD/ : { *(.u_boot_list_2_cmd_*) }
  15. #endif
  16. . = CONFIG_SPL_TEXT_BASE; /* Location of bootcode in flash */
  17. __text_start = .;
  18. .text : { *(.text*); }
  19. . = ALIGN(4);
  20. . = ALIGN(4);
  21. .u_boot_list : {
  22. KEEP(*(SORT(.u_boot_list*)));
  23. }
  24. . = ALIGN(4);
  25. .rodata : { *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) }
  26. . = ALIGN(4);
  27. .data : { *(.data*) }
  28. . = ALIGN(4);
  29. __data_end = .;
  30. __init_end = .;
  31. _image_binary_end = .;
  32. . = 0x120000;
  33. .bss (OVERLAY) : {
  34. __bss_start = .;
  35. *(.bss*)
  36. *(COM*)
  37. . = ALIGN(4);
  38. __bss_end = .;
  39. }
  40. __bss_size = __bss_end - __bss_start;
  41. /DISCARD/ : { *(.dynstr*) }
  42. /DISCARD/ : { *(.dynamic*) }
  43. /DISCARD/ : { *(.plt*) }
  44. /DISCARD/ : { *(.interp*) }
  45. /DISCARD/ : { *(.gnu*) }
  46. #ifdef CONFIG_SPL_X86_16BIT_INIT
  47. /*
  48. * The following expressions place the 16-bit Real-Mode code and
  49. * Reset Vector at the end of the Flash ROM
  50. */
  51. . = START_16 - RESET_SEG_START;
  52. .start16 : AT (START_16) {
  53. KEEP(*(.start16));
  54. }
  55. . = RESET_VEC_LOC - RESET_SEG_START;
  56. .resetvec : AT (RESET_VEC_LOC) {
  57. KEEP(*(.resetvec));
  58. }
  59. #endif
  60. }