Update to commit ceaa837f96ad ("Linux 6.2-rc8").
Signed-off-by: Avihai Horon <avihaih@nvidia.com>
Link: https://lore.kernel.org/r/20230216143630.25610-2-avihaih@nvidia.com
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
		
	
			
		
			
				
	
	
		
			158 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
 | 
						|
/*
 | 
						|
 * Copyright (C) 2019 Western Digital Corporation or its affiliates.
 | 
						|
 *
 | 
						|
 * Authors:
 | 
						|
 *     Anup Patel <anup.patel@wdc.com>
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef __LINUX_KVM_RISCV_H
 | 
						|
#define __LINUX_KVM_RISCV_H
 | 
						|
 | 
						|
#ifndef __ASSEMBLY__
 | 
						|
 | 
						|
#include <linux/types.h>
 | 
						|
#include <asm/ptrace.h>
 | 
						|
 | 
						|
#define __KVM_HAVE_READONLY_MEM
 | 
						|
 | 
						|
#define KVM_COALESCED_MMIO_PAGE_OFFSET 1
 | 
						|
 | 
						|
#define KVM_INTERRUPT_SET	-1U
 | 
						|
#define KVM_INTERRUPT_UNSET	-2U
 | 
						|
 | 
						|
/* for KVM_GET_REGS and KVM_SET_REGS */
 | 
						|
struct kvm_regs {
 | 
						|
};
 | 
						|
 | 
						|
/* for KVM_GET_FPU and KVM_SET_FPU */
 | 
						|
struct kvm_fpu {
 | 
						|
};
 | 
						|
 | 
						|
/* KVM Debug exit structure */
 | 
						|
struct kvm_debug_exit_arch {
 | 
						|
};
 | 
						|
 | 
						|
/* for KVM_SET_GUEST_DEBUG */
 | 
						|
struct kvm_guest_debug_arch {
 | 
						|
};
 | 
						|
 | 
						|
/* definition of registers in kvm_run */
 | 
						|
struct kvm_sync_regs {
 | 
						|
};
 | 
						|
 | 
						|
/* for KVM_GET_SREGS and KVM_SET_SREGS */
 | 
						|
struct kvm_sregs {
 | 
						|
};
 | 
						|
 | 
						|
/* CONFIG registers for KVM_GET_ONE_REG and KVM_SET_ONE_REG */
 | 
						|
struct kvm_riscv_config {
 | 
						|
	unsigned long isa;
 | 
						|
	unsigned long zicbom_block_size;
 | 
						|
	unsigned long mvendorid;
 | 
						|
	unsigned long marchid;
 | 
						|
	unsigned long mimpid;
 | 
						|
};
 | 
						|
 | 
						|
/* CORE registers for KVM_GET_ONE_REG and KVM_SET_ONE_REG */
 | 
						|
struct kvm_riscv_core {
 | 
						|
	struct user_regs_struct regs;
 | 
						|
	unsigned long mode;
 | 
						|
};
 | 
						|
 | 
						|
/* Possible privilege modes for kvm_riscv_core */
 | 
						|
#define KVM_RISCV_MODE_S	1
 | 
						|
#define KVM_RISCV_MODE_U	0
 | 
						|
 | 
						|
/* CSR registers for KVM_GET_ONE_REG and KVM_SET_ONE_REG */
 | 
						|
struct kvm_riscv_csr {
 | 
						|
	unsigned long sstatus;
 | 
						|
	unsigned long sie;
 | 
						|
	unsigned long stvec;
 | 
						|
	unsigned long sscratch;
 | 
						|
	unsigned long sepc;
 | 
						|
	unsigned long scause;
 | 
						|
	unsigned long stval;
 | 
						|
	unsigned long sip;
 | 
						|
	unsigned long satp;
 | 
						|
	unsigned long scounteren;
 | 
						|
};
 | 
						|
 | 
						|
/* TIMER registers for KVM_GET_ONE_REG and KVM_SET_ONE_REG */
 | 
						|
struct kvm_riscv_timer {
 | 
						|
	__u64 frequency;
 | 
						|
	__u64 time;
 | 
						|
	__u64 compare;
 | 
						|
	__u64 state;
 | 
						|
};
 | 
						|
 | 
						|
/*
 | 
						|
 * ISA extension IDs specific to KVM. This is not the same as the host ISA
 | 
						|
 * extension IDs as that is internal to the host and should not be exposed
 | 
						|
 * to the guest. This should always be contiguous to keep the mapping simple
 | 
						|
 * in KVM implementation.
 | 
						|
 */
 | 
						|
