]> git.sur5r.net Git - u-boot/commitdiff
qe: Pass in uec_info struct through uec_initialize
authorHaiying Wang <Haiying.Wang@freescale.com>
Thu, 4 Jun 2009 20:12:41 +0000 (16:12 -0400)
committerKumar Gala <galak@kernel.crashing.org>
Fri, 12 Jun 2009 22:17:02 +0000 (17:17 -0500)
The uec driver contains code to hard code configuration information for the uec
ethernet controllers. This patch creates an array of uec_info structures, which
are then parsed by the corresponding driver instance to determine configuration.
It also creates function uec_standard_init() to initialize all UEC interfaces
for 83xx and 85xx.

Signed-off-by: Haiying Wang <Haiying.Wang@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
cpu/mpc83xx/cpu.c
cpu/mpc85xx/cpu.c
drivers/qe/uec.c
drivers/qe/uec.h

index 876f5c731a8595620588078b57274ff18b2979b2..c4331ae97eebe14f7f99fd94e5335422fface5ee 100644 (file)
@@ -367,24 +367,10 @@ int dma_xfer(void *dest, u32 count, void *src)
  */
 int cpu_eth_init(bd_t *bis)
 {
-#if defined(CONFIG_UEC_ETH1)
-       uec_initialize(0);
-#endif
-#if defined(CONFIG_UEC_ETH2)
-       uec_initialize(1);
-#endif
-#if defined(CONFIG_UEC_ETH3)
-       uec_initialize(2);
-#endif
-#if defined(CONFIG_UEC_ETH4)
-       uec_initialize(3);
-#endif
-#if defined(CONFIG_UEC_ETH5)
-       uec_initialize(4);
-#endif
-#if defined(CONFIG_UEC_ETH6)
-       uec_initialize(5);
+#if defined(CONFIG_UEC_ETH)
+       uec_standard_init(bis);
 #endif
+
 #if defined(CONFIG_TSEC_ENET)
        tsec_standard_init(bis);
 #endif
index 8f94bada04162d35105c99356be31113ba61211a..9ad118842be9d2582aa3243b2f0c20f4fa3e3f76 100644 (file)
@@ -383,24 +383,11 @@ int cpu_eth_init(bd_t *bis)
 #if defined(CONFIG_ETHER_ON_FCC)
        fec_initialize(bis);
 #endif
-#if defined(CONFIG_UEC_ETH1)
-       uec_initialize(0);
-#endif
-#if defined(CONFIG_UEC_ETH2)
-       uec_initialize(1);
-#endif
-#if defined(CONFIG_UEC_ETH3)
-       uec_initialize(2);
-#endif
-#if defined(CONFIG_UEC_ETH4)
-       uec_initialize(3);
-#endif
-#if defined(CONFIG_UEC_ETH5)
-       uec_initialize(4);
-#endif
-#if defined(CONFIG_UEC_ETH6)
-       uec_initialize(5);
+
+#if defined(CONFIG_UEC_ETH)
+       uec_standard_init(bis);
 #endif
+
 #if defined(CONFIG_TSEC_ENET) || defined(CONFIG_MPC85XX_FEC)
        tsec_standard_init(bis);
 #endif
index d02c8c98e8549813a8d7af9870dc5017aff0c088..0b4a6e7c47c849bed90662c6e59bdc1aa1103c5e 100644 (file)
 #include "uec_phy.h"
 #include "miiphy.h"
 
+static uec_info_t uec_info[] = {
 #ifdef CONFIG_UEC_ETH1
-static uec_info_t eth1_uec_info = {
-       .uf_info                = {
-               .ucc_num        = CONFIG_SYS_UEC1_UCC_NUM,
-               .rx_clock       = CONFIG_SYS_UEC1_RX_CLK,
-               .tx_clock       = CONFIG_SYS_UEC1_TX_CLK,
-               .eth_type       = CONFIG_SYS_UEC1_ETH_TYPE,
-       },
-#if (CONFIG_SYS_UEC1_ETH_TYPE == FAST_ETH)
-       .num_threads_tx         = UEC_NUM_OF_THREADS_1,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_1,
-#else
-       .num_threads_tx         = UEC_NUM_OF_THREADS_4,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_4,
-#endif
-#if (MAX_QE_RISC == 4)
-       .risc_tx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-       .risc_rx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-#else
-       .risc_tx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-       .risc_rx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-#endif
-       .tx_bd_ring_len         = 16,
-       .rx_bd_ring_len         = 16,
-       .phy_address            = CONFIG_SYS_UEC1_PHY_ADDR,
-       .enet_interface         = CONFIG_SYS_UEC1_INTERFACE_MODE,
-};
+       STD_UEC_INFO(1),        /* UEC1 */
 #endif
 #ifdef CONFIG_UEC_ETH2
-static uec_info_t eth2_uec_info = {
-       .uf_info                = {
-               .ucc_num        = CONFIG_SYS_UEC2_UCC_NUM,
-               .rx_clock       = CONFIG_SYS_UEC2_RX_CLK,
-               .tx_clock       = CONFIG_SYS_UEC2_TX_CLK,
-               .eth_type       = CONFIG_SYS_UEC2_ETH_TYPE,
-       },
-#if (CONFIG_SYS_UEC2_ETH_TYPE == FAST_ETH)
-       .num_threads_tx         = UEC_NUM_OF_THREADS_1,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_1,
-#else
-       .num_threads_tx         = UEC_NUM_OF_THREADS_4,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_4,
-#endif
-#if (MAX_QE_RISC == 4)
-       .risc_tx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-       .risc_rx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-#else
-       .risc_tx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-       .risc_rx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-#endif
-       .tx_bd_ring_len         = 16,
-       .rx_bd_ring_len         = 16,
-       .phy_address            = CONFIG_SYS_UEC2_PHY_ADDR,
-       .enet_interface         = CONFIG_SYS_UEC2_INTERFACE_MODE,
-};
+       STD_UEC_INFO(2),        /* UEC2 */
 #endif
 #ifdef CONFIG_UEC_ETH3
-static uec_info_t eth3_uec_info = {
-       .uf_info                = {
-               .ucc_num        = CONFIG_SYS_UEC3_UCC_NUM,
-               .rx_clock       = CONFIG_SYS_UEC3_RX_CLK,
-               .tx_clock       = CONFIG_SYS_UEC3_TX_CLK,
-               .eth_type       = CONFIG_SYS_UEC3_ETH_TYPE,
-       },
-#if (CONFIG_SYS_UEC3_ETH_TYPE == FAST_ETH)
-       .num_threads_tx         = UEC_NUM_OF_THREADS_1,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_1,
-#else
-       .num_threads_tx         = UEC_NUM_OF_THREADS_4,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_4,
-#endif
-#if (MAX_QE_RISC == 4)
-       .risc_tx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-       .risc_rx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-#else
-       .risc_tx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-       .risc_rx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-#endif
-       .tx_bd_ring_len         = 16,
-       .rx_bd_ring_len         = 16,
-       .phy_address            = CONFIG_SYS_UEC3_PHY_ADDR,
-       .enet_interface         = CONFIG_SYS_UEC3_INTERFACE_MODE,
-};
+       STD_UEC_INFO(3),        /* UEC3 */
 #endif
 #ifdef CONFIG_UEC_ETH4
-static uec_info_t eth4_uec_info = {
-       .uf_info                = {
-               .ucc_num        = CONFIG_SYS_UEC4_UCC_NUM,
-               .rx_clock       = CONFIG_SYS_UEC4_RX_CLK,
-               .tx_clock       = CONFIG_SYS_UEC4_TX_CLK,
-               .eth_type       = CONFIG_SYS_UEC4_ETH_TYPE,
-       },
-#if (CONFIG_SYS_UEC4_ETH_TYPE == FAST_ETH)
-       .num_threads_tx         = UEC_NUM_OF_THREADS_1,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_1,
-#else
-       .num_threads_tx         = UEC_NUM_OF_THREADS_4,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_4,
-#endif
-#if (MAX_QE_RISC == 4)
-       .risc_tx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-       .risc_rx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-#else
-       .risc_tx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-       .risc_rx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-#endif
-       .tx_bd_ring_len         = 16,
-       .rx_bd_ring_len         = 16,
-       .phy_address            = CONFIG_SYS_UEC4_PHY_ADDR,
-       .enet_interface         = CONFIG_SYS_UEC4_INTERFACE_MODE,
-};
+       STD_UEC_INFO(4),        /* UEC4 */
 #endif
 #ifdef CONFIG_UEC_ETH5
-static uec_info_t eth5_uec_info = {
-       .uf_info                = {
-               .ucc_num        = CONFIG_SYS_UEC5_UCC_NUM,
-               .rx_clock       = CONFIG_SYS_UEC5_RX_CLK,
-               .tx_clock       = CONFIG_SYS_UEC5_TX_CLK,
-               .eth_type       = CONFIG_SYS_UEC5_ETH_TYPE,
-       },
-#if (CONFIG_SYS_UEC5_ETH_TYPE == FAST_ETH)
-       .num_threads_tx         = UEC_NUM_OF_THREADS_1,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_1,
-#else
-       .num_threads_tx         = UEC_NUM_OF_THREADS_4,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_4,
-#endif
-#if (MAX_QE_RISC == 4)
-       .risc_tx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-       .risc_rx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-#else
-       .risc_tx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-       .risc_rx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-#endif
-       .tx_bd_ring_len         = 16,
-       .rx_bd_ring_len         = 16,
-       .phy_address            = CONFIG_SYS_UEC5_PHY_ADDR,
-       .enet_interface         = CONFIG_SYS_UEC5_INTERFACE_MODE,
-};
+       STD_UEC_INFO(5),        /* UEC5 */
 #endif
 #ifdef CONFIG_UEC_ETH6
-static uec_info_t eth6_uec_info = {
-       .uf_info                = {
-               .ucc_num        = CONFIG_SYS_UEC6_UCC_NUM,
-               .rx_clock       = CONFIG_SYS_UEC6_RX_CLK,
-               .tx_clock       = CONFIG_SYS_UEC6_TX_CLK,
-               .eth_type       = CONFIG_SYS_UEC6_ETH_TYPE,
-       },
-#if (CONFIG_SYS_UEC6_ETH_TYPE == FAST_ETH)
-       .num_threads_tx         = UEC_NUM_OF_THREADS_1,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_1,
-#else
-       .num_threads_tx         = UEC_NUM_OF_THREADS_4,
-       .num_threads_rx         = UEC_NUM_OF_THREADS_4,
+       STD_UEC_INFO(6),        /* UEC6 */
 #endif
-#if (MAX_QE_RISC == 4)
-       .risc_tx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-       .risc_rx                        = QE_RISC_ALLOCATION_FOUR_RISCS,
-#else
-       .risc_tx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
-       .risc_rx                        = QE_RISC_ALLOCATION_RISC1_AND_RISC2,
+#ifdef CONFIG_UEC_ETH7
+       STD_UEC_INFO(7),        /* UEC7 */
 #endif
-       .tx_bd_ring_len         = 16,
-       .rx_bd_ring_len         = 16,
-       .phy_address            = CONFIG_SYS_UEC6_PHY_ADDR,
-       .enet_interface         = CONFIG_SYS_UEC6_INTERFACE_MODE,
-};
+#ifdef CONFIG_UEC_ETH8
+       STD_UEC_INFO(8),        /* UEC8 */
 #endif
+};
 
-#define MAXCONTROLLERS (6)
+#define MAXCONTROLLERS (8)
 
 static struct eth_device *devlist[MAXCONTROLLERS];
 
@@ -1447,12 +1305,11 @@ static int uec_recv(struct eth_device* dev)
        return 1;
 }
 
