aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSam Ravnborg <sam@ravnborg.org>2008-02-02 16:33:43 -0500
committerGreg Kroah-Hartman <gregkh@suse.de>2008-02-02 18:08:04 -0500
commit451124a7cc6c89fcb83d48082c7290f16f652f1c (patch)
treee81340f0d9e83f5447d60418972a064c888463c9
parent4105717bc98ba01663ff28f8a16d8716ba9d07fe (diff)
PCI: fix 4x section mismatch warnings
The following warnings were issued during build of drivers/pci with an allyesconfig build: WARNING: o-x86_64/drivers/pci/built-in.o(.text+0xdaf): Section mismatch in reference from the function pci_add_new_bus() to the function .devinit.text:pci_alloc_child_bus() WARNING: o-x86_64/drivers/pci/built-in.o(.text+0x15e2): Section mismatch in reference from the function pci_scan_single_device() to the function .devinit.text:pci_scan_device() WARNING: o-x86_64/drivers/pci/built-in.o(.text+0x1b0c5): Section mismatch in reference from the function pci_bus_assign_resources() to the function .devinit.text:pci_setup_bridge() WARNING: o-x86_64/drivers/pci/built-in.o(.text+0x1b32d): Section mismatch in reference from the function pci_bus_size_bridges() to the function .devinit.text:pci_bus_size_cardbus() Investigating each case closer it looked like all referred functions are only used in the init phase or during hotplug. So to avoid wasting too much memory in the non-hotplug case the simpler fix was to allow the fuctions to use code/data from the __devinit sections. This was done in all four case by adding the __ref annotation. Signed-off-by: Sam Ravnborg <sam@ravnborg.org> Cc: Adrian Bunk <bunk@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r--drivers/pci/probe.c4
-rw-r--r--drivers/pci/setup-bus.c4
2 files changed, 4 insertions, 4 deletions
diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
index 3bb2bc2a1e70..7f5dab34d315 100644
--- a/drivers/pci/probe.c
+++ b/drivers/pci/probe.c
@@ -433,7 +433,7 @@ pci_alloc_child_bus(struct pci_bus *parent, struct pci_dev *bridge, int busnr)
433 return child; 433 return child;
434} 434}
435 435
436struct pci_bus *pci_add_new_bus(struct pci_bus *parent, struct pci_dev *dev, int busnr) 436struct pci_bus *__ref pci_add_new_bus(struct pci_bus *parent, struct pci_dev *dev, int busnr)
437{ 437{
438 struct pci_bus *child; 438 struct pci_bus *child;
439 439
@@ -948,7 +948,7 @@ void pci_device_add(struct pci_dev *dev, struct pci_bus *bus)
948 up_write(&pci_bus_sem); 948 up_write(&pci_bus_sem);
949} 949}
950 950
951struct pci_dev *pci_scan_single_device(struct pci_bus *bus, int devfn) 951struct pci_dev *__ref pci_scan_single_device(struct pci_bus *bus, int devfn)
952{ 952{
953 struct pci_dev *dev; 953 struct pci_dev *dev;
954 954
diff --git a/drivers/pci/setup-bus.c b/drivers/pci/setup-bus.c
index 8a7232feb553..262b0439abe9 100644
--- a/drivers/pci/setup-bus.c
+++ b/drivers/pci/setup-bus.c
@@ -456,7 +456,7 @@ pci_bus_size_cardbus(struct pci_bus *bus)
456 } 456 }
457} 457}
458 458
459void pci_bus_size_bridges(struct pci_bus *bus) 459void __ref pci_bus_size_bridges(struct pci_bus *bus)
460{ 460{
461 struct pci_dev *dev; 461 struct pci_dev *dev;
462 unsigned long mask, prefmask; 462 unsigned long mask, prefmask;
@@ -511,7 +511,7 @@ void pci_bus_size_bridges(struct pci_bus *bus)
511} 511}
512EXPORT_SYMBOL(pci_bus_size_bridges); 512EXPORT_SYMBOL(pci_bus_size_bridges);
513 513
514void pci_bus_assign_resources(struct pci_bus *bus) 514void __ref pci_bus_assign_resources(struct pci_bus *bus)
515{ 515{
516 struct pci_bus *b; 516 struct pci_bus *b;
517 struct pci_dev *dev; 517 struct pci_dev *dev;