x86: fix boot on uniprocessor systems

On x86 uniprocessor systems topology_physical_package_id() returns -1
which causes rapl_cpu_prepare() to leave rapl_pmu variable uninitialized
which leads to GPF in rapl_pmu_init().

See arch/x86/kernel/cpu/perf_event_intel_rapl.c.

It turns out that physical_package_id and core_id can actually be
retreived for uniprocessor systems too. Enabling them also fixes
rapl_pmu code.

Signed-off-by: Artem Fetishev <artem_fetishev@epam.com>
Cc: Stephane Eranian <eranian@google.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>

authored by Artem Fetishev and committed by Linus Torvalds 825600c0 d9060742

Changed files
+2 -1
arch
x86
include
+2 -1
arch/x86/include/asm/topology.h
··· 119 119 120 120 extern const struct cpumask *cpu_coregroup_mask(int cpu); 121 121 122 - #ifdef ENABLE_TOPO_DEFINES 123 122 #define topology_physical_package_id(cpu) (cpu_data(cpu).phys_proc_id) 124 123 #define topology_core_id(cpu) (cpu_data(cpu).cpu_core_id) 124 + 125 + #ifdef ENABLE_TOPO_DEFINES 125 126 #define topology_core_cpumask(cpu) (per_cpu(cpu_core_map, cpu)) 126 127 #define topology_thread_cpumask(cpu) (per_cpu(cpu_sibling_map, cpu)) 127 128 #endif