summaryrefslogtreecommitdiff
path: root/arch/arm/plat-mxc/devices/platform-mxc_pwm.c
blob: 32a7516019b9fffb009c10db461718412c5c7567 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
/*
 * Copyright (C) 2009-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 <mach/hardware.h>
#include <mach/devices-common.h>

#define imx_mxc_pwm_data_entry_single(soc, _id, _hwid, _size)		\
	{								\
		.id = _id,						\
		.iobase = soc ## _PWM ## _hwid ## _BASE_ADDR,		\
		.iosize = _size,					\
		.irq = soc ## _INT_PWM ## _hwid,			\
	}
#define imx_mxc_pwm_data_entry(soc, _id, _hwid, _size)			\
	[_id] = imx_mxc_pwm_data_entry_single(soc, _id, _hwid, _size)

#ifdef CONFIG_SOC_IMX21
const struct imx_mxc_pwm_data imx21_mxc_pwm_data __initconst =
	imx_mxc_pwm_data_entry_single(MX21, 0, , SZ_4K);
#endif /* ifdef CONFIG_SOC_IMX21 */

#ifdef CONFIG_SOC_IMX25
const struct imx_mxc_pwm_data imx25_mxc_pwm_data[] __initconst = {
#define imx25_mxc_pwm_data_entry(_id, _hwid)				\
	imx_mxc_pwm_data_entry(MX25, _id, _hwid, SZ_16K)
	imx25_mxc_pwm_data_entry(0, 1),
	imx25_mxc_pwm_data_entry(1, 2),
	imx25_mxc_pwm_data_entry(2, 3),
	imx25_mxc_pwm_data_entry(3, 4),
};
#endif /* ifdef CONFIG_SOC_IMX25 */

#ifdef CONFIG_SOC_IMX27
const struct imx_mxc_pwm_data imx27_mxc_pwm_data __initconst =
	imx_mxc_pwm_data_entry_single(MX27, 0, , SZ_4K);
#endif /* ifdef CONFIG_SOC_IMX27 */

#ifdef CONFIG_SOC_IMX51
const struct imx_mxc_pwm_data imx51_mxc_pwm_data[] __initconst = {
#define imx51_mxc_pwm_data_entry(_id, _hwid)				\
	imx_mxc_pwm_data_entry(MX51, _id, _hwid, SZ_16K)
	imx51_mxc_pwm_data_entry(0, 1),
	imx51_mxc_pwm_data_entry(1, 2),
};
#endif /* ifdef CONFIG_SOC_IMX51 */

#ifdef CONFIG_SOC_IMX53
const struct imx_mxc_pwm_data imx53_mxc_pwm_data[] __initconst = {
#define imx53_mxc_pwm_data_entry(_id, _hwid)				\
	imx_mxc_pwm_data_entry(MX53, _id, _hwid, SZ_16K)
	imx53_mxc_pwm_data_entry(0, 1),
	imx53_mxc_pwm_data_entry(1, 2),
};
#endif /* ifdef CONFIG_SOC_IMX53 */

#ifdef CONFIG_SOC_IMX6Q
const struct imx_mxc_pwm_data imx6q_mxc_pwm_data[] __initconst = {
#define imx6q_mxc_pwm_data_entry(_id, _hwid)				\
	imx_mxc_pwm_data_entry(MX6Q, _id, _hwid, SZ_16K)
	imx6q_mxc_pwm_data_entry(0, 1),
	imx6q_mxc_pwm_data_entry(1, 2),
	imx6q_mxc_pwm_data_entry(2, 3),
	imx6q_mxc_pwm_data_entry(3, 4),
};
#endif /* ifdef CONFIG_SOC_IMX6Q */

#ifdef CONFIG_SOC_MVFA5
const struct imx_mxc_pwm_data mvf_mxc_pwm_data[] __initdata = {
	[0] = {
		0,
		MVF_FTM0_BASE_ADDR,
		SZ_4K,
		MVF_INT_FLEXTIMER0,
	},
	[1] = {
		1,
		MVF_FTM1_BASE_ADDR,
		SZ_4K,
		MVF_INT_FLEXTIMER1,
	},
	[2] = {
		2,
		MVF_FTM2_BASE_ADDR,
		SZ_4K,
		MVF_INT_FLEXTIMER2,
	},
	[3] = {
		3,
		MVF_FTM3_BASE_ADDR,
		SZ_4K,
		MVF_INT_FLEXTIMER3,
	},
};

struct platform_device *__init imx_add_mvf_ftm_pwm(
		const struct imx_mxc_pwm_data *data)
{
	struct resource res[] = {
		{
			.start = data->iobase,
			.end = data->iobase + data->iosize - 1,
			.flags = IORESOURCE_MEM,
		}, {
			.start = data->irq,
			.end = data->irq,
			.flags = IORESOURCE_IRQ,
		},
	};

	return imx_add_platform_device("mvf_ftm_pwm", data->id,
			res, ARRAY_SIZE(res), NULL, 0);
}
#endif

struct platform_device *__init imx_add_mxc_pwm(
		const struct imx_mxc_pwm_data *data)
{
	struct resource res[] = {
		{
			.start = data->iobase,
			.end = data->iobase + data->iosize - 1,
			.flags = IORESOURCE_MEM,
		}, {
			.start = data->irq,
			.end = data->irq,
			.flags = IORESOURCE_IRQ,
		},
	};

	return imx_add_platform_device("mxc_pwm", data->id,
			res, ARRAY_SIZE(res), NULL, 0);
}