Commit af7dc228 authored by Rabin Vincent's avatar Rabin Vincent Committed by Russell King

ARM: 6104/1: nomadik-gpio: use clk API

Add clocks with appropriate names in platforms that use it, and use the
clk API in nomadik-gpio.
Acked-by: default avatarAlessandro Rubini <rubini@unipv.it>
Acked-by: default avatarLinus Walleij <linus.walleij@stericsson.com>
Acked-by: default avatarSrinidhi Kasagar <srinidhi.kasagar@stericsson.com>
Signed-off-by: default avatarRabin Vincent <rabin.vincent@stericsson.com>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent dc6048c7
...@@ -37,6 +37,12 @@ static struct clk clk_48 = { ...@@ -37,6 +37,12 @@ static struct clk clk_48 = {
.rate = 48 * 1000 * 1000, .rate = 48 * 1000 * 1000,
}; };
/*
* Catch-all default clock to satisfy drivers using the clk API. We don't
* model the actual hardware clocks yet.
*/
static struct clk clk_default;
#define CLK(_clk, dev) \ #define CLK(_clk, dev) \
{ \ { \
.clk = _clk, \ .clk = _clk, \
...@@ -46,6 +52,10 @@ static struct clk clk_48 = { ...@@ -46,6 +52,10 @@ static struct clk clk_48 = {
static struct clk_lookup lookups[] = { static struct clk_lookup lookups[] = {
CLK(&clk_48, "uart0"), CLK(&clk_48, "uart0"),
CLK(&clk_48, "uart1"), CLK(&clk_48, "uart1"),
CLK(&clk_default, "gpio.0"),
CLK(&clk_default, "gpio.1"),
CLK(&clk_default, "gpio.2"),
CLK(&clk_default, "gpio.3"),
}; };
static int __init clk_init(void) static int __init clk_init(void)
......
...@@ -364,7 +364,8 @@ static DEFINE_PRCC_CLK(7, cfgreg_ed, 0, -1, NULL); ...@@ -364,7 +364,8 @@ static DEFINE_PRCC_CLK(7, cfgreg_ed, 0, -1, NULL);
static struct clk_lookup u8500_common_clks[] = { static struct clk_lookup u8500_common_clks[] = {
/* Peripheral Cluster #1 */ /* Peripheral Cluster #1 */
CLK(gpio0, "gpioblock0", NULL), CLK(gpio0, "gpio.0", NULL),
CLK(gpio0, "gpio.1", NULL),
CLK(slimbus0, "slimbus0", NULL), CLK(slimbus0, "slimbus0", NULL),
CLK(i2c2, "nmk-i2c.2", NULL), CLK(i2c2, "nmk-i2c.2", NULL),
CLK(sdi0, "sdi0", NULL), CLK(sdi0, "sdi0", NULL),
...@@ -374,7 +375,10 @@ static struct clk_lookup u8500_common_clks[] = { ...@@ -374,7 +375,10 @@ static struct clk_lookup u8500_common_clks[] = {
CLK(uart0, "uart0", NULL), CLK(uart0, "uart0", NULL),
/* Peripheral Cluster #3 */ /* Peripheral Cluster #3 */
CLK(gpio2, "gpioblock2", NULL), CLK(gpio2, "gpio.2", NULL),
CLK(gpio2, "gpio.3", NULL),
CLK(gpio2, "gpio.4", NULL),
CLK(gpio2, "gpio.5", NULL),
CLK(sdi5, "sdi5", NULL), CLK(sdi5, "sdi5", NULL),
CLK(uart2, "uart2", NULL), CLK(uart2, "uart2", NULL),
CLK(ske, "ske", NULL), CLK(ske, "ske", NULL),
...@@ -383,7 +387,7 @@ static struct clk_lookup u8500_common_clks[] = { ...@@ -383,7 +387,7 @@ static struct clk_lookup u8500_common_clks[] = {
CLK(fsmc, "fsmc", NULL), CLK(fsmc, "fsmc", NULL),
/* Peripheral Cluster #5 */ /* Peripheral Cluster #5 */
CLK(gpio3, "gpioblock3", NULL), CLK(gpio3, "gpio.8", NULL),
/* Peripheral Cluster #6 */ /* Peripheral Cluster #6 */
CLK(hash1, "hash1", NULL), CLK(hash1, "hash1", NULL),
...@@ -418,7 +422,8 @@ static struct clk_lookup u8500_ed_clks[] = { ...@@ -418,7 +422,8 @@ static struct clk_lookup u8500_ed_clks[] = {
CLK(msp1_ed, "msp1", NULL), CLK(msp1_ed, "msp1", NULL),
/* Peripheral Cluster #2 */ /* Peripheral Cluster #2 */
CLK(gpio1_ed, "gpioblock1", NULL), CLK(gpio1_ed, "gpio.6", NULL),
CLK(gpio1_ed, "gpio.7", NULL),
CLK(ssitx_ed, "ssitx", NULL), CLK(ssitx_ed, "ssitx", NULL),
CLK(ssirx_ed, "ssirx", NULL), CLK(ssirx_ed, "ssirx", NULL),
CLK(spi0_ed, "spi0", NULL), CLK(spi0_ed, "spi0", NULL),
...@@ -458,7 +463,8 @@ static struct clk_lookup u8500_v1_clks[] = { ...@@ -458,7 +463,8 @@ static struct clk_lookup u8500_v1_clks[] = {
CLK(msp1_v1, "msp1", NULL), CLK(msp1_v1, "msp1", NULL),
/* Peripheral Cluster #2 */ /* Peripheral Cluster #2 */
CLK(gpio1_v1, "gpioblock1", NULL), CLK(gpio1_v1, "gpio.6", NULL),
CLK(gpio1_v1, "gpio.7", NULL),
CLK(ssitx_v1, "ssitx", NULL), CLK(ssitx_v1, "ssitx", NULL),
CLK(ssirx_v1, "ssirx", NULL), CLK(ssirx_v1, "ssirx", NULL),
CLK(spi0_v1, "spi0", NULL), CLK(spi0_v1, "spi0", NULL),
......
...@@ -15,6 +15,8 @@ ...@@ -15,6 +15,8 @@
#include <linux/device.h> #include <linux/device.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/clk.h>
#include <linux/err.h>
#include <linux/gpio.h> #include <linux/gpio.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
...@@ -35,6 +37,7 @@ ...@@ -35,6 +37,7 @@
struct nmk_gpio_chip { struct nmk_gpio_chip {
struct gpio_chip chip; struct gpio_chip chip;
void __iomem *addr; void __iomem *addr;
struct clk *clk;
unsigned int parent_irq; unsigned int parent_irq;
spinlock_t lock; spinlock_t lock;
/* Keep track of configured edges */ /* Keep track of configured edges */
...@@ -310,6 +313,7 @@ static int __init nmk_gpio_probe(struct platform_device *dev) ...@@ -310,6 +313,7 @@ static int __init nmk_gpio_probe(struct platform_device *dev)
struct nmk_gpio_chip *nmk_chip; struct nmk_gpio_chip *nmk_chip;
struct gpio_chip *chip; struct gpio_chip *chip;
struct resource *res; struct resource *res;
struct clk *clk;
int irq; int irq;
int ret; int ret;
...@@ -334,15 +338,24 @@ static int __init nmk_gpio_probe(struct platform_device *dev) ...@@ -334,15 +338,24 @@ static int __init nmk_gpio_probe(struct platform_device *dev)
goto out; goto out;
} }
clk = clk_get(&dev->dev, NULL);
if (IS_ERR(clk)) {
ret = PTR_ERR(clk);
goto out_release;
}
clk_enable(clk);
nmk_chip = kzalloc(sizeof(*nmk_chip), GFP_KERNEL); nmk_chip = kzalloc(sizeof(*nmk_chip), GFP_KERNEL);
if (!nmk_chip) { if (!nmk_chip) {
ret = -ENOMEM; ret = -ENOMEM;
goto out_release; goto out_clk;
} }
/* /*
* The virt address in nmk_chip->addr is in the nomadik register space, * The virt address in nmk_chip->addr is in the nomadik register space,
* so we can simply convert the resource address, without remapping * so we can simply convert the resource address, without remapping
*/ */
nmk_chip->clk = clk;
nmk_chip->addr = io_p2v(res->start); nmk_chip->addr = io_p2v(res->start);
nmk_chip->chip = nmk_gpio_template; nmk_chip->chip = nmk_gpio_template;
nmk_chip->parent_irq = irq; nmk_chip->parent_irq = irq;
...@@ -368,6 +381,9 @@ static int __init nmk_gpio_probe(struct platform_device *dev) ...@@ -368,6 +381,9 @@ static int __init nmk_gpio_probe(struct platform_device *dev)
out_free: out_free:
kfree(nmk_chip); kfree(nmk_chip);
out_clk:
clk_disable(clk);
clk_put(clk);
out_release: out_release:
release_mem_region(res->start, resource_size(res)); release_mem_region(res->start, resource_size(res));
out: out:
...@@ -385,6 +401,8 @@ static int __exit nmk_gpio_remove(struct platform_device *dev) ...@@ -385,6 +401,8 @@ static int __exit nmk_gpio_remove(struct platform_device *dev)
nmk_chip = platform_get_drvdata(dev); nmk_chip = platform_get_drvdata(dev);
gpiochip_remove(&nmk_chip->chip); gpiochip_remove(&nmk_chip->chip);
clk_disable(nmk_chip->clk);
clk_put(nmk_chip->clk);
kfree(nmk_chip); kfree(nmk_chip);
release_mem_region(res->start, resource_size(res)); release_mem_region(res->start, resource_size(res));
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment