54 lines
1.4 KiB
C
54 lines
1.4 KiB
C
|
/*
|
||
|
* Copyright 2011 Freescale Semiconductor, Inc. All Rights Reserved.
|
||
|
*
|
||
|
* 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 <linux/compiler.h>
|
||
|
#include <linux/err.h>
|
||
|
#include <linux/init.h>
|
||
|
|
||
|
#include <mach/mx23.h>
|
||
|
#include <mach/mx28.h>
|
||
|
#include <mach/devices-common.h>
|
||
|
|
||
|
struct platform_device *__init mxs_add_gpio(
|
||
|
int id, resource_size_t iobase, int irq)
|
||
|
{
|
||
|
struct resource res[] = {
|
||
|
{
|
||
|
.start = iobase,
|
||
|
.end = iobase + SZ_8K - 1,
|
||
|
.flags = IORESOURCE_MEM,
|
||
|
}, {
|
||
|
.start = irq,
|
||
|
.end = irq,
|
||
|
.flags = IORESOURCE_IRQ,
|
||
|
},
|
||
|
};
|
||
|
|
||
|
return platform_device_register_resndata(&mxs_apbh_bus,
|
||
|
"gpio-mxs", id, res, ARRAY_SIZE(res), NULL, 0);
|
||
|
}
|
||
|
|
||
|
static int __init mxs_add_mxs_gpio(void)
|
||
|
{
|
||
|
if (cpu_is_mx23()) {
|
||
|
mxs_add_gpio(0, MX23_PINCTRL_BASE_ADDR, MX23_INT_GPIO0);
|
||
|
mxs_add_gpio(1, MX23_PINCTRL_BASE_ADDR, MX23_INT_GPIO1);
|
||
|
mxs_add_gpio(2, MX23_PINCTRL_BASE_ADDR, MX23_INT_GPIO2);
|
||
|
}
|
||
|
|
||
|
if (cpu_is_mx28()) {
|
||
|
mxs_add_gpio(0, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO0);
|
||
|
mxs_add_gpio(1, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO1);
|
||
|
mxs_add_gpio(2, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO2);
|
||
|
mxs_add_gpio(3, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO3);
|
||
|
mxs_add_gpio(4, MX28_PINCTRL_BASE_ADDR, MX28_INT_GPIO4);
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
postcore_initcall(mxs_add_mxs_gpio);
|