blob: 20f28ba16f368e7e5a5848fc119f95c033ffe938 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001// SPDX-License-Identifier: GPL-2.0-only
Gaëtan Carlier3ab3a352012-09-05 13:06:15 +02002/*
3 * Copyright (C) 2010 Pengutronix
4 * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
Gaëtan Carlier3ab3a352012-09-05 13:06:15 +02005 */
Fabio Estevam027c0a62012-11-26 14:11:22 -02006#include "../hardware.h"
7#include "devices-common.h"
Gaëtan Carlier3ab3a352012-09-05 13:06:15 +02008
9#define imx_mx2_emmaprp_data_entry_single(soc) \
10 { \
11 .iobase = soc ## _EMMAPRP_BASE_ADDR, \
Alexander Shiyan08da51c2014-04-27 20:03:26 +040012 .iosize = SZ_256, \
Gaëtan Carlier3ab3a352012-09-05 13:06:15 +020013 .irq = soc ## _INT_EMMAPRP, \
14 }
15
16#ifdef CONFIG_SOC_IMX27
17const struct imx_mx2_emma_data imx27_mx2_emmaprp_data __initconst =
18 imx_mx2_emmaprp_data_entry_single(MX27);
19#endif /* ifdef CONFIG_SOC_IMX27 */
20
21struct platform_device *__init imx_add_mx2_emmaprp(
22 const struct imx_mx2_emma_data *data)
23{
24 struct resource res[] = {
25 {
26 .start = data->iobase,
27 .end = data->iobase + data->iosize - 1,
28 .flags = IORESOURCE_MEM,
29 }, {
30 .start = data->irq,
31 .end = data->irq,
32 .flags = IORESOURCE_IRQ,
33 },
34 };
35 return imx_add_platform_device_dmamask("m2m-emmaprp", 0,
36 res, 2, NULL, 0, DMA_BIT_MASK(32));
37}