mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	irqchip/gic-v3-its: Flag device allocation as proxied if behind a PCI bridge
An aliasing PCI bridge is another case where we should flag the corresponding allocation as "proxied", as MSIs are coming with the bridge's RID, and not the originating device's. Signed-off-by: Marc Zyngier <maz@kernel.org> Tested-by: John Garry <john.garry@huawei.com> Link: https://lore.kernel.org/r/20201129135208.680293-4-maz@kernel.org
This commit is contained in:
		
							parent
							
								
									5fe71d271d
								
							
						
					
					
						commit
						34dd263fce
					
				
					 1 changed files with 8 additions and 3 deletions
				
			
		|  | @ -67,11 +67,16 @@ static int its_pci_msi_prepare(struct irq_domain *domain, struct device *dev, | |||
| 	/*
 | ||||
| 	 * If pdev is downstream of any aliasing bridges, take an upper | ||||
| 	 * bound of how many other vectors could map to the same DevID. | ||||
| 	 * Also tell the ITS that the signalling will come from a proxy | ||||
| 	 * device, and that special allocation rules apply. | ||||
| 	 */ | ||||
| 	pci_for_each_dma_alias(pdev, its_get_pci_alias, &alias_dev); | ||||
| 	if (alias_dev != pdev && alias_dev->subordinate) | ||||
| 		pci_walk_bus(alias_dev->subordinate, its_pci_msi_vec_count, | ||||
| 			     &alias_count); | ||||
| 	if (alias_dev != pdev) { | ||||
| 		if (alias_dev->subordinate) | ||||
| 			pci_walk_bus(alias_dev->subordinate, | ||||
| 				     its_pci_msi_vec_count, &alias_count); | ||||
| 		info->flags |= MSI_ALLOC_FLAGS_PROXY_DEVICE; | ||||
| 	} | ||||
| 
 | ||||
| 	/* ITS specific DeviceID, as the core ITS ignores dev. */ | ||||
| 	info->scratchpad[0].ul = pci_msi_domain_get_msi_rid(domain, pdev); | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Marc Zyngier
						Marc Zyngier