-int uec_initialize(int index)
+int uec_initialize(bd_t *bis, uec_info_t *uec_info)
 {
        struct eth_device       *dev;
        int                     i;
        uec_private_t           *uec;
-       uec_info_t              *uec_info;
        int                     err;
 
        dev = (struct eth_device *)malloc(sizeof(struct eth_device));
@@ -1467,42 +1324,17 @@ int uec_initialize(int index)
        }
        memset(uec, 0, sizeof(uec_private_t));
 
-       /* Init UEC private struct, they come from board.h */
-       uec_info = NULL;
-       if (index == 0) {
-#ifdef CONFIG_UEC_ETH1
-               uec_info = &eth1_uec_info;
-#endif
-       } else if (index == 1) {
-#ifdef CONFIG_UEC_ETH2
-               uec_info = &eth2_uec_info;
-#endif
-       } else if (index == 2) {
-#ifdef CONFIG_UEC_ETH3
-               uec_info = &eth3_uec_info;
-#endif
-       } else if (index == 3) {
-#ifdef CONFIG_UEC_ETH4
-               uec_info = &eth4_uec_info;
-#endif
-       } else if (index == 4) {
-#ifdef CONFIG_UEC_ETH5
-               uec_info = &eth5_uec_info;
-#endif
-       } else if (index == 5) {
-#ifdef CONFIG_UEC_ETH6
-               uec_info = &eth6_uec_info;
+       /* Adjust uec_info */
+#if (MAX_QE_RISC == 4)
+       uec_info->risc_tx = QE_RISC_ALLOCATION_FOUR_RISCS;
+       uec_info->risc_rx = QE_RISC_ALLOCATION_FOUR_RISCS;
 #endif
-       } else {
-               printf("%s: index is illegal.\n", __FUNCTION__);
-               return -EINVAL;
-       }
 
