Commit 799038ea authored by Rafał Miłecki's avatar Rafał Miłecki Committed by Kalle Valo

bcma: clean bus initialization code

This moves main bus init code to the main.c and renames old function to
make its purpose clear.
Thanks to this change we'll also be able to separate scanning from
registration (and support PCIe Gen 2 devices) in the future.
Signed-off-by: default avatarRafał Miłecki <zajec5@gmail.com>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent 6b47aaca
...@@ -25,6 +25,7 @@ struct bcma_bus; ...@@ -25,6 +25,7 @@ struct bcma_bus;
bool bcma_wait_value(struct bcma_device *core, u16 reg, u32 mask, u32 value, bool bcma_wait_value(struct bcma_device *core, u16 reg, u32 mask, u32 value,
int timeout); int timeout);
void bcma_prepare_core(struct bcma_bus *bus, struct bcma_device *core); void bcma_prepare_core(struct bcma_bus *bus, struct bcma_device *core);
void bcma_init_bus(struct bcma_bus *bus);
int bcma_bus_register(struct bcma_bus *bus); int bcma_bus_register(struct bcma_bus *bus);
void bcma_bus_unregister(struct bcma_bus *bus); void bcma_bus_unregister(struct bcma_bus *bus);
int __init bcma_bus_early_register(struct bcma_bus *bus, int __init bcma_bus_early_register(struct bcma_bus *bus,
...@@ -36,11 +37,11 @@ int bcma_bus_resume(struct bcma_bus *bus); ...@@ -36,11 +37,11 @@ int bcma_bus_resume(struct bcma_bus *bus);
#endif #endif
/* scan.c */ /* scan.c */
void bcma_detect_chip(struct bcma_bus *bus);
int bcma_bus_scan(struct bcma_bus *bus); int bcma_bus_scan(struct bcma_bus *bus);
int __init bcma_bus_scan_early(struct bcma_bus *bus, int __init bcma_bus_scan_early(struct bcma_bus *bus,
struct bcma_device_id *match, struct bcma_device_id *match,
struct bcma_device *core); struct bcma_device *core);
void bcma_init_bus(struct bcma_bus *bus);
/* sprom.c */ /* sprom.c */
int bcma_sprom_get(struct bcma_bus *bus); int bcma_sprom_get(struct bcma_bus *bus);
......
...@@ -268,6 +268,18 @@ void bcma_prepare_core(struct bcma_bus *bus, struct bcma_device *core) ...@@ -268,6 +268,18 @@ void bcma_prepare_core(struct bcma_bus *bus, struct bcma_device *core)
} }
} }
void bcma_init_bus(struct bcma_bus *bus)
{
mutex_lock(&bcma_buses_mutex);
bus->num = bcma_bus_next_num++;
mutex_unlock(&bcma_buses_mutex);
INIT_LIST_HEAD(&bus->cores);
bus->nr_cores = 0;
bcma_detect_chip(bus);
}
static void bcma_register_core(struct bcma_bus *bus, struct bcma_device *core) static void bcma_register_core(struct bcma_bus *bus, struct bcma_device *core)
{ {
int err; int err;
...@@ -369,10 +381,6 @@ int bcma_bus_register(struct bcma_bus *bus) ...@@ -369,10 +381,6 @@ int bcma_bus_register(struct bcma_bus *bus)
int err; int err;
struct bcma_device *core; struct bcma_device *core;
mutex_lock(&bcma_buses_mutex);
bus->num = bcma_bus_next_num++;
mutex_unlock(&bcma_buses_mutex);
/* Scan for devices (cores) */ /* Scan for devices (cores) */
err = bcma_bus_scan(bus); err = bcma_bus_scan(bus);
if (err) { if (err) {
......
...@@ -435,15 +435,12 @@ static int bcma_get_next_core(struct bcma_bus *bus, u32 __iomem **eromptr, ...@@ -435,15 +435,12 @@ static int bcma_get_next_core(struct bcma_bus *bus, u32 __iomem **eromptr,
return 0; return 0;
} }
void bcma_init_bus(struct bcma_bus *bus) void bcma_detect_chip(struct bcma_bus *bus)
{ {
s32 tmp; s32 tmp;
struct bcma_chipinfo *chipinfo = &(bus->chipinfo); struct bcma_chipinfo *chipinfo = &(bus->chipinfo);
char chip_id[8]; char chip_id[8];
INIT_LIST_HEAD(&bus->cores);
bus->nr_cores = 0;
bcma_scan_switch_core(bus, BCMA_ADDR_BASE); bcma_scan_switch_core(bus, BCMA_ADDR_BASE);
tmp = bcma_scan_read32(bus, 0, BCMA_CC_ID); tmp = bcma_scan_read32(bus, 0, BCMA_CC_ID);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment