linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [bug report] GICv4.1: multiple vpus execute vgic_v4_load at the same time will greatly increase the time consumption
@ 2024-08-21  9:51 Kunkun Jiang
  2024-08-21 10:59 ` Marc Zyngier
  0 siblings, 1 reply; 9+ messages in thread
From: Kunkun Jiang @ 2024-08-21  9:51 UTC (permalink / raw)
  To: Thomas Gleixner, Marc Zyngier, Oliver Upton, James Morse,
	Suzuki K Poulose, Zenghui Yu
  Cc: open list:IRQ SUBSYSTEM, moderated list:ARM SMMU DRIVERS, kvmarm,
	wanghaibin.wang@huawei.com, nizhiqiang1, tangnianyao@huawei.com,
	wangzhou1

Hi all,

Recently I discovered a problem about GICv4.1, the scenario is as follows:
1. Enable GICv4.1
2. Create multiple VMs.For example, 50 VMs(4U8G)
3. The business running in VMs has a frequent mmio access and need to exit
   to qemu for processing.
4. Or modify the kvm code so that wfi must trap to kvm
5. Then the utilization of pcpu where the vcpu is located will be 100%,and
   basically all in sys.
6. This problem does not exist in GICv3.

According to analysis, this problem is due to the execution of vgic_v4_load.
vcpu_load or kvm_sched_in
     kvm_arch_vcpu_load
     ...
         vgic_v4_load
             irq_set_affinity
             ...
                 irq_do_set_affinity
                     raw_spin_lock(&tmp_mask_lock)
                     chip->irq_set_affinity
                     ...
                       its_vpe_set_affinity

The tmp_mask_lock is the key. This is a global lock. I don't quite 
understand
why tmp_mask_lock is needed here. I think there are two possible 
solutions here:
1. Remove this tmp_mask_lock
2. Modify the gicv4 driver,do not perfrom VMOVP via irq_set_affinity.

Everyone is welcome to discuss.

Thanks,
Kunkun Jiang



^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2024-08-26  3:11 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-08-21  9:51 [bug report] GICv4.1: multiple vpus execute vgic_v4_load at the same time will greatly increase the time consumption Kunkun Jiang
2024-08-21 10:59 ` Marc Zyngier
2024-08-21 18:23   ` Kunkun Jiang
2024-08-22  8:26     ` Marc Zyngier
2024-08-22 10:59       ` Kunkun Jiang
2024-08-22 12:47         ` Marc Zyngier
2024-08-22 21:20           ` Thomas Gleixner
2024-08-23  8:49             ` Marc Zyngier
2024-08-26  3:10               ` Kunkun Jiang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).