vmlinux.lds.S 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /*
  2. * ld script for the c6x kernel
  3. *
  4. * Copyright (C) 2010, 2011 Texas Instruments Incorporated
  5. * Mark Salter <msalter@redhat.com>
  6. */
  7. #include <asm-generic/vmlinux.lds.h>
  8. #include <asm/thread_info.h>
  9. #include <asm/page.h>
  10. ENTRY(_c_int00)
  11. #if defined(CONFIG_CPU_BIG_ENDIAN)
  12. jiffies = jiffies_64 + 4;
  13. #else
  14. jiffies = jiffies_64;
  15. #endif
  16. #define READONLY_SEGMENT_START \
  17. . = PAGE_OFFSET;
  18. #define READWRITE_SEGMENT_START \
  19. . = ALIGN(128); \
  20. _data_lma = .;
  21. SECTIONS
  22. {
  23. /*
  24. * Start kernel read only segment
  25. */
  26. READONLY_SEGMENT_START
  27. .vectors :
  28. {
  29. _vectors_start = .;
  30. *(.vectors)
  31. . = ALIGN(0x400);
  32. _vectors_end = .;
  33. }
  34. /*
  35. * This section contains data which may be shared with other
  36. * cores. It needs to be a fixed offset from PAGE_OFFSET
  37. * regardless of kernel configuration.
  38. */
  39. .virtio_ipc_dev :
  40. {
  41. *(.virtio_ipc_dev)
  42. }
  43. . = ALIGN(PAGE_SIZE);
  44. __init_begin = .;
  45. .init :
  46. {
  47. _sinittext = .;
  48. HEAD_TEXT
  49. INIT_TEXT
  50. _einittext = .;
  51. }
  52. INIT_DATA_SECTION(16)
  53. PERCPU_SECTION(128)
  54. . = ALIGN(PAGE_SIZE);
  55. __init_end = .;
  56. .text :
  57. {
  58. _text = .;
  59. _stext = .;
  60. TEXT_TEXT
  61. SCHED_TEXT
  62. CPUIDLE_TEXT
  63. LOCK_TEXT
  64. IRQENTRY_TEXT
  65. SOFTIRQENTRY_TEXT
  66. KPROBES_TEXT
  67. *(.fixup)
  68. *(.gnu.warning)
  69. }
  70. EXCEPTION_TABLE(16)
  71. NOTES
  72. RO_DATA_SECTION(PAGE_SIZE)
  73. .const :
  74. {
  75. *(.const .const.* .gnu.linkonce.r.*)
  76. *(.switch)
  77. }
  78. . = ALIGN (8) ;
  79. __fdt_blob : AT(ADDR(__fdt_blob) - LOAD_OFFSET)
  80. {
  81. _fdt_start = . ; /* place for fdt blob */
  82. *(__fdt_blob) ; /* Any link-placed DTB */
  83. BYTE(0); /* section always has contents */
  84. . = _fdt_start + 0x4000; /* Pad up to 16kbyte */
  85. _fdt_end = . ;
  86. }
  87. _etext = .;
  88. /*
  89. * Start kernel read-write segment.
  90. */
  91. READWRITE_SEGMENT_START
  92. _sdata = .;
  93. .fardata : AT(ADDR(.fardata) - LOAD_OFFSET)
  94. {
  95. INIT_TASK_DATA(THREAD_SIZE)
  96. NOSAVE_DATA
  97. PAGE_ALIGNED_DATA(PAGE_SIZE)
  98. CACHELINE_ALIGNED_DATA(128)
  99. READ_MOSTLY_DATA(128)
  100. DATA_DATA
  101. CONSTRUCTORS
  102. *(.data1)
  103. *(.fardata .fardata.*)
  104. *(.data.debug_bpt)
  105. }
  106. .neardata ALIGN(8) : AT(ADDR(.neardata) - LOAD_OFFSET)
  107. {
  108. *(.neardata2 .neardata2.* .gnu.linkonce.s2.*)
  109. *(.neardata .neardata.* .gnu.linkonce.s.*)
  110. . = ALIGN(8);
  111. }
  112. _edata = .;
  113. __bss_start = .;
  114. SBSS(8)
  115. BSS(8)
  116. .far :
  117. {
  118. . = ALIGN(8);
  119. *(.dynfar)
  120. *(.far .far.* .gnu.linkonce.b.*)
  121. . = ALIGN(8);
  122. }
  123. __bss_stop = .;
  124. _end = .;
  125. DWARF_DEBUG
  126. /DISCARD/ :
  127. {
  128. EXIT_TEXT
  129. EXIT_DATA
  130. EXIT_CALL
  131. *(.discard)
  132. *(.discard.*)
  133. *(.interp)
  134. }
  135. }