From: Mark A. Greer <[email protected]>

Since most of the emac platform_data is really SoC specific
and not board specific, move it to the SoC-specific files.
Put a pointer to the platform_data in davinci_soc_info
so the board-specific code can set some of the platform_data
if it needs to.

Signed-off-by: Mark A. Greer <[email protected]>
---
 arch/arm/mach-davinci/board-dm355-evm.c     |    1 -
 arch/arm/mach-davinci/board-dm644x-evm.c    |   18 ++++++------
 arch/arm/mach-davinci/board-dm646x-evm.c    |   16 +++++-----
 arch/arm/mach-davinci/board-sffsdr.c        |   15 +++++-----
 arch/arm/mach-davinci/devices.c             |    5 ---
 arch/arm/mach-davinci/dm644x.c              |   36 ++++++++++++-------------
 arch/arm/mach-davinci/dm646x.c              |   38 ++++++++++++--------------
 arch/arm/mach-davinci/include/mach/common.h |    3 ++
 arch/arm/mach-davinci/include/mach/dm644x.h |    1 -
 arch/arm/mach-davinci/include/mach/dm646x.h |    1 -
 10 files changed, 62 insertions(+), 72 deletions(-)

diff --git a/arch/arm/mach-davinci/board-dm355-evm.c 
b/arch/arm/mach-davinci/board-dm355-evm.c
index a2156fd..451ce5e 100644
--- a/arch/arm/mach-davinci/board-dm355-evm.c
+++ b/arch/arm/mach-davinci/board-dm355-evm.c
@@ -33,7 +33,6 @@
 #include <mach/dm355.h>
 #include <mach/psc.h>
 #include <mach/common.h>
-#include <mach/emac.h>
 #include <mach/i2c.h>
 #include <mach/serial.h>
 #include <mach/nand.h>
diff --git a/arch/arm/mach-davinci/board-dm644x-evm.c 
b/arch/arm/mach-davinci/board-dm644x-evm.c
index 2b7c403..00e18f0 100644
--- a/arch/arm/mach-davinci/board-dm644x-evm.c
+++ b/arch/arm/mach-davinci/board-dm644x-evm.c
@@ -37,7 +37,6 @@
 
 #include <mach/dm644x.h>
 #include <mach/common.h>
-#include <mach/emac.h>
 #include <mach/i2c.h>
 #include <mach/serial.h>
 #include <mach/mux.h>
@@ -60,11 +59,6 @@
 #define LXT971_PHY_ID  (0x001378e2)
 #define LXT971_PHY_MASK        (0xfffffff0)
 
