forked from mirrors/linux
		
	xen/pirq: fix error path cleanup when binding MSIs
Current cleanup in the error path of xen_bind_pirq_msi_to_irq is
wrong. First of all there's an off-by-one in the cleanup loop, which
can lead to unbinding wrong IRQs.
Secondly IRQs not bound won't be freed, thus leaking IRQ numbers.
Note that there's no need to differentiate between bound and unbound
IRQs when freeing them, __unbind_from_irq will deal with both of them
correctly.
Fixes: 4892c9b4ad ("xen: add support for MSI message groups")
Reported-by: Hooman Mirhadi <mirhadih@amazon.com>
Signed-off-by: Roger Pau Monné <roger.pau@citrix.com>
Reviewed-by: Amit Shah <aams@amazon.com>
Reviewed-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Signed-off-by: Juergen Gross <jgross@suse.com>
			
			
This commit is contained in:
		
							parent
							
								
									68d2059be6
								
							
						
					
					
						commit
						910f8befdf
					
				
					 1 changed files with 2 additions and 2 deletions
				
			
		|  | @ -755,8 +755,8 @@ int xen_bind_pirq_msi_to_irq(struct pci_dev *dev, struct msi_desc *msidesc, | |||
| 	mutex_unlock(&irq_mapping_update_lock); | ||||
| 	return irq; | ||||
| error_irq: | ||||
| 	for (; i >= 0; i--) | ||||
| 		__unbind_from_irq(irq + i); | ||||
| 	while (nvec--) | ||||
| 		__unbind_from_irq(irq + nvec); | ||||
| 	mutex_unlock(&irq_mapping_update_lock); | ||||
| 	return ret; | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Roger Pau Monne
						Roger Pau Monne