Thread (10 messages) 10 messages, 5 authors, 2007-03-09

Re: 2.6.20-rc4-mm1: PCI=n: drivers/net/3c59x.c compile error

From: Randy Dunlap <hidden>
Date: 2007-02-26 18:30:25
Also in: lkml

On Mon, 26 Feb 2007 16:22:27 +0300 Sergei Shtylyov wrote:
Hello, I wrote:
quoted
quoted
quoted
quoted
3x59x-fix-pci-resource-management.patch causes the following compile 
error with CONFIG_PCI=n:
quoted
quoted
quoted
quoted
<--  snip  -->
quoted
quoted
quoted
quoted
...
  CC      drivers/net/3c59x.o
/home/bunk/linux/kernel-2.6/linux-2.6.20-rc4-mm1/drivers/net/3c59x.c: 
In function 'vortex_init_one':
/home/bunk/linux/kernel-2.6/linux-2.6.20-rc4-mm1/drivers/net/3c59x.c:961: 
error: implicit declaration of function 'pci_request_regions'
/home/bunk/linux/kernel-2.6/linux-2.6.20-rc4-mm1/drivers/net/3c59x.c:985: 
error: implicit declaration of function 'pci_release_regions'
make[3]: *** [drivers/net/3c59x.o] Error 1
quoted
quoted
quoted
   Grr, at at the same time it's happy with pci_enable_device().
   I'd say the problem is in <linux/pci.h>,  not in the patch.
quoted
quoted
   Has there been any patch to fix the "unbalanced" 
pci_{request|release}_regions() declarations? Am I suposed to create 
such?
quoted
   Alternatively, vortex_{init|remove_one() and struct pci_driver there 
could have been put under #ifdef CONFIG_PCI (good idea anyway -- should 
reduce driver size on non-PCI systems)...
    I wonder if I may count on any feedback on this -- asking linux-pci now...
    The issue is as follows: with my patch pci_{request|release}_regions() may 
be called with CONFIG_PCI=n (probably, this never has been a issue before) but 
<linux/pci.h> don't have them declared in this case -- unlike 
pci_enable_device() which is just empty for CONFIG_PCI=n.
    Now, what kind of approach do I take:

- a "fair one", so that pci_{request|release}_regions() get "balanced"
   declarations in the header like pci_enable_device();

- a "local one" (and even saving non-PCI kernel from needless bloat), i.e.
   #ifdef out functions that are only meaningful with CONFIG_PCI=y)?

    I'm leaning to the second now...
I'd prefer the fair one -- add stubs to include/linux/pci.h.

---
~Randy
*** Remember to use Documentation/SubmitChecklist when testing your code ***
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help