Re: [PATCH 7/7] s390/PCI: Use generic pci_enable_resources()

From: Bjorn Helgaas
Date: Mon Mar 03 2014 - 11:14:37 EST


On Mon, Mar 3, 2014 at 6:35 AM, Sebastian Ott <sebott@xxxxxxxxxxxxxxxxxx> wrote:
> Hello Bjorn,
>
> On Wed, 26 Feb 2014, Bjorn Helgaas wrote:
>
>> The generic pci_enable_resources() does essentially the same thing as the
>> code in the s390 version of pcibios_enable_device().
>>
>> There are differences, but I don't think any of them are a problem. The
>> generic code:
>>
>> - Checks everything up to PCI_NUM_RESOURCES, not PCI_BAR_COUNT (6), so
>> we'll now check the ROM resource, IOV resources, and bridge windows.
>>
>> - Checks for res->flags & IORESOURCE_UNSET. The s390 code never sets
>> IORESOURCE_UNSET, so this isn't a problem.
>>
>> - Checks res->parent. The s390 pcibios_add_device() calls
>> pci_claim_resource() on all BARs (except ROM, IOV, and bridge windows)
>> so this isn't a problem either.
>>
>> Signed-off-by: Bjorn Helgaas <bhelgaas@xxxxxxxxxx>
>> CC: Martin Schwidefsky <schwidefsky@xxxxxxxxxx>
>> CC: Heiko Carstens <heiko.carstens@xxxxxxxxxx>
>> CC: Sebastian Ott <sebott@xxxxxxxxxxxxxxxxxx>
>> CC: Jan Glauber <jang@xxxxxxxxxxxxxxxxxx>
>> CC: linux390@xxxxxxxxxx
>> ---
>> arch/s390/pci/pci.c | 13 +------------
>> 1 file changed, 1 insertion(+), 12 deletions(-)
>>
>> diff --git a/arch/s390/pci/pci.c b/arch/s390/pci/pci.c
>> index 66670ff262a0..7d5fcaed3361 100644
>> --- a/arch/s390/pci/pci.c
>> +++ b/arch/s390/pci/pci.c
>> @@ -695,18 +695,7 @@ int pcibios_enable_device(struct pci_dev *pdev, int mask)
>> zpci_fmb_enable_device(zdev);
>> zpci_map_resources(zdev);
>>
>> - pci_read_config_word(pdev, PCI_COMMAND, &cmd);
>> - for (i = 0; i < PCI_BAR_COUNT; i++) {
>> - res = &pdev->resource[i];
>> -
>> - if (res->flags & IORESOURCE_IO)
>> - return -EINVAL;
>> -
>> - if (res->flags & IORESOURCE_MEM)
>> - cmd |= PCI_COMMAND_MEMORY;
>> - }
>> - pci_write_config_word(pdev, PCI_COMMAND, cmd);
>> - return 0;
>> + return pci_enable_resources(pdev, mask);
>> }
>>
>> void pcibios_disable_device(struct pci_dev *pdev)
>>
>
> Let's also remove some now unused variables (updated patch below). Other
> than that:
>
> Acked-by: Sebastian Ott <sebott@xxxxxxxxxxxxxxxxxx>

Hi Sebastian,

Sorry, that was sloppy of me to leave those unused variables. I
updated the patch and added your ack. Thanks!

Bjorn

> ---
> s390/PCI: Use generic pci_enable_resources()
>
> The generic pci_enable_resources() does essentially the same thing as the
> code in the s390 version of pcibios_enable_device().
>
> There are differences, but I don't think any of them are a problem. The
> generic code:
>
> - Checks everything up to PCI_NUM_RESOURCES, not PCI_BAR_COUNT (6), so
> we'll now check the ROM resource, IOV resources, and bridge windows.
>
> - Checks for res->flags & IORESOURCE_UNSET. The s390 code never sets
> IORESOURCE_UNSET, so this isn't a problem.
>
> - Checks res->parent. The s390 pcibios_add_device() calls
> pci_claim_resource() on all BARs (except ROM, IOV, and bridge windows)
> so this isn't a problem either.
>
> Signed-off-by: Bjorn Helgaas <bhelgaas@xxxxxxxxxx>
> CC: Martin Schwidefsky <schwidefsky@xxxxxxxxxx>
> CC: Heiko Carstens <heiko.carstens@xxxxxxxxxx>
> CC: Sebastian Ott <sebott@xxxxxxxxxxxxxxxxxx>
> CC: Jan Glauber <jang@xxxxxxxxxxxxxxxxxx>
> CC: linux390@xxxxxxxxxx
> ---
> arch/s390/pci/pci.c | 16 +---------------
> 1 file changed, 1 insertion(+), 15 deletions(-)
>
> --- a/arch/s390/pci/pci.c
> +++ b/arch/s390/pci/pci.c
> @@ -686,27 +686,13 @@ int pcibios_add_device(struct pci_dev *p
> int pcibios_enable_device(struct pci_dev *pdev, int mask)
> {
> struct zpci_dev *zdev = get_zdev(pdev);
> - struct resource *res;
> - u16 cmd;
> - int i;
>
> zdev->pdev = pdev;
> zpci_debug_init_device(zdev);
> zpci_fmb_enable_device(zdev);
> zpci_map_resources(zdev);
>
> - pci_read_config_word(pdev, PCI_COMMAND, &cmd);
> - for (i = 0; i < PCI_BAR_COUNT; i++) {
> - res = &pdev->resource[i];
> -
> - if (res->flags & IORESOURCE_IO)
> - return -EINVAL;
> -
> - if (res->flags & IORESOURCE_MEM)
> - cmd |= PCI_COMMAND_MEMORY;
> - }
> - pci_write_config_word(pdev, PCI_COMMAND, cmd);
> - return 0;
> + return pci_enable_resources(pdev, mask);
> }
>
> void pcibios_disable_device(struct pci_dev *pdev)
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/