2021-08-04 08:52:35 -07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Linux-specific definitions for managing interactions with Microsoft's
|
|
|
|
* Hyper-V hypervisor. The definitions in this file are specific to
|
|
|
|
* the ARM64 architecture. See include/asm-generic/mshyperv.h for
|
|
|
|
* definitions are that architecture independent.
|
|
|
|
*
|
2024-11-25 15:24:43 -08:00
|
|
|
* Definitions that are derived from Hyper-V code or headers should not go in
|
|
|
|
* this file, but should instead go in the relevant files in include/hyperv.
|
2021-08-04 08:52:35 -07:00
|
|
|
*
|
|
|
|
* Copyright (C) 2021, Microsoft, Inc.
|
|
|
|
*
|
|
|
|
* Author : Michael Kelley <mikelley@microsoft.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ASM_MSHYPERV_H
|
|
|
|
#define _ASM_MSHYPERV_H
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/arm-smccc.h>
|
2024-11-25 15:24:43 -08:00
|
|
|
#include <hyperv/hvhdk.h>
|
2021-08-04 08:52:35 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Declare calls to get and set Hyper-V VP register values on ARM64, which
|
|
|
|
* requires a hypercall.
|
|
|
|
*/
|
|
|
|
|
|
|
|
void hv_set_vpreg(u32 reg, u64 value);
|
|
|
|
u64 hv_get_vpreg(u32 reg);
|
|
|
|
void hv_get_vpreg_128(u32 reg, struct hv_get_vp_registers_output *result);
|
|
|
|
|
hyperv-tlfs: Change prefix of generic HV_REGISTER_* MSRs to HV_MSR_*
The HV_REGISTER_ are used as arguments to hv_set/get_register(), which
delegate to arch-specific mechanisms for getting/setting synthetic
Hyper-V MSRs.
On arm64, HV_REGISTER_ defines are synthetic VP registers accessed via
the get/set vp registers hypercalls. The naming matches the TLFS
document, although these register names are not specific to arm64.
However, on x86 the prefix HV_REGISTER_ indicates Hyper-V MSRs accessed
via rdmsrl()/wrmsrl(). This is not consistent with the TLFS doc, where
HV_REGISTER_ is *only* used for used for VP register names used by
the get/set register hypercalls.
To fix this inconsistency and prevent future confusion, change the
arch-generic aliases used by callers of hv_set/get_register() to have
the prefix HV_MSR_ instead of HV_REGISTER_.
Use the prefix HV_X64_MSR_ for the x86-only Hyper-V MSRs. On x86, the
generic HV_MSR_'s point to the corresponding HV_X64_MSR_.
Move the arm64 HV_REGISTER_* defines to the asm-generic hyperv-tlfs.h,
since these are not specific to arm64. On arm64, the generic HV_MSR_'s
point to the corresponding HV_REGISTER_.
While at it, rename hv_get/set_registers() and related functions to
hv_get/set_msr(), hv_get/set_nested_msr(), etc. These are only used for
Hyper-V MSRs and this naming makes that clear.
Signed-off-by: Nuno Das Neves <nunodasneves@linux.microsoft.com>
Reviewed-by: Wei Liu <wei.liu@kernel.org>
Reviewed-by: Michael Kelley <mhklinux@outlook.com>
Link: https://lore.kernel.org/r/1708440933-27125-1-git-send-email-nunodasneves@linux.microsoft.com
Signed-off-by: Wei Liu <wei.liu@kernel.org>
Message-ID: <1708440933-27125-1-git-send-email-nunodasneves@linux.microsoft.com>
2024-02-20 06:55:33 -08:00
|
|
|
static inline void hv_set_msr(unsigned int reg, u64 value)
|
2021-08-04 08:52:35 -07:00
|
|
|
{
|
|
|
|
hv_set_vpreg(reg, value);
|
|
|
|
}
|
|
|
|
|
hyperv-tlfs: Change prefix of generic HV_REGISTER_* MSRs to HV_MSR_*
The HV_REGISTER_ are used as arguments to hv_set/get_register(), which
delegate to arch-specific mechanisms for getting/setting synthetic
Hyper-V MSRs.
On arm64, HV_REGISTER_ defines are synthetic VP registers accessed via
the get/set vp registers hypercalls. The naming matches the TLFS
document, although these register names are not specific to arm64.
However, on x86 the prefix HV_REGISTER_ indicates Hyper-V MSRs accessed
via rdmsrl()/wrmsrl(). This is not consistent with the TLFS doc, where
HV_REGISTER_ is *only* used for used for VP register names used by
the get/set register hypercalls.
To fix this inconsistency and prevent future confusion, change the
arch-generic aliases used by callers of hv_set/get_register() to have
the prefix HV_MSR_ instead of HV_REGISTER_.
Use the prefix HV_X64_MSR_ for the x86-only Hyper-V MSRs. On x86, the
generic HV_MSR_'s point to the corresponding HV_X64_MSR_.
Move the arm64 HV_REGISTER_* defines to the asm-generic hyperv-tlfs.h,
since these are not specific to arm64. On arm64, the generic HV_MSR_'s
point to the corresponding HV_REGISTER_.
While at it, rename hv_get/set_registers() and related functions to
hv_get/set_msr(), hv_get/set_nested_msr(), etc. These are only used for
Hyper-V MSRs and this naming makes that clear.
Signed-off-by: Nuno Das Neves <nunodasneves@linux.microsoft.com>
Reviewed-by: Wei Liu <wei.liu@kernel.org>
Reviewed-by: Michael Kelley <mhklinux@outlook.com>
Link: https://lore.kernel.org/r/1708440933-27125-1-git-send-email-nunodasneves@linux.microsoft.com
Signed-off-by: Wei Liu <wei.liu@kernel.org>
Message-ID: <1708440933-27125-1-git-send-email-nunodasneves@linux.microsoft.com>
2024-02-20 06:55:33 -08:00
|
|
|
static inline u64 hv_get_msr(unsigned int reg)
|
2021-08-04 08:52:35 -07:00
|
|
|
{
|
|
|
|
return hv_get_vpreg(reg);
|
|
|
|
}
|
|
|
|
|
2025-03-14 12:28:49 -07:00
|
|
|
/*
|
|
|
|
* Nested is not supported on arm64
|
|
|
|
*/
|
|
|
|
static inline void hv_set_non_nested_msr(unsigned int reg, u64 value)
|
|
|
|
{
|
|
|
|
hv_set_msr(reg, value);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline u64 hv_get_non_nested_msr(unsigned int reg)
|
|
|
|
{
|
|
|
|
return hv_get_msr(reg);
|
|
|
|
}
|
|
|
|
|
2021-08-04 08:52:35 -07:00
|
|
|
/* SMCCC hypercall parameters */
|
|
|
|
#define HV_SMCCC_FUNC_NUMBER 1
|
|
|
|
#define HV_FUNC_ID ARM_SMCCC_CALL_VAL( \
|
|
|
|
ARM_SMCCC_STD_CALL, \
|
|
|
|
ARM_SMCCC_SMC_64, \
|
|
|
|
ARM_SMCCC_OWNER_VENDOR_HYP, \
|
|
|
|
HV_SMCCC_FUNC_NUMBER)
|
|
|
|
|
|
|
|
#include <asm-generic/mshyperv.h>
|
|
|
|
|
|
|
|
#endif
|