|
@@ -459,8 +459,8 @@ static void pcibios_init_hw(struct device *parent, struct hw_pci *hw,
|
|
|
|
|
|
for (nr = busnr = 0; nr < hw->nr_controllers; nr++) {
|
|
|
sys = kzalloc(sizeof(struct pci_sys_data), GFP_KERNEL);
|
|
|
- if (!sys)
|
|
|
- panic("PCI: unable to allocate sys data!");
|
|
|
+ if (WARN(!sys, "PCI: unable to allocate sys data!"))
|
|
|
+ break;
|
|
|
|
|
|
#ifdef CONFIG_PCI_MSI
|
|
|
sys->msi_ctrl = hw->msi_ctrl;
|
|
@@ -489,8 +489,10 @@ static void pcibios_init_hw(struct device *parent, struct hw_pci *hw,
|
|
|
sys->bus = pci_scan_root_bus(parent, sys->busnr,
|
|
|
hw->ops, sys, &sys->resources);
|
|
|
|
|
|
- if (!sys->bus)
|
|
|
- panic("PCI: unable to scan bus!");
|
|
|
+ if (WARN(!sys->bus, "PCI: unable to scan bus!")) {
|
|
|
+ kfree(sys);
|
|
|
+ break;
|
|
|
+ }
|
|
|
|
|
|
busnr = sys->bus->busn_res.end + 1;
|
|
|
|