]> git.sur5r.net Git - u-boot/commitdiff
Moved initialization of MPC8220 FEC to cpu_eth_init()
authorBen Warren <biggerbadderben@gmail.com>
Thu, 23 Oct 2008 06:47:51 +0000 (23:47 -0700)
committerBen Warren <biggerbadderben@gmail.com>
Mon, 10 Nov 2008 05:38:03 +0000 (21:38 -0800)
Removed initialization of the driver from net/eth.c

Signed-off-by: Ben Warren <biggerbadderben@gmail.com>
board/sorcery/sorcery.c
cpu/mpc8220/cpu.c
include/netdev.h
net/eth.c

index 3e1bd6f0cf3b76c8e9f542813cc3b09f99afad46..90d4298020d1b3f53d299919f0d7aa1541c5807f 100644 (file)
@@ -62,5 +62,7 @@ void pci_init_board (void)
 
 int board_eth_init(bd_t *bis)
 {
+       /* Initialize built-in FEC first */
+       cpu_eth_init(bis);
        return pci_eth_init(bis);
 }
index 5b3fdd32c16d5ca6f8771b3ad2ec52a7d700bc3f..563cfe0536b57f98c9d00b1649d43090921f0aa0 100644 (file)
@@ -29,6 +29,7 @@
 #include <watchdog.h>
 #include <command.h>
 #include <mpc8220.h>
+#include <netdev.h>
 #include <asm/processor.h>
 
 DECLARE_GLOBAL_DATA_PTR;
@@ -89,3 +90,15 @@ unsigned long get_tbclk (void)
 }
 
 /* ------------------------------------------------------------------------- */
+
+/*
+ * Initializes on-chip ethernet controllers.
+ * to override, implement board_eth_init()
+ */
+int cpu_eth_init(bd_t *bis)
+{
+#if defined(CONFIG_MPC8220_FEC)
+       mpc8220_fec_initialize(bis);
+#endif
+       return 0;
+}
index 3b11961c8b9092f97306901982bca4e869552e5f..55183e87a14ded603aa6953e57c9a1a9c5b248f5 100644 (file)
@@ -56,6 +56,7 @@ int mcdmafec_initialize(bd_t *bis);
 int mcffec_initialize(bd_t *bis);
 int mpc512x_fec_initialize(bd_t *bis);
 int mpc5xxx_fec_initialize(bd_t *bis);
+int mpc8220_fec_initialize(bd_t *bis);
 int natsemi_initialize(bd_t *bis);
 int npe_initialize(bd_t *bis);
 int ns8382x_initialize(bd_t *bis);
index 3793dd7cb8ab551a2c98981bfac81910be45c8b8..d5431639aee7d24ea06993a2115c7c7bd454d43f 100644 (file)
--- a/net/eth.c
+++ b/net/eth.c
@@ -39,7 +39,6 @@ static int __def_eth_init(bd_t *bis)
 int cpu_eth_init(bd_t *bis) __attribute((weak, alias("__def_eth_init")));
 int board_eth_init(bd_t *bis) __attribute((weak, alias("__def_eth_init")));
 
-extern int mpc8220_fec_initialize(bd_t*);
 extern int mv6436x_eth_initialize(bd_t *);
 extern int mv6446x_eth_initialize(bd_t *);
 extern int ppc_4xx_eth_initialize(bd_t *);
@@ -160,9 +159,6 @@ int eth_initialize(bd_t *bis)
 #endif
 #ifdef SCC_ENET
        scc_initialize(bis);
-#endif
-#if defined(CONFIG_MPC8220_FEC)
-       mpc8220_fec_initialize(bis);
 #endif
        if (!eth_devices) {
                puts ("No ethernet found.\n");