blob: 2cb188ad9a0a614422892a7ef64396bacdead050 [file] [log] [blame]
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +02001/*
2 * Copyright (C) 2010 Pengutronix
3 * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License version 2 as published by the
7 * Free Software Foundation.
8 */
Alexey Dobriyanb7f080c2011-06-16 11:01:34 +00009#include <linux/dma-mapping.h>
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020010#include <asm/sizes.h>
Shawn Guo50f2de62012-09-14 14:14:45 +080011
12#include "../hardware.h"
Shawn Guoe0557c02012-09-13 15:51:15 +080013#include "devices-common.h"
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020014
Shawn Guo0ca1e292011-07-01 18:11:22 +080015#define imx_fec_data_entry_single(soc, _devid) \
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020016 { \
Shawn Guo0ca1e292011-07-01 18:11:22 +080017 .devid = _devid, \
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020018 .iobase = soc ## _FEC_BASE_ADDR, \
19 .irq = soc ## _INT_FEC, \
20 }
21
Uwe Kleine-König972cc482010-11-11 18:35:01 +010022#ifdef CONFIG_SOC_IMX25
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020023const struct imx_fec_data imx25_fec_data __initconst =
Shawn Guo0ca1e292011-07-01 18:11:22 +080024 imx_fec_data_entry_single(MX25, "imx25-fec");
Uwe Kleine-König972cc482010-11-11 18:35:01 +010025#endif /* ifdef CONFIG_SOC_IMX25 */
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020026
27#ifdef CONFIG_SOC_IMX27
28const struct imx_fec_data imx27_fec_data __initconst =
Shawn Guo0ca1e292011-07-01 18:11:22 +080029 imx_fec_data_entry_single(MX27, "imx27-fec");
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020030#endif /* ifdef CONFIG_SOC_IMX27 */
31
Uwe Kleine-Königa528bc82010-11-12 10:11:42 +010032#ifdef CONFIG_SOC_IMX35
Shawn Guo0ca1e292011-07-01 18:11:22 +080033/* i.mx35 has the i.mx27 type fec */
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020034const struct imx_fec_data imx35_fec_data __initconst =
Shawn Guo0ca1e292011-07-01 18:11:22 +080035 imx_fec_data_entry_single(MX35, "imx27-fec");
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020036#endif
37
Richard Zhao82c520d2011-01-14 17:48:03 +080038#ifdef CONFIG_SOC_IMX50
Shawn Guo0ca1e292011-07-01 18:11:22 +080039/* i.mx50 has the i.mx25 type fec */
Richard Zhao82c520d2011-01-14 17:48:03 +080040const struct imx_fec_data imx50_fec_data __initconst =
Shawn Guo0ca1e292011-07-01 18:11:22 +080041 imx_fec_data_entry_single(MX50, "imx25-fec");
Richard Zhao82c520d2011-01-14 17:48:03 +080042#endif
43
Fabio Estevamd94ed122010-11-26 12:25:58 -020044#ifdef CONFIG_SOC_IMX51
Shawn Guo0ca1e292011-07-01 18:11:22 +080045/* i.mx51 has the i.mx27 type fec */
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020046const struct imx_fec_data imx51_fec_data __initconst =
Shawn Guo0ca1e292011-07-01 18:11:22 +080047 imx_fec_data_entry_single(MX51, "imx27-fec");
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020048#endif
49
Yong Shen63904762011-01-07 12:25:32 +080050#ifdef CONFIG_SOC_IMX53
Shawn Guo0ca1e292011-07-01 18:11:22 +080051/* i.mx53 has the i.mx25 type fec */
Yong Shen63904762011-01-07 12:25:32 +080052const struct imx_fec_data imx53_fec_data __initconst =
Shawn Guo0ca1e292011-07-01 18:11:22 +080053 imx_fec_data_entry_single(MX53, "imx25-fec");
Yong Shen63904762011-01-07 12:25:32 +080054#endif
55
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020056struct platform_device *__init imx_add_fec(
57 const struct imx_fec_data *data,
58 const struct fec_platform_data *pdata)
59{
60 struct resource res[] = {
61 {
62 .start = data->iobase,
Shawn Guo5d187242011-03-20 11:17:59 +080063 .end = data->iobase + SZ_4K - 1,
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020064 .flags = IORESOURCE_MEM,
65 }, {
66 .start = data->irq,
67 .end = data->irq,
68 .flags = IORESOURCE_IRQ,
69 },
70 };
71
Shawn Guo0ca1e292011-07-01 18:11:22 +080072 return imx_add_platform_device_dmamask(data->devid, 0,
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020073 res, ARRAY_SIZE(res),
Uwe Kleine-König78159562011-01-19 11:37:10 +010074 pdata, sizeof(*pdata), DMA_BIT_MASK(32));
Uwe Kleine-König6bd96f32010-10-06 12:00:18 +020075}