init/main.c: Execute lockdep_init() as early as possible
authorMing Lei <tom.leiming@gmail.com>
Thu, 17 Nov 2011 05:34:31 +0000 (13:34 +0800)
committerIngo Molnar <mingo@elte.hu>
Tue, 6 Dec 2011 07:16:53 +0000 (08:16 +0100)
commit73839c5b2eacc15cb0aa79c69b285fc659fa8851
tree460e38f3b8036b33a3bed5e4322ea1bb5ef4e3c8
parentd3d03d4fc5b1bec3a579112de170a9676e9d97cb
init/main.c: Execute lockdep_init() as early as possible

This patch fixes a lockdep warning on ARM platforms:

  [    0.000000] WARNING: lockdep init error! Arch code didn't call lockdep_init() early enough?
  [    0.000000] Call stack leading to lockdep invocation was:
  [    0.000000]  [<c00164bc>] save_stack_trace_tsk+0x0/0x90
  [    0.000000]  [<ffffffff>] 0xffffffff

The warning is caused by printk inside smp_setup_processor_id().

It is safe to do this because lockdep_init() doesn't depend on
smp_setup_processor_id(), so improve things that printk can be
called as early as possible without lockdep complaint.

Signed-off-by: Ming Lei <tom.leiming@gmail.com>
Reviewed-by: Yong Zhang <yong.zhang0@gmail.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Link: http://lkml.kernel.org/r/1321508072-23853-1-git-send-email-tom.leiming@gmail.com
Signed-off-by: Ingo Molnar <mingo@elte.hu>
init/main.c