enum KVM_RISCV_ISA_EXT_ID {
 | 
						|
	KVM_RISCV_ISA_EXT_A = 0,
 | 
						|
	KVM_RISCV_ISA_EXT_C,
 | 
						|
	KVM_RISCV_ISA_EXT_D,
 | 
						|
	KVM_RISCV_ISA_EXT_F,
 | 
						|
	KVM_RISCV_ISA_EXT_H,
 | 
						|
	KVM_RISCV_ISA_EXT_I,
 | 
						|
	KVM_RISCV_ISA_EXT_M,
 | 
						|
	KVM_RISCV_ISA_EXT_SVPBMT,
 | 
						|
	KVM_RISCV_ISA_EXT_SSTC,
 | 
						|
	KVM_RISCV_ISA_EXT_SVINVAL,
 | 
						|
	KVM_RISCV_ISA_EXT_ZIHINTPAUSE,
 | 
						|
	KVM_RISCV_ISA_EXT_ZICBOM,
 | 
						|
	KVM_RISCV_ISA_EXT_MAX,
 | 
						|
};
 | 
						|
 | 
						|
/* Possible states for kvm_riscv_timer */
 | 
						|
#define KVM_RISCV_TIMER_STATE_OFF	0
 | 
						|
#define KVM_RISCV_TIMER_STATE_ON	1
 | 
						|
 | 
						|
#define KVM_REG_SIZE(id)		\
 | 
						|
	(1U << (((id) & KVM_REG_SIZE_MASK) >> KVM_REG_SIZE_SHIFT))
 | 
						|
 | 
						|
/* If you need to interpret the index values, here is the key: */
 | 
						|
#define KVM_REG_RISCV_TYPE_MASK		0x00000000FF000000
 | 
						|
#define KVM_REG_RISCV_TYPE_SHIFT	24
 | 
						|
 | 
						|
/* Config registers are mapped as type 1 */
 | 
						|
#define KVM_REG_RISCV_CONFIG		(0x01 << KVM_REG_RISCV_TYPE_SHIFT)
 | 
						|
#define KVM_REG_RISCV_CONFIG_REG(name)	\
 | 
						|
	(offsetof(struct kvm_riscv_config, name) / sizeof(unsigned long))
 | 
						|
 | 
						|
/* Core registers are mapped as type 2 */
 | 
						|
#define KVM_REG_RISCV_CORE		(0x02 << KVM_REG_RISCV_TYPE_SHIFT)
 | 
						|
#define KVM_REG_RISCV_CORE_REG(name)	\
 | 
						|
		(offsetof(struct kvm_riscv_core, name) / sizeof(unsigned long))
 | 
						|
 | 
						|
/* Control and status registers are mapped as type 3 */
 | 
						|
#define KVM_REG_RISCV_CSR		(0x03 << KVM_REG_RISCV_TYPE_SHIFT)
 | 
						|
#define KVM_REG_RISCV_CSR_REG(name)	\
 | 
						|
		(offsetof(struct kvm_riscv_csr, name) / sizeof(unsigned long))
 | 
						|
 | 
						|
/* Timer registers are mapped as type 4 */
 | 
						|
#define KVM_REG_RISCV_TIMER		(0x04 << KVM_REG_RISCV_TYPE_SHIFT)
 | 
						|
#define KVM_REG_RISCV_TIMER_REG(name)	\
 | 
						|
		(offsetof(struct kvm_riscv_timer, name) / sizeof(__u64))
 | 
						|
 | 
						|
/* F extension registers are mapped as type 5 */
 | 
						|
#define KVM_REG_RISCV_FP_F		(0x05 << KVM_REG_RISCV_TYPE_SHIFT)
 | 
						|
#define KVM_REG_RISCV_FP_F_REG(name)	\
 | 
						|
		(offsetof(struct __riscv_f_ext_state, name) / sizeof(__u32))
 | 
						|
 | 
						|
/* D extension registers are mapped as type 6 */
 | 
						|
#define KVM_REG_RISCV_FP_D		(0x06 << KVM_REG_RISCV_TYPE_SHIFT)
 | 
						|
#define KVM_REG_RISCV_FP_D_REG(name)	\
 | 
						|
		(offsetof(struct __riscv_d_ext_state, name) / sizeof(__u64))
 | 
						|
 | 
						|
/* ISA Extension registers are mapped as type 7 */
 | 
						|
#define KVM_REG_RISCV_ISA_EXT		(0x07 << KVM_REG_RISCV_TYPE_SHIFT)
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
#endif /* __LINUX_KVM_RISCV_H */
 |