From 9a97177b907330971aa7bf41855fafc2602e1c18 Mon Sep 17 00:00:00 2001 From: Jonas Gorski Date: Sun, 22 Dec 2013 12:26:57 +0100 Subject: [PATCH 51/56] MIPS: BCM63XX: detect flash type early and store the result Signed-off-by: Jonas Gorski --- arch/mips/bcm63xx/dev-flash.c | 10 +++++++--- arch/mips/bcm63xx/prom.c | 4 ++++ arch/mips/include/asm/mach-bcm63xx/bcm63xx_dev_flash.h | 2 ++ 3 files changed, 13 insertions(+), 3 deletions(-) --- a/arch/mips/bcm63xx/dev-flash.c +++ b/arch/mips/bcm63xx/dev-flash.c @@ -22,6 +22,8 @@ #include #include +static int flash_type; + static struct mtd_partition mtd_partitions[] = { { .name = "cfe", @@ -108,13 +110,15 @@ static int __init bcm63xx_detect_flash_t } } +void __init bcm63xx_flash_detect(void) +{ + flash_type = bcm63xx_detect_flash_type(); +} + int __init bcm63xx_flash_register(void) { - int flash_type; u32 val; - flash_type = bcm63xx_detect_flash_type(); - switch (flash_type) { case BCM63XX_FLASH_TYPE_PARALLEL: /* read base address of boot chip select (0) */ --- a/arch/mips/bcm63xx/prom.c +++ b/arch/mips/bcm63xx/prom.c @@ -17,6 +17,7 @@ #include #include #include +#include void __init prom_init(void) { @@ -52,6 +53,9 @@ void __init prom_init(void) reg &= ~mask; bcm_perf_writel(reg, PERF_CKCTL_REG); + /* detect and setup flash access */ + bcm63xx_flash_detect(); + /* do low level board init */ board_prom_init(); --- a/arch/mips/include/asm/mach-bcm63xx/bcm63xx_dev_flash.h +++ b/arch/mips/include/asm/mach-bcm63xx/bcm63xx_dev_flash.h @@ -7,6 +7,8 @@ enum { BCM63XX_FLASH_TYPE_NAND, }; +void bcm63xx_flash_detect(void); + int __init bcm63xx_flash_register(void); #endif /* __BCM63XX_FLASH_H */