-static struct emac_platform_data dm644x_evm_emac_pdata = {
-       .phy_mask       = DM644X_EVM_PHY_MASK,
-       .mdio_max_freq  = DM644X_EVM_MDIO_FREQUENCY,
-};
-
 static struct mtd_partition davinci_evm_norflash_partitions[] = {
        /* bootloader (UBL, U-Boot, etc) in first 5 sectors */
        {
@@ -417,6 +411,7 @@ static struct at24_iface *at24_if;
 
 static int at24_setup(struct at24_iface *iface, void *context)
 {
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
        DECLARE_MAC_BUF(mac_str);
        char mac_addr[6];
 
@@ -427,9 +422,9 @@ static int at24_setup(struct at24_iface *iface, void 
*context)
                printk(KERN_INFO "Read MAC addr from EEPROM: %s\n",
                       print_mac(mac_str, mac_addr));
 
-               memcpy(dm644x_evm_emac_pdata.mac_addr, mac_addr, 6);
+               memcpy(davinci_soc_info->emac_pdata->mac_addr, mac_addr, 6);
        }
-
+#endif
        return 0;
 }
 
@@ -679,7 +674,12 @@ static __init void davinci_evm_init(void)
        davinci_setup_mmc(0, &dm6446evm_mmc_config);
 
        davinci_serial_init(&uart_config);
-       davinci_init_emac(&dm644x_evm_emac_pdata);
+
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       davinci_soc_info->emac_pdata->phy_mask = DM644X_EVM_PHY_MASK;
+       davinci_soc_info->emac_pdata->mdio_max_freq = DM644X_EVM_MDIO_FREQUENCY;
+       davinci_init_emac(davinci_soc_info->emac_pdata);
+#endif
 
        /* Register the fixup for PHY on DaVinci */
        phy_register_fixup_for_uid(LXT971_PHY_ID, LXT971_PHY_MASK,
diff --git a/arch/arm/mach-davinci/board-dm646x-evm.c 
b/arch/arm/mach-davinci/board-dm646x-evm.c
index 3f52ba8..16c15a9 100644
--- a/arch/arm/mach-davinci/board-dm646x-evm.c
+++ b/arch/arm/mach-davinci/board-dm646x-evm.c
@@ -45,16 +45,10 @@
 #include <linux/i2c.h>
 #include <linux/i2c/at24.h>
 #include <linux/etherdevice.h>
-#include <mach/emac.h>
 
 #define DM646X_EVM_PHY_MASK            (0x2)
 #define DM646X_EVM_MDIO_FREQUENCY      (2200000) /* PHY bus frequency */
 
-static struct emac_platform_data dm646x_evm_emac_pdata = {
-       .phy_mask       = DM646X_EVM_PHY_MASK,
-       .mdio_max_freq  = DM646X_EVM_MDIO_FREQUENCY,
-};
-
 static struct davinci_uart_config uart_config __initdata = {
        .enabled_uarts = (1 << 0),
 };
@@ -67,6 +61,7 @@ static struct at24_iface *at24_if;
 
 static int at24_setup(struct at24_iface *iface, void *context)
 {
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
        DECLARE_MAC_BUF(mac_str);
        char mac_addr[6];
 
@@ -77,8 +72,9 @@ static int at24_setup(struct at24_iface *iface, void *context)
                printk(KERN_INFO "Read MAC addr from EEPROM: %s\n",
                print_mac(mac_str, mac_addr));
 
-               memcpy(dm646x_evm_emac_pdata.mac_addr, mac_addr, 6);
+               memcpy(davinci_soc_info->emac_pdata->mac_addr, mac_addr, 6);
        }
+#endif
        return 0;
 }
 static struct at24_platform_data eeprom_info = {
@@ -134,7 +130,11 @@ static __init void evm_init(void)
 {
        evm_init_i2c();
        davinci_serial_init(&uart_config);
-       davinci_init_emac(&dm646x_evm_emac_pdata);
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       davinci_soc_info->emac_pdata->phy_mask = DM646X_EVM_PHY_MASK;
+       davinci_soc_info->emac_pdata->mdio_max_freq = DM646X_EVM_MDIO_FREQUENCY;
+       davinci_init_emac(davinci_soc_info->emac_pdata);
+#endif
 }
 
 static __init void davinci_dm646x_evm_irq_init(void)
diff --git a/arch/arm/mach-davinci/board-sffsdr.c 
b/arch/arm/mach-davinci/board-sffsdr.c
index 5a13ee4..4188ff7 100644
--- a/arch/arm/mach-davinci/board-sffsdr.c
+++ b/arch/arm/mach-davinci/board-sffsdr.c
@@ -48,7 +48,6 @@
 
 #include <mach/dm644x.h>
 #include <mach/common.h>
-#include <mach/emac.h>
 #include <mach/i2c.h>
 #include <mach/serial.h>
 #include <mach/psc.h>
@@ -112,11 +111,6 @@ static struct platform_device 
davinci_sffsdr_nandflash_device = {
 /* Get Ethernet address from kernel boot params */
 static u8 davinci_sffsdr_mac_addr[6] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
 
-static struct emac_platform_data sffsdr_emac_pdata = {
-       .phy_mask       = SFFSDR_PHY_MASK,
-       .mdio_max_freq  = SFFSDR_MDIO_FREQUENCY,
-};
-
 static struct at24_platform_data eeprom_info = {
        .byte_len       = (64*1024) / 8,
        .page_size      = 32,
@@ -168,8 +162,13 @@ static __init void davinci_sffsdr_init(void)
                             ARRAY_SIZE(davinci_sffsdr_devices));
        sffsdr_init_i2c();
        davinci_serial_init(&uart_config);
-       memcpy(sffsdr_emac_pdata.mac_addr, davinci_sffsdr_mac_addr, 6);
-       davinci_init_emac(&sffsdr_emac_pdata);
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       memcpy(davinci_soc_info->emac_pdata->mac_addr,
+                       davinci_sffsdr_mac_addr, 6);
+       davinci_soc_info->emac_pdata->phy_mask = SFFSDR_PHY_MASK;
+       davinci_soc_info->emac_pdata->mdio_max_freq = SFFSDR_MDIO_FREQUENCY;
+       davinci_init_emac(davinci_soc_info->emac_pdata);
+#endif
        setup_usb(0, 0); /* We support only peripheral mode. */
 
        /* mux VLYNQ pins */
diff --git a/arch/arm/mach-davinci/devices.c b/arch/arm/mach-davinci/devices.c
index 0ea0a84..b8de587 100644
--- a/arch/arm/mach-davinci/devices.c
+++ b/arch/arm/mach-davinci/devices.c
@@ -264,11 +264,6 @@ void davinci_init_emac(struct emac_platform_data *pdata)
 {
        DECLARE_MAC_BUF(buf);
 
-       if (cpu_is_davinci_dm644x())
-               dm644x_init_emac(pdata);
-       else if (cpu_is_davinci_dm646x())
-               dm646x_init_emac(pdata);
-
        /* if valid MAC exists, don't re-register */
        if (is_valid_ether_addr(pdata->mac_addr))
                return;
diff --git a/arch/arm/mach-davinci/dm644x.c b/arch/arm/mach-davinci/dm644x.c
index 3d33390..fe75898 100644
--- a/arch/arm/mach-davinci/dm644x.c
+++ b/arch/arm/mach-davinci/dm644x.c
@@ -320,6 +320,14 @@ struct davinci_clk dm644x_clks[] = {
 };
 
 #if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+static struct emac_platform_data dm644x_emac_pdata = {
+       .ctrl_reg_offset        = DM644X_EMAC_CNTRL_OFFSET,
+       .ctrl_mod_reg_offset    = DM644X_EMAC_CNTRL_MOD_OFFSET,
+       .ctrl_ram_offset        = DM644X_EMAC_CNTRL_RAM_OFFSET,
+       .mdio_reg_offset        = DM644X_EMAC_MDIO_OFFSET,
+       .ctrl_ram_size          = DM644X_EMAC_CNTRL_RAM_SIZE,
+       .version                = EMAC_VERSION_1,
+};
 
 static struct resource dm644x_emac_resources[] = {
        {
@@ -337,10 +345,12 @@ static struct resource dm644x_emac_resources[] = {
 static struct platform_device dm644x_emac_device = {
        .name           = "davinci_emac",
        .id             = 1,
+       .dev = {
+              .platform_data   = &dm644x_emac_pdata,
+       },
        .num_resources  = ARRAY_SIZE(dm644x_emac_resources),
        .resource       = dm644x_emac_resources,
 };
-
 #endif
 
 /*
@@ -520,24 +530,6 @@ static struct platform_device dm644x_edma_device = {
 };
 
 /*----------------------------------------------------------------------*/
-#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
-
-void dm644x_init_emac(struct emac_platform_data *pdata)
-{
-       pdata->ctrl_reg_offset          = DM644X_EMAC_CNTRL_OFFSET;
-       pdata->ctrl_mod_reg_offset      = DM644X_EMAC_CNTRL_MOD_OFFSET;
-       pdata->ctrl_ram_offset          = DM644X_EMAC_CNTRL_RAM_OFFSET;
-       pdata->mdio_reg_offset          = DM644X_EMAC_MDIO_OFFSET;
-       pdata->ctrl_ram_size            = DM644X_EMAC_CNTRL_RAM_SIZE;
-       pdata->version                  = EMAC_VERSION_1;
-       dm644x_emac_device.dev.platform_data = pdata;
-       platform_device_register(&dm644x_emac_device);
-}
-#else
-
-void dm644x_init_emac(struct emac_platform_data *unused) {}
-
-#endif
 
 static struct map_desc dm644x_io_desc[] = {
        {
@@ -638,6 +630,9 @@ static struct davinci_soc_info davinci_soc_info_dm644x = {
        .gpio_num               = 71,
        .gpio_irq               = IRQ_GPIOBNK0,
        .serial_dev             = &dm644x_serial_device,
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       .emac_pdata             = &dm644x_emac_pdata,
+#endif
 };
 
 struct davinci_soc_info *dm644x_get_soc_info(void)
@@ -651,6 +646,9 @@ static int __init dm644x_init_devices(void)
                return 0;
 
        platform_device_register(&dm644x_edma_device);
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       platform_device_register(&dm644x_emac_device);
+#endif
        return 0;
 }
 postcore_initcall(dm644x_init_devices);
diff --git a/arch/arm/mach-davinci/dm646x.c b/arch/arm/mach-davinci/dm646x.c
index d413a31..dc6de6f 100644
--- a/arch/arm/mach-davinci/dm646x.c
+++ b/arch/arm/mach-davinci/dm646x.c
@@ -287,6 +287,15 @@ struct davinci_clk dm646x_clks[] = {
 };
 
 #if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+static struct emac_platform_data dm646x_emac_pdata = {
+       .ctrl_reg_offset        = DM646X_EMAC_CNTRL_OFFSET,
+       .ctrl_mod_reg_offset    = DM646X_EMAC_CNTRL_MOD_OFFSET,
+       .ctrl_ram_offset        = DM646X_EMAC_CNTRL_RAM_OFFSET,
+       .mdio_reg_offset        = DM646X_EMAC_MDIO_OFFSET,
+       .ctrl_ram_size          = DM646X_EMAC_CNTRL_RAM_SIZE,
+       .version                = EMAC_VERSION_2,
+};
+
 static struct resource dm646x_emac_resources[] = {
        {
                .start  = DM646X_EMAC_BASE,
@@ -318,10 +327,12 @@ static struct resource dm646x_emac_resources[] = {
 static struct platform_device dm646x_emac_device = {
        .name           = "davinci_emac",
        .id             = 1,
+       .dev = {
+               .platform_data  = &dm646x_emac_pdata,
+       },
        .num_resources  = ARRAY_SIZE(dm646x_emac_resources),
        .resource       = dm646x_emac_resources,
 };
-
 #endif
 
 /*
@@ -499,25 +510,6 @@ static struct platform_device dm646x_edma_device = {
 
 /*----------------------------------------------------------------------*/
 
-#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
-
-void dm646x_init_emac(struct emac_platform_data *pdata)
-{
-       pdata->ctrl_reg_offset          = DM646X_EMAC_CNTRL_OFFSET;
-       pdata->ctrl_mod_reg_offset      = DM646X_EMAC_CNTRL_MOD_OFFSET;
-       pdata->ctrl_ram_offset          = DM646X_EMAC_CNTRL_RAM_OFFSET;
-       pdata->mdio_reg_offset          = DM646X_EMAC_MDIO_OFFSET;
-       pdata->ctrl_ram_size            = DM646X_EMAC_CNTRL_RAM_SIZE;
-       pdata->version                  = EMAC_VERSION_2;
-       dm646x_emac_device.dev.platform_data = pdata;
-       platform_device_register(&dm646x_emac_device);
-}
-#else
-
-void dm646x_init_emac(struct emac_platform_data *unused) {}
-
-#endif
-
 static struct map_desc dm646x_io_desc[] = {
        {
                .virtual        = IO_VIRT,
@@ -617,6 +609,9 @@ static struct davinci_soc_info davinci_soc_info_dm646x = {
        .gpio_num               = 43, /* Only 33 usable */
        .gpio_irq               = IRQ_DM646X_GPIOBNK0,
        .serial_dev             = &dm646x_serial_device,
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       .emac_pdata             = &dm646x_emac_pdata,
+#endif
 };
 
 struct davinci_soc_info *dm646x_get_soc_info(void)
@@ -630,6 +625,9 @@ static int __init dm646x_init_devices(void)
                return 0;
 
        platform_device_register(&dm646x_edma_device);
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       platform_device_register(&dm646x_emac_device);
+#endif
        return 0;
 }
 postcore_initcall(dm646x_init_devices);
diff --git a/arch/arm/mach-davinci/include/mach/common.h 
b/arch/arm/mach-davinci/include/mach/common.h
index 6a34ce9..63d5188 100644
--- a/arch/arm/mach-davinci/include/mach/common.h
+++ b/arch/arm/mach-davinci/include/mach/common.h
@@ -59,6 +59,9 @@ struct davinci_soc_info {
        unsigned                        gpio_num;
        unsigned                        gpio_irq;
        struct platform_device          *serial_dev;
+#if defined(CONFIG_TI_DAVINCI_EMAC) || defined(CONFIG_TI_DAVINCI_EMAC_MODULE)
+       struct emac_platform_data       *emac_pdata;
+#endif
 };
 
 extern struct davinci_soc_info *davinci_soc_info;
diff --git a/arch/arm/mach-davinci/include/mach/dm644x.h 
b/arch/arm/mach-davinci/include/mach/dm644x.h
index f6f2f9c..30c1939 100644
--- a/arch/arm/mach-davinci/include/mach/dm644x.h
+++ b/arch/arm/mach-davinci/include/mach/dm644x.h
@@ -34,6 +34,5 @@
 #define DM644X_EMAC_CNTRL_RAM_SIZE     (0x2000)
 
 struct davinci_soc_info *dm644x_get_soc_info(void);
-void dm644x_init_emac(struct emac_platform_data *pdata);
 
 #endif /* __ASM_ARCH_DM644X_H */
diff --git a/arch/arm/mach-davinci/include/mach/dm646x.h 
b/arch/arm/mach-davinci/include/mach/dm646x.h
index ba6f2e4..2cfaf04 100644
--- a/arch/arm/mach-davinci/include/mach/dm646x.h
+++ b/arch/arm/mach-davinci/include/mach/dm646x.h
@@ -23,6 +23,5 @@
 #define DM646X_EMAC_CNTRL_RAM_SIZE     (0x2000)
 
 struct davinci_soc_info *dm646x_get_soc_info(void);
-void dm646x_init_emac(struct emac_platform_data *pdata);
 
 #endif /* __ASM_ARCH_DM646X_H */
-- 
1.6.0.3


_______________________________________________
Davinci-linux-open-source mailing list
[email protected]
http://linux.davincidsp.com/mailman/listinfo/davinci-linux-open-source

Reply via email to