@@ -9,14 +9,40 @@
#include <asm/sizes.h>
#include <mach/devices-common.h>
+static struct platform_device *__init mxs_add_pwm_core(resource_size_t iobase)
+{
+ struct resource res = {
+ .flags = IORESOURCE_MEM,
+ .start = iobase,
+ .end = iobase + 0xff,
+ };
+
+ return mxs_add_platform_device("mxs-pwm-core", 0, &res, 1, NULL, 0);
+}
+
struct platform_device *__init mxs_add_mxs_pwm(resource_size_t iobase, int id)
{
+ struct resource *r;
+
+ static struct platform_device *pwm_core;
struct resource res = {
.flags = IORESOURCE_MEM,
+ .start = iobase + 0x10 + 0x20 * id,
+ .end = iobase + 0x10 + 0x20 * id + 0x1f,
};
- res.start = iobase + 0x10 + 0x20 * id;
- res.end = res.start + 0x1f;
+ if (!pwm_core) {
+ pwm_core = mxs_add_pwm_core(iobase);
+ if (!pwm_core)
+ return NULL;
+ }
+
+ r = platform_get_resource(pwm_core, IORESOURCE_MEM, 0);
+ if (!r)
+ return NULL;
+
+ res.parent = r;
- return mxs_add_platform_device("mxs-pwm", id, &res, 1, NULL, 0);
+ return platform_device_register_resndata(&pwm_core->dev, "mxs-pwm",
+ id, &res, 1, NULL, 0);
}
The PWMs on i.MX23/28 have almost seperated register spaces but share a common enable register. To reflect this register a parent device to the PWMs which handles the enable register. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> --- arch/arm/mach-mxs/devices/platform-mxs-pwm.c | 32 +++++++++++++++++++++++-- 1 files changed, 29 insertions(+), 3 deletions(-)