Home
last modified time | relevance | path

Searched full:gicv2 (Results 1 – 25 of 28) sorted by relevance

12

/linux/include/kvm/
H A Darm_vgic.h39 VGIC_V2, /* Good ol' GICv2 */
68 /* maximum number of VCPUs allowed (GICv2 limits us to 8) */
152 u8 targets; /* GICv2 target VCPUs mask */
155 u8 source; /* GICv2 SGIs only */
156 u8 active_source; /* GICv2 SGIs only */
242 /* vGIC model the kernel emulates for the guest (GICv2 or GICv3) */
247 #define KVM_VGIC_IMP_REV_2 2 /* GICv2 restorable groups */
251 /* Userspace can write to GICv2 IGROUPR */
265 /* either a GICv2 CPU interface */
/linux/Documentation/virt/kvm/devices/
H A Darm-vgic.rst17 guest GICv2 through this interface. For information on creating a guest GICv3
19 create both a GICv3 and GICv2 device on the same VM.
58 GICv2 specs. Getting or setting such a register has the same effect as
65 GICv2 is changed in a way directly observable by the guest or userspace.
92 defined in the GICv2 specs. Getting or setting such a register has the
96 fixed format for our implementation that fits with the model of a "GICv2
112 similar to GICv2's GICH_APR.
H A Darm-vgic-v3.rst14 possible to create both a GICv3 and GICv2 on the same VM.
/linux/arch/arm64/boot/dts/arm/
H A Dfoundation-v8-psci.dts4 * ARMv8 Foundation model DTS (GICv2+PSCI configuration)
8 #include "foundation-v8-gicv2.dtsi"
H A Dfoundation-v8.dts5 * ARMv8 Foundation model DTS (GICv2 configuration)
9 #include "foundation-v8-gicv2.dtsi"
H A Dfoundation-v8-gicv2.dtsi4 * ARMv8 Foundation model DTS (GICv2 configuration)
/linux/Documentation/devicetree/bindings/pci/
H A Dbrcm,stb-pcie.yaml206 interrupt-map = <0 0 0 1 &gicv2 GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH
207 0 0 0 2 &gicv2 GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH
208 0 0 0 3 &gicv2 GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH
209 0 0 0 4 &gicv2 GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>;
/linux/arch/arm64/kvm/vgic/
H A Dvgic-mmio-v2.c20 * Revision 1: Report GICv2 interrupts as group 0 instead of group 1
370 /* GICv2 hardware systems support max. 32 groups */ in vgic_mmio_read_apr()
382 /* GICv3 only uses ICH_AP1Rn for memory mapped (GICv2) guests */ in vgic_mmio_read_apr()
396 /* GICv2 hardware systems support max. 32 groups */ in vgic_mmio_write_apr()
408 /* GICv3 only uses ICH_AP1Rn for memory mapped (GICv2) guests */ in vgic_mmio_write_apr()
H A Dvgic-init.c33 * structures. Can be executed lazily for GICv2.
79 * which had no chance yet to check the availability of the GICv2 in kvm_vgic_create()
201 * initialization when using a virtual GICv2. in kvm_vgic_dist_init()
520 * is a GICv2. A GICv3 must be explicitly initialized by userspace using the
531 * for the legacy case of a GICv2. Any other type must in vgic_lazy_init()
H A Dvgic-v2.c194 /* The GICv2 LR only holds five bits of priority. */ in vgic_v2_populate_lr()
343 kvm_err("GICv2 not supported in protected mode\n"); in vgic_v2_probe()
382 kvm_err("Cannot register GICv2 KVM device\n"); in vgic_v2_probe()
H A Dvgic-mmio.c323 * GICv2 SGIs are terribly broken. We can't restore in __set_pending()
409 * More fun with GICv2 SGIs! If we're clearing one of them in __clear_pending()
466 * For GICv2 private interrupts we don't have to do anything because
570 * The GICv2 architecture indicates that the source CPUID for in vgic_mmio_change_active()
578 * for a GICv2 VM on some GIC implementations. Oh well. in vgic_mmio_change_active()
H A Dvgic-v3.c273 * If we are emulating a GICv3, we do it in an non-GICv2-compatible in vgic_v3_enable()
689 kvm_err("Cannot register GICv2 KVM device.\n"); in vgic_v3_probe()
702 kvm_info("disabling GICv2 emulation\n"); in vgic_v3_probe()
H A Dvgic.h170 * state to userspace can generate either GICv2 or GICv3 CPU interface
H A Dvgic.c818 /* GICv2 SGIs can count for more than one... */ in compute_ap_list_depth()
891 * GICv2 can always be accessed from the kernel because it is in can_access_vgic_from_kernel()
H A Dvgic-debug.c186 seq_printf(s, "vgic_model:\t%s\n", v3 ? "GICv3" : "GICv2"); in print_dist_state()
/linux/drivers/irqchip/
H A Dirq-gic.c897 .name = "GICv2",
1299 * first page of a GICv2. in gic_check_eoimode()
1305 pr_warn("GIC: GICv2 detected, but range too small and irqchip.gicv2_force_probe not set\n"); in gic_check_eoimode()
1314 * The first page was that of a GICv2, and in gic_check_eoimode()
1316 * to be a GICv2, and update the mapping. in gic_check_eoimode()
1318 pr_warn("GIC: GICv2 at %pa, but range is too small (broken DT?), assuming 8kB\n", in gic_check_eoimode()
1326 * We detected *two* initial GICv2 pages in a in gic_check_eoimode()
1327 * row. Could be a GICv2 aliased over two 64kB in gic_check_eoimode()
1335 pr_warn("GIC: Aliased GICv2 at %pa, trying to find the canonical range over 128kB\n", in gic_check_eoimode()
1343 * Verify that we have the first 4kB of a GICv2 in gic_check_eoimode()
[all …]
H A Dirq-gic-v3.c992 /* Extended SPI range, not handled by the GICv2/GICv3 common code */ in gic_dist_init()
/linux/arch/arm/boot/dts/broadcom/
H A Dbcm2711.dtsi13 interrupt-parent = <&gicv2>;
56 gicv2: interrupt-controller@40041000 { label
564 interrupt-map = <0 0 0 1 &gicv2 GIC_SPI 143
566 <0 0 0 2 &gicv2 GIC_SPI 144
568 <0 0 0 3 &gicv2 GIC_SPI 145
570 <0 0 0 4 &gicv2 GIC_SPI 146
/linux/tools/testing/selftests/kvm/arm64/
H A Dvgic_init.c137 * ARM_VGIC (GICv2 or GICv3) device gets created with an overlapping
138 * DIST/REDIST (or DIST/CPUIF for GICv2). Assumption is 4 vcpus are going to be
140 * and a DIST region is set @0x70000. The GICv2 case sets a CPUIF @0x0 and a
147 struct vgic_region_attr rdist; /* CPU interface in GICv2*/ in subtest_dist_rdist()
1017 print_skip("No GICv2 nor GICv3 support"); in main()
H A Dvgic_irq.c39 * more priority levels. Also note that 32 is the minimum for GICv3 and GICv2.
/linux/Documentation/devicetree/bindings/gpio/
H A Dapm,xgene-gpio-sb.yaml22 | (GICv2) +--------------+ +------ GPIO_[N+8]/EXT_INT_N
/linux/Documentation/translations/zh_CN/arch/arm64/
H A Dbooting.txt205 - 设备树(DT)或 ACPI 表必须描述一个 GICv2 中断控制器。
/linux/Documentation/translations/zh_TW/arch/arm64/
H A Dbooting.txt209 - 設備樹(DT)或 ACPI 表必須描述一個 GICv2 中斷控制器。
/linux/include/linux/irqchip/
H A Darm-gic-v3.h50 * Those registers are actually from GICv2, but the spec demands that they
580 /* These are for GICv2 emulation only */
/linux/Documentation/arch/arm64/
H A Dbooting.rst294 - The DT or ACPI tables must describe a GICv2 interrupt controller.

12