mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-09 15:29:16 +00:00
KVM: x86: SVM: move tsc ratio definitions to svm.h
Another piece of SVM spec which should be in the header file Signed-off-by: Maxim Levitsky <mlevitsk@redhat.com> Message-Id: <20220322172449.235575-6-mlevitsk@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
0dacc3df89
commit
bb2aa78e9a
@ -221,6 +221,12 @@ struct __attribute__ ((__packed__)) vmcb_control_area {
|
|||||||
#define SVM_NESTED_CTL_SEV_ES_ENABLE BIT(2)
|
#define SVM_NESTED_CTL_SEV_ES_ENABLE BIT(2)
|
||||||
|
|
||||||
|
|
||||||
|
#define SVM_TSC_RATIO_RSVD 0xffffff0000000000ULL
|
||||||
|
#define SVM_TSC_RATIO_MIN 0x0000000000000001ULL
|
||||||
|
#define SVM_TSC_RATIO_MAX 0x000000ffffffffffULL
|
||||||
|
#define SVM_TSC_RATIO_DEFAULT 0x0100000000ULL
|
||||||
|
|
||||||
|
|
||||||
/* AVIC */
|
/* AVIC */
|
||||||
#define AVIC_LOGICAL_ID_ENTRY_GUEST_PHYSICAL_ID_MASK (0xFFULL)
|
#define AVIC_LOGICAL_ID_ENTRY_GUEST_PHYSICAL_ID_MASK (0xFFULL)
|
||||||
#define AVIC_LOGICAL_ID_ENTRY_VALID_BIT 31
|
#define AVIC_LOGICAL_ID_ENTRY_VALID_BIT 31
|
||||||
|
@ -72,10 +72,6 @@ MODULE_DEVICE_TABLE(x86cpu, svm_cpu_id);
|
|||||||
|
|
||||||
#define DEBUGCTL_RESERVED_BITS (~(0x3fULL))
|
#define DEBUGCTL_RESERVED_BITS (~(0x3fULL))
|
||||||
|
|
||||||
#define TSC_RATIO_RSVD 0xffffff0000000000ULL
|
|
||||||
#define TSC_RATIO_MIN 0x0000000000000001ULL
|
|
||||||
#define TSC_RATIO_MAX 0x000000ffffffffffULL
|
|
||||||
|
|
||||||
static bool erratum_383_found __read_mostly;
|
static bool erratum_383_found __read_mostly;
|
||||||
|
|
||||||
u32 msrpm_offsets[MSRPM_OFFSETS] __read_mostly;
|
u32 msrpm_offsets[MSRPM_OFFSETS] __read_mostly;
|
||||||
@ -87,7 +83,6 @@ u32 msrpm_offsets[MSRPM_OFFSETS] __read_mostly;
|
|||||||
static uint64_t osvw_len = 4, osvw_status;
|
static uint64_t osvw_len = 4, osvw_status;
|
||||||
|
|
||||||
static DEFINE_PER_CPU(u64, current_tsc_ratio);
|
static DEFINE_PER_CPU(u64, current_tsc_ratio);
|
||||||
#define TSC_RATIO_DEFAULT 0x0100000000ULL
|
|
||||||
|
|
||||||
static const struct svm_direct_access_msrs {
|
static const struct svm_direct_access_msrs {
|
||||||
u32 index; /* Index of the MSR */
|
u32 index; /* Index of the MSR */
|
||||||
@ -480,7 +475,7 @@ static void svm_hardware_disable(void)
|
|||||||
{
|
{
|
||||||
/* Make sure we clean up behind us */
|
/* Make sure we clean up behind us */
|
||||||
if (tsc_scaling)
|
if (tsc_scaling)
|
||||||
wrmsrl(MSR_AMD64_TSC_RATIO, TSC_RATIO_DEFAULT);
|
wrmsrl(MSR_AMD64_TSC_RATIO, SVM_TSC_RATIO_DEFAULT);
|
||||||
|
|
||||||
cpu_svm_disable();
|
cpu_svm_disable();
|
||||||
|
|
||||||
@ -526,8 +521,8 @@ static int svm_hardware_enable(void)
|
|||||||
* Set the default value, even if we don't use TSC scaling
|
* Set the default value, even if we don't use TSC scaling
|
||||||
* to avoid having stale value in the msr
|
* to avoid having stale value in the msr
|
||||||
*/
|
*/
|
||||||
wrmsrl(MSR_AMD64_TSC_RATIO, TSC_RATIO_DEFAULT);
|
wrmsrl(MSR_AMD64_TSC_RATIO, SVM_TSC_RATIO_DEFAULT);
|
||||||
__this_cpu_write(current_tsc_ratio, TSC_RATIO_DEFAULT);
|
__this_cpu_write(current_tsc_ratio, SVM_TSC_RATIO_DEFAULT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2723,7 +2718,7 @@ static int svm_set_msr(struct kvm_vcpu *vcpu, struct msr_data *msr)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (data & TSC_RATIO_RSVD)
|
if (data & SVM_TSC_RATIO_RSVD)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
svm->tsc_ratio_msr = data;
|
svm->tsc_ratio_msr = data;
|
||||||
@ -4765,7 +4760,7 @@ static __init int svm_hardware_setup(void)
|
|||||||
} else {
|
} else {
|
||||||
pr_info("TSC scaling supported\n");
|
pr_info("TSC scaling supported\n");
|
||||||
kvm_has_tsc_control = true;
|
kvm_has_tsc_control = true;
|
||||||
kvm_max_tsc_scaling_ratio = TSC_RATIO_MAX;
|
kvm_max_tsc_scaling_ratio = SVM_TSC_RATIO_MAX;
|
||||||
kvm_tsc_scaling_ratio_frac_bits = 32;
|
kvm_tsc_scaling_ratio_frac_bits = 32;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user