mirror of
https://github.com/torvalds/linux.git
synced 2025-12-07 20:06:24 +00:00
Extend KVM's export macro framework to provide EXPORT_SYMBOL_FOR_KVM(), and use the helper macro to export symbols for KVM throughout x86 if and only if KVM will build one or more modules, and only for those modules. To avoid unnecessary exports when CONFIG_KVM=m but kvm.ko will not be built (because no vendor modules are selected), let arch code #define EXPORT_SYMBOL_FOR_KVM to suppress/override the exports. Note, the set of symbols to restrict to KVM was generated by manual search and audit; any "misses" are due to human error, not some grand plan. Signed-off-by: Sean Christopherson <seanjc@google.com> Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com> Acked-by: Kai Huang <kai.huang@intel.com> Tested-by: Kai Huang <kai.huang@intel.com> Link: https://patch.msgid.link/20251112173944.1380633-5-seanjc%40google.com
44 lines
922 B
C
44 lines
922 B
C
/*
|
|
* Common functions shared between the various APIC flavours
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0
|
|
*/
|
|
#include <linux/irq.h>
|
|
#include <linux/kvm_types.h>
|
|
#include <asm/apic.h>
|
|
|
|
#include "local.h"
|
|
|
|
u32 apic_default_calc_apicid(unsigned int cpu)
|
|
{
|
|
return per_cpu(x86_cpu_to_apicid, cpu);
|
|
}
|
|
|
|
u32 apic_flat_calc_apicid(unsigned int cpu)
|
|
{
|
|
return 1U << cpu;
|
|
}
|
|
|
|
u32 default_cpu_present_to_apicid(int mps_cpu)
|
|
{
|
|
if (mps_cpu < nr_cpu_ids && cpu_present(mps_cpu))
|
|
return (int)per_cpu(x86_cpu_to_apicid, mps_cpu);
|
|
else
|
|
return BAD_APICID;
|
|
}
|
|
EXPORT_SYMBOL_FOR_KVM(default_cpu_present_to_apicid);
|
|
|
|
/*
|
|
* Set up the logical destination ID when the APIC operates in logical
|
|
* destination mode.
|
|
*/
|
|
void default_init_apic_ldr(void)
|
|
{
|
|
unsigned long val;
|
|
|
|
apic_write(APIC_DFR, APIC_DFR_FLAT);
|
|
val = apic_read(APIC_LDR) & ~APIC_LDR_MASK;
|
|
val |= SET_APIC_LOGICAL_ID(1UL << smp_processor_id());
|
|
apic_write(APIC_LDR, val);
|
|
}
|