mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
RISC-V: KVM: Add timer functionality
The RISC-V hypervisor specification doesn't have any virtual timer feature. Due to this, the guest VCPU timer will be programmed via SBI calls. The host will use a separate hrtimer event for each guest VCPU to provide timer functionality. We inject a virtual timer interrupt to the guest VCPU whenever the guest VCPU hrtimer event expires. This patch adds guest VCPU timer implementation along with ONE_REG interface to access VCPU timer state from user space. Signed-off-by: Atish Patra <atish.patra@wdc.com> Signed-off-by: Anup Patel <anup.patel@wdc.com> Acked-by: Paolo Bonzini <pbonzini@redhat.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> Acked-by: Daniel Lezcano <daniel.lezcano@linaro.org> Acked-by: Palmer Dabbelt <palmerdabbelt@google.com>
This commit is contained in:
parent
9955371cc0
commit
3a9f66cb25
9 changed files with 334 additions and 1 deletions
44
arch/riscv/include/asm/kvm_vcpu_timer.h
Normal file
44
arch/riscv/include/asm/kvm_vcpu_timer.h
Normal file
|
@ -0,0 +1,44 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
/*
|
||||
* Copyright (C) 2019 Western Digital Corporation or its affiliates.
|
||||
*
|
||||
* Authors:
|
||||
* Atish Patra <atish.patra@wdc.com>
|
||||
*/
|
||||
|
||||
#ifndef __KVM_VCPU_RISCV_TIMER_H
|
||||
#define __KVM_VCPU_RISCV_TIMER_H
|
||||
|
||||
#include <linux/hrtimer.h>
|
||||
|
||||
struct kvm_guest_timer {
|
||||
/* Mult & Shift values to get nanoseconds from cycles */
|
||||
u32 nsec_mult;
|
||||
u32 nsec_shift;
|
||||
/* Time delta value */
|
||||
u64 time_delta;
|
||||
};
|
||||
|
||||
struct kvm_vcpu_timer {
|
||||
/* Flag for whether init is done */
|
||||
bool init_done;
|
||||
/* Flag for whether timer event is configured */
|
||||
bool next_set;
|
||||
/* Next timer event cycles */
|
||||
u64 next_cycles;
|
||||
/* Underlying hrtimer instance */
|
||||
struct hrtimer hrt;
|
||||
};
|
||||
|
||||
int kvm_riscv_vcpu_timer_next_event(struct kvm_vcpu *vcpu, u64 ncycles);
|
||||
int kvm_riscv_vcpu_get_reg_timer(struct kvm_vcpu *vcpu,
|
||||
const struct kvm_one_reg *reg);
|
||||
int kvm_riscv_vcpu_set_reg_timer(struct kvm_vcpu *vcpu,
|
||||
const struct kvm_one_reg *reg);
|
||||
int kvm_riscv_vcpu_timer_init(struct kvm_vcpu *vcpu);
|
||||
int kvm_riscv_vcpu_timer_deinit(struct kvm_vcpu *vcpu);
|
||||
int kvm_riscv_vcpu_timer_reset(struct kvm_vcpu *vcpu);
|
||||
void kvm_riscv_vcpu_timer_restore(struct kvm_vcpu *vcpu);
|
||||
int kvm_riscv_guest_timer_init(struct kvm *kvm);
|
||||
|
||||
#endif
|
Loading…
Add table
Add a link
Reference in a new issue