Oliver Upton <[email protected]> writes:

On Tue, Dec 09, 2025 at 08:51:17PM +0000, Colton Lewis wrote:
Because ARM hardware is not yet capable of direct interrupt injection

PPI injection, it can do LPIs just fine.

Clarification noted. I will update the message.

@@ -961,6 +964,12 @@ static irqreturn_t armv8pmu_handle_irq(struct arm_pmu *cpu_pmu)
                 */
                perf_event_overflow(event, &data, regs);
        }
+
+       govf = pmovsr & kvm_pmu_guest_counter_mask(cpu_pmu);
+
+       if (kvm_pmu_is_partitioned(cpu_pmu) && govf)
+               kvm_pmu_handle_guest_irq(govf);
+

The state ownership of this whole interaction is very odd. I would much
rather that KVM have full ownership of the range of counters while the
guest is loaded. By that I mean the PMUv3 driver only clears overflows
on PMCs that it owns and KVM will do the same on the back of the IRQ.

If I'm understanding correctly this is a code location concern, because
the host driver has to handle the interrupt in this function or a callee
of this function.

I will do it that way. It would be duplicating a small amount of logic
in kvm_pmu_handle_guest_irq() but I see your reasoning.

Similarly, KVM should be leaving the "guest" range of counters in a
non-overflow condition at vcpu_put().

Noted from your comments on kvm_pmu_put()


Thanks,
Oliver

Reply via email to