blob: fdd355ae4d5fb3d2f754b4daf353c0f44fff3864 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001// SPDX-License-Identifier: GPL-2.0-only
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +01002/*
3 * Copyright (C) 2010 Pengutronix
4 * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +01005 */
Masahiro Yamada87dfb312019-05-14 15:46:51 -07006#include <linux/sizes.h>
Shawn Guo50f2de62012-09-14 14:14:45 +08007
8#include "../hardware.h"
Shawn Guoe0557c02012-09-13 15:51:15 +08009#include "devices-common.h"
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010010
Fabio Estevam8c2efec2010-12-06 16:38:32 -020011#define imx_imx2_wdt_data_entry_single(soc, _id, _hwid, _size) \
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010012 { \
Fabio Estevam8c2efec2010-12-06 16:38:32 -020013 .id = _id, \
14 .iobase = soc ## _WDOG ## _hwid ## _BASE_ADDR, \
Uwe Kleine-König00871502010-11-11 16:58:50 +010015 .iosize = _size, \
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010016 }
Fabio Estevam8c2efec2010-12-06 16:38:32 -020017#define imx_imx2_wdt_data_entry(soc, _id, _hwid, _size) \
18 [_id] = imx_imx2_wdt_data_entry_single(soc, _id, _hwid, _size)
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010019
20#ifdef CONFIG_SOC_IMX21
21const struct imx_imx2_wdt_data imx21_imx2_wdt_data __initconst =
Fabio Estevam8c2efec2010-12-06 16:38:32 -020022 imx_imx2_wdt_data_entry_single(MX21, 0, , SZ_4K);
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010023#endif /* ifdef CONFIG_SOC_IMX21 */
24
25#ifdef CONFIG_SOC_IMX27
26const struct imx_imx2_wdt_data imx27_imx2_wdt_data __initconst =
Fabio Estevam8c2efec2010-12-06 16:38:32 -020027 imx_imx2_wdt_data_entry_single(MX27, 0, , SZ_4K);
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010028#endif /* ifdef CONFIG_SOC_IMX27 */
29
Uwe Kleine-König742269e2010-11-15 15:28:45 +010030#ifdef CONFIG_SOC_IMX31
31const struct imx_imx2_wdt_data imx31_imx2_wdt_data __initconst =
Fabio Estevam8c2efec2010-12-06 16:38:32 -020032 imx_imx2_wdt_data_entry_single(MX31, 0, , SZ_16K);
Uwe Kleine-König742269e2010-11-15 15:28:45 +010033#endif /* ifdef CONFIG_SOC_IMX31 */
34
35#ifdef CONFIG_SOC_IMX35
36const struct imx_imx2_wdt_data imx35_imx2_wdt_data __initconst =
Fabio Estevam8c2efec2010-12-06 16:38:32 -020037 imx_imx2_wdt_data_entry_single(MX35, 0, , SZ_16K);
Uwe Kleine-König742269e2010-11-15 15:28:45 +010038#endif /* ifdef CONFIG_SOC_IMX35 */
39
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010040struct platform_device *__init imx_add_imx2_wdt(
41 const struct imx_imx2_wdt_data *data)
42{
43 struct resource res[] = {
44 {
45 .start = data->iobase,
Uwe Kleine-König00871502010-11-11 16:58:50 +010046 .end = data->iobase + data->iosize - 1,
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010047 .flags = IORESOURCE_MEM,
48 },
49 };
Fabio Estevam8c2efec2010-12-06 16:38:32 -020050 return imx_add_platform_device("imx2-wdt", data->id,
Uwe Kleine-Könige0a19612010-11-04 10:09:10 +010051 res, ARRAY_SIZE(res), NULL, 0);
52}