mcf5225x_512_rom.ld 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright 2012 by Embedded Technologies s.r.o
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. *
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name of the copyright holders nor the names of
  14. * contributors may be used to endorse or promote products derived
  15. * from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  18. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  19. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  20. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  21. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  22. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  23. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  24. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  25. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  26. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  27. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. *
  30. * For additional information see http://www.ethernut.de/
  31. */
  32. OUTPUT_ARCH(m68k)
  33. STARTUP(crt_common.o)
  34. INPUT(crt_mcf5225x.o)
  35. INPUT(libnutarch.a) /* FIXME: Remove this temporary fix */
  36. INPUT(crt_mcf5225x_512_rom.o)
  37. ENTRY(_start)
  38. /*
  39. * Memory regions
  40. */
  41. MEMORY
  42. {
  43. bootloader(r) : ORIGIN = 0x00000000, LENGTH = 0
  44. rom(rx) : ORIGIN = 0x00000000 + LENGTH(bootloader), LENGTH = 512K - LENGTH(bootloader)
  45. intram(rwx) : ORIGIN = 0x20000000, LENGTH = 64K
  46. ipsbar(rw) : ORIGIN = 0x40000000, LENGTH = 1024M
  47. extram(rwx) : ORIGIN = 0x80000000, LENGTH = 0
  48. }
  49. /*
  50. * Symbols for CPU initialization
  51. */
  52. PROVIDE (__intram_start = ORIGIN(intram));
  53. PROVIDE (__intram_size = LENGTH(intram));
  54. PROVIDE (__extram_start = ORIGIN(extram));
  55. PROVIDE (__extram_size = LENGTH(extram));
  56. PROVIDE (__rambar = __intram_start);
  57. PROVIDE (__flashbar = ORIGIN(bootloader));
  58. PROVIDE (__ipsbar = ORIGIN(ipsbar));
  59. PROVIDE (__stack_init = __intram_start + __intram_size);
  60. /*
  61. * Symbols required for Nut/OS initialization
  62. */
  63. PROVIDE (__stack_heap_start = 0);
  64. PROVIDE (__stack_heap_size = 0);
  65. PROVIDE (__heap_start = __bss_end);
  66. PROVIDE (__heap_size = __intram_size - (__heap_start - __intram_start));
  67. PROVIDE (__heap2_start = 0);
  68. PROVIDE (__heap2_size = 0);
  69. /*
  70. * VMA - Virtual Memory Addresses
  71. * This are the addresses the sections will have when the code is running
  72. * (after code relocation)
  73. */
  74. REGION_ALIAS("REGION_TEXT", rom);
  75. REGION_ALIAS("REGION_RODATA", rom);
  76. REGION_ALIAS("REGION_DATA", intram);
  77. REGION_ALIAS("REGION_DATA_INT", intram);
  78. REGION_ALIAS("REGION_BSS", intram);
  79. REGION_ALIAS("REGION_BSS_INT", intram);
  80. /*
  81. * LMA - Load Memory Address
  82. * This is the address at which the code will be placed after power on
  83. * (before code relocation)
  84. */
  85. REGION_ALIAS("REGION_LOAD", rom);
  86. /*
  87. * Sections description
  88. */
  89. INCLUDE sections.ld