| /linux/arch/arm64/kvm/vgic/ |
| H A D | vgic-init.c | 54 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_vgic_early_init() 145 kvm->arch.vgic.in_kernel = true; in kvm_vgic_create() 146 kvm->arch.vgic.vgic_model = type; in kvm_vgic_create() 147 kvm->arch.vgic.implementation_rev = KVM_VGIC_IMP_REV_LATEST; in kvm_vgic_create() 148 kvm->arch.vgic.vgic_dist_base = VGIC_ADDR_UNDEF; in kvm_vgic_create() 152 kvm->arch.vgic.vgic_cpu_base = VGIC_ADDR_UNDEF; in kvm_vgic_create() 155 INIT_LIST_HEAD(&kvm->arch.vgic.rd_regions); in kvm_vgic_create() 178 kvm->arch.vgic.vgic_model = 0; in kvm_vgic_create() 183 kvm->arch.vgic.nassgicap = system_supports_direct_sgis(); in kvm_vgic_create() 209 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_vgic_dist_init() [all …]
|
| H A D | vgic-v3.c | 64 atomic_read(&vcpu->kvm->arch.vgic.active_spis)) in vgic_v3_configure_hcr() 81 if (vcpu->kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3) { in vgic_v3_fold_lr() 130 atomic_dec_if_positive(&vcpu->kvm->arch.vgic.active_spis); in vgic_v3_fold_lr() 199 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_deactivate() 219 val >= vcpu->kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS) in vgic_v3_deactivate() 300 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_compute_lr() 368 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_populate_lr() 407 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_set_vmcr() 435 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_get_vmcr() 483 if (vcpu->kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3) { in vgic_v3_reset() [all …]
|
| H A D | vgic-mmio-v3.c | 43 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_has_its() 71 return kvm->arch.vgic.nassgicap; in vgic_supports_direct_sgis() 84 struct vgic_dist *vgic = &vcpu->kvm->arch.vgic; in vgic_mmio_read_v3_misc() local 89 if (vgic->enabled) in vgic_mmio_read_v3_misc() 92 if (vgic->nassgireq) in vgic_mmio_read_v3_misc() 96 value = vgic->nr_spis + VGIC_NR_PRIVATE_IRQS; in vgic_mmio_read_v3_misc() 111 (vgic->implementation_rev << GICD_IIDR_REVISION_SHIFT) | in vgic_mmio_read_v3_misc() 125 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in vgic_mmio_write_v3_misc() 174 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in vgic_mmio_uaccess_write_v3_misc() 321 struct vgic_dist *vgic = &vcpu->kvm->arch.vgic; in vgic_mmio_vcpu_rdist_is_last() local [all …]
|
| H A D | vgic-mmio-v2.c | 28 struct vgic_dist *vgic = &vcpu->kvm->arch.vgic; in vgic_mmio_read_v2_misc() local 33 value = vgic->enabled ? GICD_ENABLE : 0; in vgic_mmio_read_v2_misc() 36 value = vgic->nr_spis + VGIC_NR_PRIVATE_IRQS; in vgic_mmio_read_v2_misc() 42 (vgic->implementation_rev << GICD_IIDR_REVISION_SHIFT) | in vgic_mmio_read_v2_misc() 56 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in vgic_mmio_write_v2_misc() 76 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in vgic_mmio_uaccess_write_v2_misc() 98 vcpu->kvm->arch.vgic.v2_groups_user_writable = true; in vgic_mmio_uaccess_write_v2_misc() 114 if (vcpu->kvm->arch.vgic.v2_groups_user_writable) in vgic_mmio_uaccess_write_v2_group()
|
| H A D | vgic.c | 68 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_get_lpi() 95 intid < (kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS)) { in vgic_get_irq() 96 intid = array_index_nospec(intid, kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS); in vgic_get_irq() 97 return &kvm->arch.vgic.spis[intid - VGIC_NR_PRIVATE_IRQS]; in vgic_get_irq() 159 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_put_irq() 181 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_release_deleted_lpis() 279 !irq->target_vcpu->kvm->arch.vgic.enabled)) in vgic_target_oracle() 404 kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3); in vgic_model_needs_bcst_kick() 500 atomic_fetch_inc(&vcpu->kvm->arch.vgic.active_spis) == 0); in vgic_queue_irq_unlock() 1171 const struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in kvm_vgic_load() [all …]
|
| H A D | vgic-v4.c | 192 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_v4_configure_vsgis() 244 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_v4_init() 320 struct its_vm *its_vm = &kvm->arch.vgic.its_vm; in vgic_v4_teardown() 389 err = its_make_vpe_resident(vpe, false, vcpu->kvm->arch.vgic.enabled); in vgic_v4_load() 476 .vm = &kvm->arch.vgic.its_vm, in kvm_vgic_v4_set_forwarding() 520 xa_for_each(&kvm->arch.vgic.lpi_xa, idx, irq) { in __vgic_host_irq_get_vlpi()
|
| H A D | vgic-debug.c | 35 struct vgic_dist *dist = &kvm->arch.vgic; in iter_next() 66 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_count_lpis() 87 iter->nr_spis = kvm->arch.vgic.nr_spis; in iter_init() 243 print_dist_state(s, &kvm->arch.vgic, iter); in vgic_debug_show() 247 if (!kvm->arch.vgic.initialized) in vgic_debug_show()
|
| H A D | trace.h | 33 #define TRACE_INCLUDE_PATH ../../arch/arm64/kvm/vgic
|
| H A D | vgic-its.c | 79 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_add_lpi() 283 u64 propbase = GICR_PROPBASER_ADDRESS(kvm->arch.vgic.propbaser); in update_lpi_config() 392 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in its_sync_lpi_pending_table() 1047 lpi_nr >= max_lpis_propbaser(kvm->arch.vgic.propbaser)) in vgic_its_cmd_handle_mapi() 1297 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_its_invall() 1352 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_its_cmd_handle_movall() 1881 dev->kvm->arch.vgic.msis_require_devid = true; in vgic_its_create() 1882 dev->kvm->arch.vgic.has_its = true; in vgic_its_create() 1890 dev->kvm->arch.vgic.propbaser = INITIAL_PROPBASER_VALUE; in vgic_its_create() 2718 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_arch_allow_write_without_running_vcpu()
|
| H A D | vgic-irqfd.c | 139 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_vgic_setup_default_irq_routing()
|
| H A D | vgic-v2.c | 422 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_v2_map_resources()
|
| /linux/Documentation/virt/kvm/devices/ |
| H A D | arm-vgic.rst | 18 device and guest ITS devices, see arm-vgic-v3.txt. It is not possible to 155 -ENOMEM memory shortage when allocating vgic internal data
|
| H A D | arm-vgic-v3.rst | 318 -ENOMEM memory shortage when allocating vgic internal data
|
| /linux/tools/testing/selftests/kvm/ |
| H A D | Makefile.kvm | 40 LIBKVM_arm64 += lib/arm64/vgic.c 185 TEST_GEN_PROGS_arm64 += arm64/no-vgic
|
| /linux/arch/arm64/kvm/ |
| H A D | arm.c | 422 r = kvm->arch.vgic.msis_require_devid; in kvm_vm_ioctl_check_extension() 634 vcpu->kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3 && in kvm_vcpu_should_clear_twi() 636 vcpu->kvm->arch.vgic.nassgireq); in kvm_vcpu_should_clear_twi() 1511 mask = kvm->arch.vgic.gicv5_vm.userspace_ppis; in kvm_vm_ioctl_irq_line()
|
| H A D | sys_regs.c | 725 unsigned long *mask = vcpu->kvm->arch.vgic.gicv5_vm.vgic_ppi_mask; in access_gicv5_ppi_enabler()
|
| /linux/arch/arm64/kvm/hyp/nvhe/ |
| H A D | pkvm.c | 349 hyp_vm->kvm.arch.vgic.vgic_model = host_kvm->arch.vgic.vgic_model; in pkvm_init_features_from_host()
|
| /linux/arch/arm64/include/asm/ |
| H A D | kvm_host.h | 330 struct vgic_dist vgic; member
|
| /linux/Documentation/virt/kvm/ |
| H A D | api.rst | 8742 NOTE: Multiple examples of using the backup bitmap: (1) save vgic/its 8744 KVM device "kvm-arm-vgic-its". (2) restore vgic/its tables through 8746 "kvm-arm-vgic-its". VGICv3 LPI pending status is restored. (3) save 8748 command on KVM device "kvm-arm-vgic-v3".
|
| /linux/ |
| H A D | MAINTAINERS | 2111 F: include/linux/irqchip/arm-vgic-info.h
|