Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754173Ab2KGXAn (ORCPT ); Wed, 7 Nov 2012 18:00:43 -0500 Received: from mail-wi0-f172.google.com ([209.85.212.172]:37362 "EHLO mail-wi0-f172.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751404Ab2KGXAl (ORCPT ); Wed, 7 Nov 2012 18:00:41 -0500 MIME-Version: 1.0 In-Reply-To: References: <1347994314.9011.1.camel@joe2Laptop> From: Bjorn Helgaas Date: Wed, 7 Nov 2012 16:00:19 -0700 Message-ID: Subject: Re: [PATCH] pci: Convert pci_resource_ macros to static inlines To: Joe Perches Cc: linux-pci , LKML Content-Type: text/plain; charset=ISO-8859-1 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3243 Lines: 86 On Mon, Nov 5, 2012 at 3:28 PM, Bjorn Helgaas wrote: > On Tue, Sep 18, 2012 at 12:51 PM, Joe Perches wrote: >> Get the compiler to verify the argument type of struct pci_dev *. >> >> Signed-off-by: Joe Perches > > I applied this to my pci/misc branch as v3.8 material. Thanks! I dropped this for now because of these build failures: drivers/staging/telephony/ixj.c: In function 'ixj_probe_pci': drivers/staging/telephony/ixj.c:7732:13: warning: assignment makes integer from pointer without a cast [enabled by default] drivers/staging/telephony/ixj.c:7732:38: error: expected ';' before 'pci_resource_start' drivers/scsi/gdth.c: In function 'gdth_init_pci': drivers/scsi/gdth.c:1111:34: error: lvalue required as left operand of assignment I posted a fix for the gdth.c problem, and ixj.c is apparently being deleted. When those happen, we can try again. Bjorn >> --- >> >> Another possible improvement is to range check index. >> >> include/linux/pci.h | 36 ++++++++++++++++++++++++++---------- >> 1 files changed, 26 insertions(+), 10 deletions(-) >> >> diff --git a/include/linux/pci.h b/include/linux/pci.h >> index 5faa831..971d0e9 100644 >> --- a/include/linux/pci.h >> +++ b/include/linux/pci.h >> @@ -1396,16 +1396,32 @@ static inline struct pci_dev *pci_dev_get(struct pci_dev *dev) >> >> /* these helpers provide future and backwards compatibility >> * for accessing popular PCI BAR info */ >> -#define pci_resource_start(dev, bar) ((dev)->resource[(bar)].start) >> -#define pci_resource_end(dev, bar) ((dev)->resource[(bar)].end) >> -#define pci_resource_flags(dev, bar) ((dev)->resource[(bar)].flags) >> -#define pci_resource_len(dev,bar) \ >> - ((pci_resource_start((dev), (bar)) == 0 && \ >> - pci_resource_end((dev), (bar)) == \ >> - pci_resource_start((dev), (bar))) ? 0 : \ >> - \ >> - (pci_resource_end((dev), (bar)) - \ >> - pci_resource_start((dev), (bar)) + 1)) >> +static inline resource_size_t >> +pci_resource_start(const struct pci_dev *dev, int index) >> +{ >> + return dev->resource[index].start; >> +} >> + >> +static inline resource_size_t >> +pci_resource_end(const struct pci_dev *dev, int index) >> +{ >> + return dev->resource[index].end; >> +} >> + >> +static inline unsigned long >> +pci_resource_flags(const struct pci_dev *dev, int index) >> +{ >> + return dev->resource[index].flags; >> +} >> + >> +static inline resource_size_t >> +pci_resource_len(const struct pci_dev *dev, int index) >> +{ >> + if (pci_resource_start(dev, index) == 0 && >> + pci_resource_end(dev, index) == 0) >> + return 0; >> + return resource_size(&dev->resource[index]); >> +} >> >> /* Similar to the helpers above, these manipulate per-pci_dev >> * driver-specific data. They are really just a wrapper around >> >> >> -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/