diff options
Diffstat (limited to 'arch/x86/kernel/cpu/common.c')
| -rw-r--r-- | arch/x86/kernel/cpu/common.c | 40 | 
1 files changed, 21 insertions, 19 deletions
| diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c index 4868e4a951ee..68e4a6f2211e 100644 --- a/arch/x86/kernel/cpu/common.c +++ b/arch/x86/kernel/cpu/common.c @@ -1084,6 +1084,20 @@ static void clear_all_debug_regs(void)  	}  } +#ifdef CONFIG_KGDB +/* + * Restore debug regs if using kgdbwait and you have a kernel debugger + * connection established. + */ +static void dbg_restore_debug_regs(void) +{ +	if (unlikely(kgdb_connected && arch_kgdb_ops.correct_hw_break)) +		arch_kgdb_ops.correct_hw_break(); +} +#else /* ! CONFIG_KGDB */ +#define dbg_restore_debug_regs() +#endif /* ! CONFIG_KGDB */ +  /*   * cpu_init() initializes state that is per-CPU. Some data is already   * initialized (naturally) in the bootstrap process, such as the GDT @@ -1107,9 +1121,9 @@ void __cpuinit cpu_init(void)  	oist = &per_cpu(orig_ist, cpu);  #ifdef CONFIG_NUMA -	if (cpu != 0 && percpu_read(node_number) == 0 && -	    cpu_to_node(cpu) != NUMA_NO_NODE) -		percpu_write(node_number, cpu_to_node(cpu)); +	if (cpu != 0 && percpu_read(numa_node) == 0 && +	    early_cpu_to_node(cpu) != NUMA_NO_NODE) +		set_numa_node(early_cpu_to_node(cpu));  #endif  	me = current; @@ -1174,18 +1188,8 @@ void __cpuinit cpu_init(void)  	load_TR_desc();  	load_LDT(&init_mm.context); -#ifdef CONFIG_KGDB -	/* -	 * If the kgdb is connected no debug regs should be altered.  This -	 * is only applicable when KGDB and a KGDB I/O module are built -	 * into the kernel and you are using early debugging with -	 * kgdbwait. KGDB will control the kernel HW breakpoint registers. -	 */ -	if (kgdb_connected && arch_kgdb_ops.correct_hw_break) -		arch_kgdb_ops.correct_hw_break(); -	else -#endif -		clear_all_debug_regs(); +	clear_all_debug_regs(); +	dbg_restore_debug_regs();  	fpu_init(); @@ -1239,14 +1243,12 @@ void __cpuinit cpu_init(void)  #endif  	clear_all_debug_regs(); +	dbg_restore_debug_regs();  	/*  	 * Force FPU initialization:  	 */ -	if (cpu_has_xsave) -		current_thread_info()->status = TS_XSAVE; -	else -		current_thread_info()->status = 0; +	current_thread_info()->status = 0;  	clear_used_math();  	mxcsr_feature_mask_init(); | 
