debugobjects: Section mismatch cleanup
authorHenrik Kretzschmar <henne@nachtwindheim.de>
Fri, 26 Mar 2010 19:38:35 +0000 (20:38 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Fri, 26 Mar 2010 20:52:29 +0000 (21:52 +0100)
This patch marks two functions, which only get called at
initialization, as __init.

Here is also interesting, that modpost doesn't catch here the right
function name.

WARNING: lib/built-in.o(.text+0x585f): Section mismatch in reference
from the function T.506() to the variable .init.data:obj
The function T.506() references the variable __initdata obj.
This is often because T.506 lacks a __initdata annotation or the
annotation of obj is wrong.

Signed-off-by: Henrik Kretzschmar <henne@nachtwindheim.de>
LKML-Reference: <1269632315-19403-1-git-send-email-henne@nachtwindheim.de>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
lib/debugobjects.c

index a9a8996d286a8e64f5ac23aec220b7645356cfac..c4ecd3ce7fd403af3e223f58378ed09e6bac0005 100644 (file)
@@ -773,7 +773,7 @@ static int __init fixup_free(void *addr, enum debug_obj_state state)
        }
 }
 
-static int
+static int __init
 check_results(void *addr, enum debug_obj_state state, int fixups, int warnings)
 {
        struct debug_bucket *db;
@@ -916,7 +916,7 @@ void __init debug_objects_early_init(void)
 /*
  * Convert the statically allocated objects to dynamic ones:
  */
-static int debug_objects_replace_static_objects(void)
+static int __init debug_objects_replace_static_objects(void)
 {
        struct debug_bucket *db = obj_hash;
        struct hlist_node *node, *tmp;