123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- From 83131acbfb59760a19f3711c09526e191c8aad54 Mon Sep 17 00:00:00 2001
- From: Jonas Gorski <jogo@openwrt.org>
- Date: Tue, 29 Jul 2014 21:52:56 +0200
- Subject: [PATCH 03/10] MIPS: BCM63XX: make fallback sprom optional
- Some devices do not provide enough mac addresses to populate wifi in
- addition to ethernet.
- Use having pci enabled as a rough heuristic which boards should have it
- enabled.
- Signed-off-by: Jonas Gorski <jogo@openwrt.org>
- ---
- arch/mips/bcm63xx/boards/board_bcm963xx.c | 12 ++++++++++++
- arch/mips/bcm63xx/boards/board_common.c | 5 +++--
- arch/mips/include/asm/mach-bcm63xx/board_bcm963xx.h | 1 +
- 3 files changed, 16 insertions(+), 2 deletions(-)
- --- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
- +++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
- @@ -70,6 +70,7 @@ static struct board_info __initdata boar
- .has_uart0 = 1,
- .has_pci = 1,
- .has_usbd = 0,
- + .use_fallback_sprom = 1,
-
- .usbd = {
- .use_fullspeed = 0,
- @@ -219,6 +220,7 @@ static struct board_info __initdata boar
- .has_uart0 = 1,
- .has_enet0 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -264,6 +266,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -324,6 +327,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -378,6 +382,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -436,6 +441,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -459,6 +465,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -477,6 +484,7 @@ static struct board_info __initdata boar
-
- .has_uart0 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
- .has_ohci0 = 1,
-
- .has_enet0 = 1,
- @@ -499,6 +507,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -525,6 +534,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -577,6 +587,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- @@ -648,6 +659,7 @@ static struct board_info __initdata boar
- .has_enet0 = 1,
- .has_enet1 = 1,
- .has_pci = 1,
- + .use_fallback_sprom = 1,
-
- .enet0 = {
- .has_phy = 1,
- --- a/arch/mips/bcm63xx/boards/board_common.c
- +++ b/arch/mips/bcm63xx/boards/board_common.c
- @@ -188,8 +188,9 @@ int __init board_register_devices(void)
- * do this after registering enet devices
- */
-
- - if (board_get_mac_address(board.fallback_sprom.mac_addr) ||
- - bcm63xx_register_fallback_sprom(&board.fallback_sprom))
- + if (board.use_fallback_sprom &&
- + (board_get_mac_address(board.fallback_sprom.mac_addr) ||
- + bcm63xx_register_fallback_sprom(&board.fallback_sprom)))
- pr_err(PFX "failed to register fallback SPROM\n");
-
- bcm63xx_spi_register();
- --- a/arch/mips/include/asm/mach-bcm63xx/board_bcm963xx.h
- +++ b/arch/mips/include/asm/mach-bcm63xx/board_bcm963xx.h
- @@ -34,6 +34,7 @@ struct board_info {
- unsigned int has_dsp:1;
- unsigned int has_uart0:1;
- unsigned int has_uart1:1;
- + unsigned int use_fallback_sprom:1;
-
- /* ethernet config */
- struct bcm63xx_enet_platform_data enet0;
|