vmlinux.lds: move __attribute__((__cold__)) functions back into final .text section

Due to the addition of __attribute__((__cold__)) to a few symbols
without adjusting the linker scripts, those symbols currently may end
up outside the [_stext,_etext) range, as they get placed in
.text.unlikely by (at least) gcc 4.3.0. This may confuse code not only
outside of the kernel, symbol_put_addr()'s BUG() could also trigger.
Hence we need to add .text.unlikely (and for future uses of
__attribute__((__hot__)) also .text.hot) to the TEXT_TEXT() macro.

Issue observed by Lukas Lipavsky.

Signed-off-by: Jan Beulich <jbeulich@novell.com>
Tested-by: Lukas Lipavsky <llipavsky@suse.cz>
Cc: <stable@kernel.org>
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>

authored by

Jan Beulich and committed by
Sam Ravnborg
fb5e2b37 37a4c940

+3 -1
+3 -1
include/asm-generic/vmlinux.lds.h
··· 221 * during second ld run in second ld pass when generating System.map */ 222 #define TEXT_TEXT \ 223 ALIGN_FUNCTION(); \ 224 *(.text) \ 225 *(.ref.text) \ 226 *(.text.init.refok) \ ··· 231 CPU_KEEP(init.text) \ 232 CPU_KEEP(exit.text) \ 233 MEM_KEEP(init.text) \ 234 - MEM_KEEP(exit.text) 235 236 237 /* sched.text is aling to function alignment to secure we have same
··· 221 * during second ld run in second ld pass when generating System.map */ 222 #define TEXT_TEXT \ 223 ALIGN_FUNCTION(); \ 224 + *(.text.hot) \ 225 *(.text) \ 226 *(.ref.text) \ 227 *(.text.init.refok) \ ··· 230 CPU_KEEP(init.text) \ 231 CPU_KEEP(exit.text) \ 232 MEM_KEEP(init.text) \ 233 + MEM_KEEP(exit.text) \ 234 + *(.text.unlikely) 235 236 237 /* sched.text is aling to function alignment to secure we have same