mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-23 20:53:53 +08:00
7356420cd3
Only mx508 based board is mach-mx50_rdp and it has been marked as BROKEN for several releases. mx508 currently lacks clock support. In case someone needs to add mx508 support back, then the recommended approach is to use device tree. Signed-off-by: Fabio Estevam <fabio.estevam@freescale.com> Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
70 lines
1.8 KiB
C
70 lines
1.8 KiB
C
/*
|
|
* Copyright (C) 2010 Pengutronix
|
|
* Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
* the terms of the GNU General Public License version 2 as published by the
|
|
* Free Software Foundation.
|
|
*/
|
|
#include <linux/dma-mapping.h>
|
|
#include <asm/sizes.h>
|
|
|
|
#include "../hardware.h"
|
|
#include "devices-common.h"
|
|
|
|
#define imx_fec_data_entry_single(soc, _devid) \
|
|
{ \
|
|
.devid = _devid, \
|
|
.iobase = soc ## _FEC_BASE_ADDR, \
|
|
.irq = soc ## _INT_FEC, \
|
|
}
|
|
|
|
#ifdef CONFIG_SOC_IMX25
|
|
const struct imx_fec_data imx25_fec_data __initconst =
|
|
imx_fec_data_entry_single(MX25, "imx25-fec");
|
|
#endif /* ifdef CONFIG_SOC_IMX25 */
|
|
|
|
#ifdef CONFIG_SOC_IMX27
|
|
const struct imx_fec_data imx27_fec_data __initconst =
|
|
imx_fec_data_entry_single(MX27, "imx27-fec");
|
|
#endif /* ifdef CONFIG_SOC_IMX27 */
|
|
|
|
#ifdef CONFIG_SOC_IMX35
|
|
/* i.mx35 has the i.mx27 type fec */
|
|
const struct imx_fec_data imx35_fec_data __initconst =
|
|
imx_fec_data_entry_single(MX35, "imx27-fec");
|
|
#endif
|
|
|
|
#ifdef CONFIG_SOC_IMX51
|
|
/* i.mx51 has the i.mx27 type fec */
|
|
const struct imx_fec_data imx51_fec_data __initconst =
|
|
imx_fec_data_entry_single(MX51, "imx27-fec");
|
|
#endif
|
|
|
|
#ifdef CONFIG_SOC_IMX53
|
|
/* i.mx53 has the i.mx25 type fec */
|
|
const struct imx_fec_data imx53_fec_data __initconst =
|
|
imx_fec_data_entry_single(MX53, "imx25-fec");
|
|
#endif
|
|
|
|
struct platform_device *__init imx_add_fec(
|
|
const struct imx_fec_data *data,
|
|
const struct fec_platform_data *pdata)
|
|
{
|
|
struct resource res[] = {
|
|
{
|
|
.start = data->iobase,
|
|
.end = data->iobase + SZ_4K - 1,
|
|
.flags = IORESOURCE_MEM,
|
|
}, {
|
|
.start = data->irq,
|
|
.end = data->irq,
|
|
.flags = IORESOURCE_IRQ,
|
|
},
|
|
};
|
|
|
|
return imx_add_platform_device_dmamask(data->devid, 0,
|
|
res, ARRAY_SIZE(res),
|
|
pdata, sizeof(*pdata), DMA_BIT_MASK(32));
|
|
}
|