|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v11 01/17] pci: msi: pass pdev to pci_enable_msi() function
On 02.12.2023 02:27, Volodymyr Babchuk wrote:
> --- a/xen/drivers/char/ns16550.c
> +++ b/xen/drivers/char/ns16550.c
> @@ -452,21 +452,29 @@ static void __init cf_check ns16550_init_postirq(struct
> serial_port *port)
> if ( rc > 0 )
> {
> struct msi_desc *msi_desc = NULL;
> + struct pci_dev *pdev;
>
> pcidevs_lock();
>
> - rc = pci_enable_msi(&msi, &msi_desc);
> - if ( !rc )
> + pdev = pci_get_pdev(NULL, msi.sbdf);
> + if ( pdev )
> {
> - struct irq_desc *desc = irq_to_desc(msi.irq);
> - unsigned long flags;
> -
> - spin_lock_irqsave(&desc->lock, flags);
> - rc = setup_msi_irq(desc, msi_desc);
> - spin_unlock_irqrestore(&desc->lock, flags);
> - if ( rc )
> - pci_disable_msi(msi_desc);
> + rc = pci_enable_msi(pdev, &msi, &msi_desc);
> +
> + if ( !rc )
> + {
> + struct irq_desc *desc = irq_to_desc(msi.irq);
> + unsigned long flags;
> +
> + spin_lock_irqsave(&desc->lock, flags);
> + rc = setup_msi_irq(desc, msi_desc);
> + spin_unlock_irqrestore(&desc->lock, flags);
> + if ( rc )
> + pci_disable_msi(msi_desc);
> + }
> }
> + else
> + rc = -ENODEV;
>
> pcidevs_unlock();
When mere re-indenting is needed, and even more so when indentation gets
this deep, I think it is necessary to consider alternatives: With
pdev = pci_get_pdev(NULL, msi.sbdf);
rc = pdev ? pci_enable_msi(pdev, &msi, &msi_desc) : -ENODEV;
I think all of the other code churn could be avoided.
Jan
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |