bus->boardinfo.vendor = bus->host_pci->subsystem_vendor;
        bus->boardinfo.type = bus->host_pci->subsystem_device;
 
+       /* Initialize struct, detect chip */
+       bcma_init_bus(bus);
+
        /* Register */
        err = bcma_bus_register(bus);
        if (err)
 
        bus->hosttype = BCMA_HOSTTYPE_SOC;
        bus->ops = &bcma_host_soc_ops;
 
+       /* Initialize struct, detect chip */
+       bcma_init_bus(bus);
+
        /* Register */
        err = bcma_bus_early_register(bus, &soc->core_cc, &soc->core_mips);
        if (err)
 
        struct bcma_device *core;
        struct bcma_device_id match;
 
-       bcma_init_bus(bus);
-
        match.manuf = BCMA_MANUF_BCM;
        match.id = bcma_cc_core_id(bus);
        match.class = BCMA_CL_SIM;
 
        s32 tmp;
        struct bcma_chipinfo *chipinfo = &(bus->chipinfo);
 
-       if (bus->init_done)
-               return;
-
        INIT_LIST_HEAD(&bus->cores);
        bus->nr_cores = 0;
 
        chipinfo->pkg = (tmp & BCMA_CC_ID_PKG) >> BCMA_CC_ID_PKG_SHIFT;
        bcma_info(bus, "Found chip with id 0x%04X, rev 0x%02X and package 0x%02X\n",
                  chipinfo->id, chipinfo->rev, chipinfo->pkg);
-
-       bus->init_done = true;
 }
 
 int bcma_bus_scan(struct bcma_bus *bus)
 
        int err, core_num = 0;
 
-       bcma_init_bus(bus);
-
        erombase = bcma_scan_read32(bus, 0, BCMA_CC_EROM);
        if (bus->hosttype == BCMA_HOSTTYPE_SOC) {
                eromptr = ioremap_nocache(erombase, BCMA_CORE_SIZE);
 
        struct bcma_device *mapped_core;
        struct list_head cores;
        u8 nr_cores;
-       u8 init_done:1;
        u8 num;
 
        struct bcma_drv_cc drv_cc;