/linux-6.12.1/arch/arm64/kvm/ |
D | Makefile | 19 vgic-sys-reg-v3.o fpsimd.o pkvm.o \ 21 vgic/vgic.o vgic/vgic-init.o \ 22 vgic/vgic-irqfd.o vgic/vgic-v2.o \ 23 vgic/vgic-v3.o vgic/vgic-v4.o \ 24 vgic/vgic-mmio.o vgic/vgic-mmio-v2.o \ 25 vgic/vgic-mmio-v3.o vgic/vgic-kvm-device.o \ 26 vgic/vgic-its.o vgic/vgic-debug.o
|
D | arm.c | 370 r = kvm->arch.vgic.msis_require_devid; in kvm_vm_ioctl_check_extension() 565 vcpu->kvm->arch.vgic.nassgireq); in kvm_vcpu_should_clear_twi()
|
/linux-6.12.1/arch/arm64/kvm/vgic/ |
D | vgic-debug.c | 37 struct vgic_dist *dist = &kvm->arch.vgic; in iter_next() 66 struct vgic_dist *dist = &kvm->arch.vgic; in iter_mark_lpis() 84 struct vgic_dist *dist = &kvm->arch.vgic; in iter_unmark_lpis() 102 iter->nr_spis = kvm->arch.vgic.nr_spis; in iter_init() 103 if (kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3) in iter_init() 125 iter = kvm->arch.vgic.iter; in vgic_debug_start() 138 kvm->arch.vgic.iter = iter; in vgic_debug_start() 150 struct vgic_state_iter *iter = kvm->arch.vgic.iter; in vgic_debug_next() 172 iter = kvm->arch.vgic.iter; in vgic_debug_stop() 175 kvm->arch.vgic.iter = NULL; in vgic_debug_stop() [all …]
|
D | vgic-init.c | 54 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_vgic_early_init() 115 kvm->arch.vgic.in_kernel = true; in kvm_vgic_create() 116 kvm->arch.vgic.vgic_model = type; in kvm_vgic_create() 118 kvm->arch.vgic.vgic_dist_base = VGIC_ADDR_UNDEF; in kvm_vgic_create() 121 kvm->arch.vgic.vgic_cpu_base = VGIC_ADDR_UNDEF; in kvm_vgic_create() 123 INIT_LIST_HEAD(&kvm->arch.vgic.rd_regions); in kvm_vgic_create() 140 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_vgic_dist_init() 249 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in kvm_vgic_vcpu_init() 296 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_init() 381 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_vgic_dist_destroy() [all …]
|
D | vgic-kvm-device.c | 39 if (kvm->arch.vgic.vgic_model != type_needed) in vgic_check_type() 47 struct vgic_dist *vgic = &kvm->arch.vgic; in kvm_set_legacy_vgic_v2_addr() local 55 r = vgic_check_iorange(kvm, vgic->vgic_dist_base, dev_addr->addr, in kvm_set_legacy_vgic_v2_addr() 58 vgic->vgic_dist_base = dev_addr->addr; in kvm_set_legacy_vgic_v2_addr() 63 r = vgic_check_iorange(kvm, vgic->vgic_cpu_base, dev_addr->addr, in kvm_set_legacy_vgic_v2_addr() 66 vgic->vgic_cpu_base = dev_addr->addr; in kvm_set_legacy_vgic_v2_addr() 95 struct vgic_dist *vgic = &kvm->arch.vgic; in kvm_vgic_addr() local 114 addr_ptr = &vgic->vgic_dist_base; in kvm_vgic_addr() 120 addr_ptr = &vgic->vgic_cpu_base; in kvm_vgic_addr() 126 addr_ptr = &vgic->vgic_dist_base; in kvm_vgic_addr() [all …]
|
D | vgic-mmio-v3.c | 43 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_has_its() 67 struct vgic_dist *vgic = &vcpu->kvm->arch.vgic; in vgic_mmio_read_v3_misc() local 72 if (vgic->enabled) in vgic_mmio_read_v3_misc() 75 if (vgic->nassgireq) in vgic_mmio_read_v3_misc() 79 value = vgic->nr_spis + VGIC_NR_PRIVATE_IRQS; in vgic_mmio_read_v3_misc() 94 (vgic->implementation_rev << GICD_IIDR_REVISION_SHIFT) | in vgic_mmio_read_v3_misc() 108 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in vgic_mmio_write_v3_misc() 157 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in vgic_mmio_uaccess_write_v3_misc() 294 struct vgic_dist *vgic = &vcpu->kvm->arch.vgic; in vgic_mmio_vcpu_rdist_is_last() local 304 struct list_head *rd_regions = &vgic->rd_regions; in vgic_mmio_vcpu_rdist_is_last() [all …]
|
D | vgic-v3.c | 39 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_fold_lr_state() 109 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_populate_lr() 197 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_set_vmcr() 227 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_v3_get_vmcr() 277 if (vcpu->kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3) { in vgic_v3_enable() 368 struct vgic_dist *dist = &kvm->arch.vgic; in unmap_all_vpes() 377 struct vgic_dist *dist = &kvm->arch.vgic; in map_all_vpes() 391 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_v3_save_pending_tables() 475 struct vgic_dist *d = &kvm->arch.vgic; in vgic_v3_rdist_overlap() 492 struct vgic_dist *d = &kvm->arch.vgic; in vgic_v3_check_base() [all …]
|
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()
|
D | vgic-v4.c | 189 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_v4_configure_vsgis() 241 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_v4_init() 317 struct its_vm *its_vm = &kvm->arch.vgic.its_vm; in vgic_v4_teardown() 370 err = its_make_vpe_resident(vpe, false, vcpu->kvm->arch.vgic.enabled); in vgic_v4_load() 450 .vm = &kvm->arch.vgic.its_vm, in kvm_vgic_v4_set_forwarding()
|
D | vgic-mmio.c | 264 switch (vcpu->kvm->arch.vgic.vgic_model) { in __read_pending() 301 vcpu->kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V2); in is_vgic_v2_sgi() 473 if ((vcpu->kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3 && in vgic_access_active_prepare() 482 if ((vcpu->kvm->arch.vgic.vgic_model == KVM_DEV_TYPE_ARM_VGIC_V3 && in vgic_access_active_finish() 564 u32 model = vcpu->kvm->arch.vgic.vgic_model; in vgic_mmio_change_active() 770 int nr_irqs = vcpu->kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS; in vgic_read_irq_line_level_info() 792 int nr_irqs = vcpu->kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS; in vgic_write_irq_line_level_info() 922 int flags, nr_irqs = kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS; in check_region() 1083 struct vgic_io_device *io_device = &kvm->arch.vgic.dist_iodev; in vgic_register_dist_iodev()
|
D | vgic.c | 68 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_get_lpi() 97 if (intid < (kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS)) { in vgic_get_irq() 98 intid = array_index_nospec(intid, kvm->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS); in vgic_get_irq() 99 return &kvm->arch.vgic.spis[intid - VGIC_NR_PRIVATE_IRQS]; in vgic_get_irq() 120 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_put_irq() 216 !irq->target_vcpu->kvm->arch.vgic.enabled)) in vgic_target_oracle() 959 if (!vcpu->kvm->arch.vgic.enabled) in kvm_vgic_vcpu_pending_irq()
|
D | vgic.h | 105 return vcpu->kvm->arch.vgic.implementation_rev; in vgic_get_implementation_rev() 139 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_write_guest_lock() 325 struct vgic_dist *d = &kvm->arch.vgic; in vgic_dist_overlap()
|
D | trace.h | 33 #define TRACE_INCLUDE_PATH ../../arch/arm64/kvm/vgic
|
D | vgic-its.c | 44 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_add_lpi() 281 u64 propbase = GICR_PROPBASER_ADDRESS(kvm->arch.vgic.propbaser); in update_lpi_config() 395 struct vgic_dist *dist = &vcpu->kvm->arch.vgic; in its_sync_lpi_pending_table() 1031 lpi_nr >= max_lpis_propbaser(kvm->arch.vgic.propbaser)) in vgic_its_cmd_handle_mapi() 1280 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_its_invall() 1335 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_its_cmd_handle_movall() 1864 dev->kvm->arch.vgic.msis_require_devid = true; in vgic_its_create() 1865 dev->kvm->arch.vgic.has_its = true; in vgic_its_create() 1873 dev->kvm->arch.vgic.propbaser = INITIAL_PROPBASER_VALUE; in vgic_its_create() 2703 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_arch_allow_write_without_running_vcpu()
|
D | vgic-irqfd.c | 139 struct vgic_dist *dist = &kvm->arch.vgic; in kvm_vgic_setup_default_irq_routing()
|
D | vgic-v2.c | 291 struct vgic_dist *dist = &kvm->arch.vgic; in vgic_v2_map_resources()
|
/linux-6.12.1/arch/arm64/kvm/hyp/ |
D | vgic-v2-cpuif-proxy.c | 40 struct vgic_dist *vgic = &kvm->arch.vgic; in __vgic_v2_perform_cpuif_access() local 50 if (fault_ipa < vgic->vgic_cpu_base || in __vgic_v2_perform_cpuif_access() 51 fault_ipa >= (vgic->vgic_cpu_base + KVM_VGIC_V2_CPU_SIZE)) in __vgic_v2_perform_cpuif_access() 68 addr += fault_ipa - vgic->vgic_cpu_base; in __vgic_v2_perform_cpuif_access()
|
/linux-6.12.1/Documentation/virt/kvm/devices/ |
D | index.rst | 10 arm-vgic-its 11 arm-vgic 12 arm-vgic-v3
|
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
|
D | arm-vgic-its.rst | 12 arm-vgic-v3.txt), but does not depend on having physical ITS controllers.
|
/linux-6.12.1/arch/arm64/kvm/hyp/vhe/ |
D | Makefile | 12 obj-y += ../vgic-v3-sr.o ../aarch32.o ../vgic-v2-cpuif-proxy.o ../entry.o \
|
/linux-6.12.1/include/kvm/ |
D | arm_vgic.h | 393 #define irqchip_in_kernel(k) (!!((k)->arch.vgic.in_kernel)) 394 #define vgic_initialized(k) ((k)->arch.vgic.initialized) 395 #define vgic_ready(k) ((k)->arch.vgic.ready) 397 ((i) < (k)->arch.vgic.nr_spis + VGIC_NR_PRIVATE_IRQS))
|
/linux-6.12.1/arch/arm64/kvm/hyp/nvhe/ |
D | Makefile | 28 hyp-obj-y += ../vgic-v3-sr.o ../aarch32.o ../vgic-v2-cpuif-proxy.o ../entry.o \
|
/linux-6.12.1/tools/testing/selftests/kvm/ |
D | Makefile | 53 LIBKVM_aarch64 += lib/aarch64/vgic.c 168 TEST_GEN_PROGS_aarch64 += aarch64/no-vgic-v3
|
/linux-6.12.1/arch/arm64/include/asm/ |
D | kvm_emulate.h | 103 vcpu->kvm->arch.vgic.nassgireq) in vcpu_clear_wfx_traps()
|