9fedf14677
For a GICv2 there is always only one (v)CPU involved: the one that does the access. On a GICv3 the access to a CPU redistributor is memory-mapped, but not banked, so the (v)CPU affected is determined by looking at the MMIO address region being accessed. To allow passing the affected CPU into the accessors later, extend struct kvm_exit_mmio to add an opaque private pointer parameter. The current GICv2 emulation just does not use it. Signed-off-by: Andre Przywara <andre.przywara@arm.com> Acked-by: Christoffer Dall <christoffer.dall@linaro.org> Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
61 lines
1.7 KiB
C
61 lines
1.7 KiB
C
/*
|
|
* Copyright (C) 2012 - Virtual Open Systems and Columbia University
|
|
* Author: Christoffer Dall <c.dall@virtualopensystems.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License, version 2, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef __ARM64_KVM_MMIO_H__
|
|
#define __ARM64_KVM_MMIO_H__
|
|
|
|
#include <linux/kvm_host.h>
|
|
#include <asm/kvm_asm.h>
|
|
#include <asm/kvm_arm.h>
|
|
|
|
/*
|
|
* This is annoying. The mmio code requires this, even if we don't
|
|
* need any decoding. To be fixed.
|
|
*/
|
|
struct kvm_decode {
|
|
unsigned long rt;
|
|
bool sign_extend;
|
|
};
|
|
|
|
/*
|
|
* The in-kernel MMIO emulation code wants to use a copy of run->mmio,
|
|
* which is an anonymous type. Use our own type instead.
|
|
*/
|
|
struct kvm_exit_mmio {
|
|
phys_addr_t phys_addr;
|
|
u8 data[8];
|
|
u32 len;
|
|
bool is_write;
|
|
void *private;
|
|
};
|
|
|
|
static inline void kvm_prepare_mmio(struct kvm_run *run,
|
|
struct kvm_exit_mmio *mmio)
|
|
{
|
|
run->mmio.phys_addr = mmio->phys_addr;
|
|
run->mmio.len = mmio->len;
|
|
run->mmio.is_write = mmio->is_write;
|
|
memcpy(run->mmio.data, mmio->data, mmio->len);
|
|
run->exit_reason = KVM_EXIT_MMIO;
|
|
}
|
|
|
|
int kvm_handle_mmio_return(struct kvm_vcpu *vcpu, struct kvm_run *run);
|
|
int io_mem_abort(struct kvm_vcpu *vcpu, struct kvm_run *run,
|
|
phys_addr_t fault_ipa);
|
|
|
|
#endif /* __ARM64_KVM_MMIO_H__ */
|