提交 aad09470 编写于 作者: J Jan Beulich 提交者: Linus Torvalds

[PATCH] move kallsyms data to .rodata

Kallsyms data is never written to, so it can as well benefit from
CONFIG_DEBUG_RODATA.
Signed-off-by: NJan Beulich <jbeulich@novell.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 d93f7de8
...@@ -31,14 +31,14 @@ ...@@ -31,14 +31,14 @@
#endif #endif
/* These will be re-linked against their real values during the second link stage */ /* These will be re-linked against their real values during the second link stage */
extern unsigned long kallsyms_addresses[] __attribute__((weak)); extern const unsigned long kallsyms_addresses[] __attribute__((weak));
extern unsigned long kallsyms_num_syms __attribute__((weak,section("data"))); extern const unsigned long kallsyms_num_syms __attribute__((weak));
extern u8 kallsyms_names[] __attribute__((weak)); extern const u8 kallsyms_names[] __attribute__((weak));
extern u8 kallsyms_token_table[] __attribute__((weak)); extern const u8 kallsyms_token_table[] __attribute__((weak));
extern u16 kallsyms_token_index[] __attribute__((weak)); extern const u16 kallsyms_token_index[] __attribute__((weak));
extern unsigned long kallsyms_markers[] __attribute__((weak)); extern const unsigned long kallsyms_markers[] __attribute__((weak));
static inline int is_kernel_inittext(unsigned long addr) static inline int is_kernel_inittext(unsigned long addr)
{ {
...@@ -84,7 +84,7 @@ static int is_ksym_addr(unsigned long addr) ...@@ -84,7 +84,7 @@ static int is_ksym_addr(unsigned long addr)
static unsigned int kallsyms_expand_symbol(unsigned int off, char *result) static unsigned int kallsyms_expand_symbol(unsigned int off, char *result)
{ {
int len, skipped_first = 0; int len, skipped_first = 0;
u8 *tptr, *data; const u8 *tptr, *data;
/* get the compressed symbol length from the first symbol byte */ /* get the compressed symbol length from the first symbol byte */
data = &kallsyms_names[off]; data = &kallsyms_names[off];
...@@ -132,7 +132,7 @@ static char kallsyms_get_symbol_type(unsigned int off) ...@@ -132,7 +132,7 @@ static char kallsyms_get_symbol_type(unsigned int off)
* kallsyms array */ * kallsyms array */
static unsigned int get_symbol_offset(unsigned long pos) static unsigned int get_symbol_offset(unsigned long pos)
{ {
u8 *name; const u8 *name;
int i; int i;
/* use the closest marker we have. We have markers every 256 positions, /* use the closest marker we have. We have markers every 256 positions,
......
...@@ -265,7 +265,7 @@ static void write_src(void) ...@@ -265,7 +265,7 @@ static void write_src(void)
printf("#define ALGN .align 4\n"); printf("#define ALGN .align 4\n");
printf("#endif\n"); printf("#endif\n");
printf(".data\n"); printf("\t.section .rodata, \"a\"\n");
/* Provide proper symbols relocatability by their '_text' /* Provide proper symbols relocatability by their '_text'
* relativeness. The symbol names cannot be used to construct * relativeness. The symbol names cannot be used to construct
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册