-       devlist[index] = dev;
+       devlist[uec_info->uf_info.ucc_num] = dev;
 
        uec->uec_info = uec_info;
 
-       sprintf(dev->name, "FSL UEC%d", index);
+       sprintf(dev->name, "FSL UEC%d", uec_info->uf_info.ucc_num);
        dev->iobase = 0;
        dev->priv = (void *)uec;
        dev->init = uec_init;
@@ -1529,3 +1361,20 @@ int uec_initialize(int index)
 
        return 1;
 }
+
+int uec_eth_init(bd_t *bis, uec_info_t *uecs, int num)
+{
+       int i;
+
+       for (i = 0; i < num; i++)
+               uec_initialize(bis, &uecs[i]);
+
+       return 0;
+}
+
+int uec_standard_init(bd_t *bis)
+{
+       return uec_eth_init(bis, uec_info, ARRAY_SIZE(uec_info));
+}
+
+
index 4fd10962c92172979559a5cc0ff1b8702bf9a211..6c408d102c4541900bd87905bf02b0c5682640ec 100644 (file)
@@ -650,6 +650,24 @@ typedef enum enet_interface {
 
 /* UEC initialization info struct
 */
+#define STD_UEC_INFO(num) \
+{                      \
+       .uf_info                = {     \
+               .ucc_num        = CONFIG_SYS_UEC##num##_UCC_NUM,\
+               .rx_clock       = CONFIG_SYS_UEC##num##_RX_CLK, \
+               .tx_clock       = CONFIG_SYS_UEC##num##_TX_CLK, \
+               .eth_type       = CONFIG_SYS_UEC##num##_ETH_TYPE,\
+       },      \
+       .num_threads_tx         = UEC_NUM_OF_THREADS_1, \
+       .num_threads_rx         = UEC_NUM_OF_THREADS_1, \
+       .risc_tx                = QE_RISC_ALLOCATION_RISC1_AND_RISC2, \
+       .risc_rx                = QE_RISC_ALLOCATION_RISC1_AND_RISC2, \
+       .tx_bd_ring_len         = 16,   \
+       .rx_bd_ring_len         = 16,   \
+       .phy_address            = CONFIG_SYS_UEC##num##_PHY_ADDR, \
+       .enet_interface         = CONFIG_SYS_UEC##num##_INTERFACE_MODE, \
+}
+
 typedef struct uec_info {
        ucc_fast_info_t                 uf_info;
        uec_num_of_threads_e            num_threads_tx;
@@ -716,4 +734,7 @@ typedef struct uec_private {
        int                             oldlink;
 } uec_private_t;
 
+int uec_initialize(bd_t *bis, uec_info_t *uec_info);
+int uec_eth_init(bd_t *bis, uec_info_t *uecs, int num);
+int uec_standard_init(bd_t *bis);
 #endif /* __UEC_H__ */