ed105f0f54
topology - fate#311376: EFI support in SP2 - fate#311529: Native UEFI booting under Xen (installation) 23074-pfn.h.patch 23571-vtd-fault-verbosity.patch 23574-x86-dom0-compressed-ELF.patch 23575-x86-DMI.patch 23610-x86-topology-info.patch 23611-amd-fam15-topology.patch 23613-EFI-headers.patch 23614-x86_64-EFI-boot.patch 23615-x86_64-EFI-runtime.patch 23616-x86_64-EFI-MPS.patch - Mark xen-scsi.ko supported (bnc#582265, fate#309459). - fate#310308: Hypervisor assisted watchdog driver ioemu-watchdog-support.patch ioemu-watchdog-linkage.patch ioemu-watchdog-ib700-timer.patch tools-watchdog-support.patch - bnc#702025 - VUL-0: xen: VT-d (PCI passthrough) MSI trap injection (CVE-2011-1898) Fixed in Xen version 4.1.1 - fate#310956: Support Direct Kernel Boot for FV guests kernel-boot-hvm.patch OBS-URL: https://build.opensuse.org/package/show/Virtualization/xen?expand=0&rev=130
213 lines
7.1 KiB
Diff
213 lines
7.1 KiB
Diff
References: fate#309894
|
|
|
|
# HG changeset patch
|
|
# User Wei Huang <wei.huang2@amd.com>
|
|
# Date 1309248811 -3600
|
|
# Node ID 87c2013c2aa2d4874f892507e6cc7b52219a3acf
|
|
# Parent 819c315a919daec434f80ffb6e790ac492cbd2a7
|
|
x86: consolidate cpu_core_id and phys_proc_id into cpuinfo_x86 struct
|
|
|
|
This patch moves cpu_core_id and phys_proc_id into cpuinfo_x86
|
|
structure. This is similar to upstream Linux kernel's approach.
|
|
|
|
Signed-off-by: Wei Huang <wei.huang2@amd.com>
|
|
|
|
--- a/xen/arch/x86/cpu/amd.c
|
|
+++ b/xen/arch/x86/cpu/amd.c
|
|
@@ -579,11 +579,11 @@ static void __devinit init_amd(struct cp
|
|
while ((1 << bits) < c->x86_max_cores)
|
|
bits++;
|
|
}
|
|
- cpu_core_id[cpu] = phys_proc_id[cpu] & ((1<<bits)-1);
|
|
- phys_proc_id[cpu] >>= bits;
|
|
+ c->cpu_core_id = c->phys_proc_id & ((1<<bits)-1);
|
|
+ c->phys_proc_id >>= bits;
|
|
if (opt_cpu_info)
|
|
printk("CPU %d(%d) -> Core %d\n",
|
|
- cpu, c->x86_max_cores, cpu_core_id[cpu]);
|
|
+ cpu, c->x86_max_cores, c->cpu_core_id);
|
|
}
|
|
#endif
|
|
|
|
--- a/xen/arch/x86/cpu/common.c
|
|
+++ b/xen/arch/x86/cpu/common.c
|
|
@@ -326,7 +326,7 @@ void __cpuinit generic_identify(struct c
|
|
early_intel_workaround(c);
|
|
|
|
#ifdef CONFIG_X86_HT
|
|
- phys_proc_id[smp_processor_id()] = (cpuid_ebx(1) >> 24) & 0xff;
|
|
+ c->phys_proc_id = (cpuid_ebx(1) >> 24) & 0xff;
|
|
#endif
|
|
}
|
|
|
|
@@ -362,6 +362,8 @@ void __cpuinit identify_cpu(struct cpuin
|
|
c->x86_max_cores = 1;
|
|
c->x86_num_siblings = 1;
|
|
c->x86_clflush_size = 0;
|
|
+ c->phys_proc_id = BAD_APICID;
|
|
+ c->cpu_core_id = BAD_APICID;
|
|
memset(&c->x86_capability, 0, sizeof c->x86_capability);
|
|
|
|
if (!have_cpuid_p()) {
|
|
@@ -510,7 +512,6 @@ void __cpuinit detect_extended_topology(
|
|
unsigned int ht_mask_width, core_plus_mask_width;
|
|
unsigned int core_select_mask, core_level_siblings;
|
|
unsigned int initial_apicid;
|
|
- int cpu = smp_processor_id();
|
|
|
|
if ( c->cpuid_level < 0xb )
|
|
return;
|
|
@@ -545,9 +546,9 @@ void __cpuinit detect_extended_topology(
|
|
|
|
core_select_mask = (~(-1 << core_plus_mask_width)) >> ht_mask_width;
|
|
|
|
- cpu_core_id[cpu] = phys_pkg_id(initial_apicid, ht_mask_width)
|
|
+ c->cpu_core_id = phys_pkg_id(initial_apicid, ht_mask_width)
|
|
& core_select_mask;
|
|
- phys_proc_id[cpu] = phys_pkg_id(initial_apicid, core_plus_mask_width);
|
|
+ c->phys_proc_id = phys_pkg_id(initial_apicid, core_plus_mask_width);
|
|
|
|
c->apicid = phys_pkg_id(initial_apicid, 0);
|
|
c->x86_max_cores = (core_level_siblings / c->x86_num_siblings);
|
|
@@ -555,10 +556,10 @@ void __cpuinit detect_extended_topology(
|
|
if ( opt_cpu_info )
|
|
{
|
|
printk("CPU: Physical Processor ID: %d\n",
|
|
- phys_proc_id[cpu]);
|
|
+ c->phys_proc_id);
|
|
if ( c->x86_max_cores > 1 )
|
|
printk("CPU: Processor Core ID: %d\n",
|
|
- cpu_core_id[cpu]);
|
|
+ c->cpu_core_id);
|
|
}
|
|
}
|
|
|
|
@@ -567,7 +568,6 @@ void __cpuinit detect_ht(struct cpuinfo_
|
|
{
|
|
u32 eax, ebx, ecx, edx;
|
|
int index_msb, core_bits;
|
|
- int cpu = smp_processor_id();
|
|
|
|
cpuid(1, &eax, &ebx, &ecx, &edx);
|
|
|
|
@@ -590,11 +590,11 @@ void __cpuinit detect_ht(struct cpuinfo_
|
|
}
|
|
|
|
index_msb = get_count_order(c->x86_num_siblings);
|
|
- phys_proc_id[cpu] = phys_pkg_id((ebx >> 24) & 0xFF, index_msb);
|
|
+ c->phys_proc_id = phys_pkg_id((ebx >> 24) & 0xFF, index_msb);
|
|
|
|
if (opt_cpu_info)
|
|
printk("CPU: Physical Processor ID: %d\n",
|
|
- phys_proc_id[cpu]);
|
|
+ c->phys_proc_id);
|
|
|
|
c->x86_num_siblings = c->x86_num_siblings / c->x86_max_cores;
|
|
|
|
@@ -602,12 +602,12 @@ void __cpuinit detect_ht(struct cpuinfo_
|
|
|
|
core_bits = get_count_order(c->x86_max_cores);
|
|
|
|
- cpu_core_id[cpu] = phys_pkg_id((ebx >> 24) & 0xFF, index_msb) &
|
|
+ c->cpu_core_id = phys_pkg_id((ebx >> 24) & 0xFF, index_msb) &
|
|
((1 << core_bits) - 1);
|
|
|
|
if (opt_cpu_info && c->x86_max_cores > 1)
|
|
printk("CPU: Processor Core ID: %d\n",
|
|
- cpu_core_id[cpu]);
|
|
+ c->cpu_core_id);
|
|
}
|
|
}
|
|
#endif
|
|
--- a/xen/arch/x86/cpu/mcheck/mce.c
|
|
+++ b/xen/arch/x86/cpu/mcheck/mce.c
|
|
@@ -1041,9 +1041,9 @@ void x86_mc_get_cpu_info(unsigned cpu, u
|
|
if (nthreads != NULL)
|
|
*nthreads = 1;
|
|
} else {
|
|
- *chipid = phys_proc_id[cpu];
|
|
+ *chipid = c->phys_proc_id;
|
|
if (c->x86_max_cores > 1)
|
|
- *coreid = cpu_core_id[cpu];
|
|
+ *coreid = c->cpu_core_id;
|
|
else
|
|
*coreid = 0;
|
|
*threadid = c->apicid & ((1 << (c->x86_num_siblings - 1)) - 1);
|
|
--- a/xen/arch/x86/smpboot.c
|
|
+++ b/xen/arch/x86/smpboot.c
|
|
@@ -52,12 +52,6 @@
|
|
/* Set if we find a B stepping CPU */
|
|
static int smp_b_stepping;
|
|
|
|
-/* Package ID of each logical CPU */
|
|
-int phys_proc_id[NR_CPUS] __read_mostly = {[0 ... NR_CPUS-1] = BAD_APICID};
|
|
-
|
|
-/* Core ID of each logical CPU */
|
|
-int cpu_core_id[NR_CPUS] __read_mostly = {[0 ... NR_CPUS-1] = BAD_APICID};
|
|
-
|
|
/* representing HT siblings of each logical CPU */
|
|
DEFINE_PER_CPU_READ_MOSTLY(cpumask_t, cpu_sibling_map);
|
|
/* representing HT and core siblings of each logical CPU */
|
|
@@ -258,8 +252,8 @@ static void set_cpu_sibling_map(int cpu)
|
|
{
|
|
for_each_cpu_mask ( i, cpu_sibling_setup_map )
|
|
{
|
|
- if ( (phys_proc_id[cpu] == phys_proc_id[i]) &&
|
|
- (cpu_core_id[cpu] == cpu_core_id[i]) )
|
|
+ if ( (c[cpu].phys_proc_id == c[i].phys_proc_id) &&
|
|
+ (c[cpu].cpu_core_id == c[i].cpu_core_id) )
|
|
{
|
|
cpu_set(i, per_cpu(cpu_sibling_map, cpu));
|
|
cpu_set(cpu, per_cpu(cpu_sibling_map, i));
|
|
@@ -282,7 +276,7 @@ static void set_cpu_sibling_map(int cpu)
|
|
|
|
for_each_cpu_mask ( i, cpu_sibling_setup_map )
|
|
{
|
|
- if ( phys_proc_id[cpu] == phys_proc_id[i] )
|
|
+ if ( c[cpu].phys_proc_id == c[i].phys_proc_id )
|
|
{
|
|
cpu_set(i, per_cpu(cpu_core_map, cpu));
|
|
cpu_set(cpu, per_cpu(cpu_core_map, i));
|
|
@@ -843,8 +837,8 @@ remove_siblinginfo(int cpu)
|
|
cpu_clear(cpu, per_cpu(cpu_sibling_map, sibling));
|
|
cpus_clear(per_cpu(cpu_sibling_map, cpu));
|
|
cpus_clear(per_cpu(cpu_core_map, cpu));
|
|
- phys_proc_id[cpu] = BAD_APICID;
|
|
- cpu_core_id[cpu] = BAD_APICID;
|
|
+ c[cpu].phys_proc_id = BAD_APICID;
|
|
+ c[cpu].cpu_core_id = BAD_APICID;
|
|
cpu_clear(cpu, cpu_sibling_setup_map);
|
|
}
|
|
|
|
--- a/xen/include/asm-x86/processor.h
|
|
+++ b/xen/include/asm-x86/processor.h
|
|
@@ -175,6 +175,8 @@ struct cpuinfo_x86 {
|
|
__u32 x86_max_cores; /* cpuid returned max cores value */
|
|
__u32 booted_cores; /* number of cores as seen by OS */
|
|
__u32 x86_num_siblings; /* cpuid logical cpus per chip value */
|
|
+ int phys_proc_id; /* package ID of each logical CPU */
|
|
+ int cpu_core_id; /* core ID of each logical CPU*/
|
|
__u32 apicid;
|
|
unsigned short x86_clflush_size;
|
|
} __cacheline_aligned;
|
|
@@ -194,8 +196,6 @@ extern struct cpuinfo_x86 cpu_data[];
|
|
#endif
|
|
|
|
extern u64 host_pat;
|
|
-extern int phys_proc_id[NR_CPUS];
|
|
-extern int cpu_core_id[NR_CPUS];
|
|
extern bool_t opt_cpu_info;
|
|
|
|
/* Maximum width of physical addresses supported by the hardware */
|
|
@@ -215,8 +215,8 @@ extern void detect_ht(struct cpuinfo_x86
|
|
static always_inline void detect_ht(struct cpuinfo_x86 *c) {}
|
|
#endif
|
|
|
|
-#define cpu_to_core(_cpu) (cpu_core_id[_cpu])
|
|
-#define cpu_to_socket(_cpu) (phys_proc_id[_cpu])
|
|
+#define cpu_to_core(_cpu) (cpu_data[_cpu].cpu_core_id)
|
|
+#define cpu_to_socket(_cpu) (cpu_data[_cpu].phys_proc_id)
|
|
|
|
/*
|
|
* Generic CPUID function
|