Commit 08fdffd4 authored by Russell King's avatar Russell King Committed by Russell King

[ARM] Ensure head text is always placed at the start of kernel

Commit 86c0baf1 highlighted that we
may end up with the head text placed elsewhere in the kernel image.
Introduce a new .text.head section to contain the initial kernel
startup code, and always place this section at the beginning of the
kernel image.
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 4efb4482
...@@ -33,7 +33,7 @@ ...@@ -33,7 +33,7 @@
* numbers for r1. * numbers for r1.
* *
*/ */
__INIT .section ".text.head", "ax"
.type stext, %function .type stext, %function
ENTRY(stext) ENTRY(stext)
msr cpsr_c, #PSR_F_BIT | PSR_I_BIT | SVC_MODE @ ensure svc mode msr cpsr_c, #PSR_F_BIT | PSR_I_BIT | SVC_MODE @ ensure svc mode
......
...@@ -73,7 +73,7 @@ ...@@ -73,7 +73,7 @@
* crap here - that's what the boot loader (or in extreme, well justified * crap here - that's what the boot loader (or in extreme, well justified
* circumstances, zImage) is for. * circumstances, zImage) is for.
*/ */
__INIT .section ".text.head", "ax"
.type stext, %function .type stext, %function
ENTRY(stext) ENTRY(stext)
msr cpsr_c, #PSR_F_BIT | PSR_I_BIT | SVC_MODE @ ensure svc mode msr cpsr_c, #PSR_F_BIT | PSR_I_BIT | SVC_MODE @ ensure svc mode
......
...@@ -23,11 +23,15 @@ SECTIONS ...@@ -23,11 +23,15 @@ SECTIONS
#else #else
. = PAGE_OFFSET + TEXT_OFFSET; . = PAGE_OFFSET + TEXT_OFFSET;
#endif #endif
.init : { /* Init code and data */ .text.head : {
_stext = .; _stext = .;
_sinittext = .; _sinittext = .;
*(.text.head)
}
.init : { /* Init code and data */
*(.init.text) *(.init.text)
_einittext = .; _einittext = .;
__proc_info_begin = .; __proc_info_begin = .;
*(.proc.info.init) *(.proc.info.init)
__proc_info_end = .; __proc_info_end = .;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment