Hi Nikolay, On Wed, Aug 05, 2015 at 05:31:27PM +0300, Nikolay Dimitrov wrote: >Hi Peng, > >On 08/03/2015 01:06 PM, Peng Fan wrote: >>The MIB RAM and FIFO receive start register does not exist on >>i.MX6UL. Accessing these register will cause enet not work well. >> >>Signed-off-by: Peng Fan <[email protected]> >>Signed-off-by: Fugang Duan <[email protected]> >>Cc: Joe Hershberger <[email protected]> >>--- >> drivers/net/fec_mxc.c | 4 ++++ >> 1 file changed, 4 insertions(+) >> >>diff --git a/drivers/net/fec_mxc.c b/drivers/net/fec_mxc.c >>index c5dcbbb..7fb1d5f 100644 >>--- a/drivers/net/fec_mxc.c >>+++ b/drivers/net/fec_mxc.c >>@@ -520,8 +520,10 @@ static int fec_open(struct eth_device *edev) >> static int fec_init(struct eth_device *dev, bd_t* bd) >> { >> struct fec_priv *fec = (struct fec_priv *)dev->priv; >>+#if !defined(CONFIG_MX6UL) >> uint32_t mib_ptr = (uint32_t)&fec->eth->rmon_t_drop; >> int i; >>+#endif >> >> /* Initialize MAC address */ >> fec_set_hwaddr(dev); >>@@ -551,12 +553,14 @@ static int fec_init(struct eth_device *dev, bd_t* bd) >> writel(0x00000000, &fec->eth->gaddr2); >> >> >>+#if !defined(CONFIG_MX6UL) >> /* clear MIB RAM */ >> for (i = mib_ptr; i <= mib_ptr + 0xfc; i += 4) >> writel(0, i); >> >> /* FIFO receive start register */ >> writel(0x520, &fec->eth->r_fstart); >>+#endif >> >> /* size and address of each buffer */ >> writel(FEC_MAX_PKT_SIZE, &fec->eth->emrbr); >> > >Is it possible to do runtime check for the SoC type, instead of ifdefs?
This driver is used by i.MX7 and i.MX6, but i.MX7 patchset has not been upstreamed now. I considered using "if (!is_cpu_type(MXC_CPU_MX6UL))", but this will cause i.MX7 fail to complile successfully, because i.MX7 does not support the macro MXC_CPU_MX6UL. The way I can think out is to refactor the code to support DM or FDT, using compatible string to figure out which SoC. But now I do not have much time to refactor the driver. So I just use the "#if !defined" way which is not good solution. Regards, Peng. -- _______________________________________________ U-Boot mailing list [email protected] http://lists.denx.de/mailman/listinfo/u-boot

