[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <66b55c14-a124-f6cb-0b02-7aa7afd2e434@gmail.com>
Date: Thu, 1 Mar 2018 21:36:51 +0100
From: Heiner Kallweit <hkallweit1@...il.com>
To: Andy Shevchenko <andriy.shevchenko@...ux.intel.com>,
nic_swsd@...ltek.com, "David S . Miller" <davem@...emloft.net>
Cc: netdev@...r.kernel.org
Subject: Re: [PATCH v4 2/2] r8169: switch to device-managed functions in probe
(part 2)
Am 01.03.2018 um 21:15 schrieb Andy Shevchenko:
> On Thu, 2018-03-01 at 20:54 +0100, Heiner Kallweit wrote:
>> Am 01.03.2018 um 12:27 schrieb Andy Shevchenko:
>
>>> - rc = pci_request_regions(pdev, MODULENAME);
>>> + rc = pcim_iomap_regions(pdev, BIT(region), MODULENAME);
>>> if (rc < 0) {
>>> - netif_err(tp, probe, dev, "could not request
>>> regions\n");
>>> + netif_err(tp, probe, dev, "cannot remap MMIO,
>>> aborting\n");
>>> return rc;
>>> }
>>>
>>>
>
>>> + tp->mmio_addr = pcim_iomap_table(pdev)[region];
>>>
>>
>> pcim_iomap_table() can return NULL in case of an error.
>
> No.
>
>> Shouldn't we catch this?
>
> No.
>
> Yeah, I'm a bit tired to explain everyone that pcim_iomap_table() will
> never fail if previous pcim_iomap_regions() not failed.
>
Ahh, missed this because I didn't dig that deep into these functions.
Would be nice if pcim_iomap_regions() returned iomap directly
(or an ERRPTR). Then the additional call to pcim_iomap_table()
wouldn't be needed.
>> Typical benefit of switching to device-managed functions is that we
>> don't
>> have to clean up in the probe() error path and in remove(). With the
>> change here we don't have any such benefit and we just exchange two
>> calls
>> against two other calls w/o functional change (AFAICS).
>> Which benefit do you see justifying this patch?
>
> -67% statistics is a good sign, no?
>
>> However I don't know the PCI API's good enough to be able to judge
>> whether
>> one set of calls is preferable.
>
> More than above, it's about consistency. While you switch to devm_, for
> PCI driver it's naturally to go for pcim_.
>
> Esp. taking into account that pcim_enable_device() _is_ already there.
>
Powered by blists - more mailing lists