diff options
-rw-r--r-- | arch/arm/mach-nomadik/clock.c | 10 | ||||
-rw-r--r-- | arch/arm/mach-ux500/clock.c | 16 | ||||
-rw-r--r-- | arch/arm/plat-nomadik/gpio.c | 20 |
3 files changed, 40 insertions, 6 deletions
diff --git a/arch/arm/mach-nomadik/clock.c b/arch/arm/mach-nomadik/clock.c index 7af785017782..60f5bee09f2e 100644 --- a/arch/arm/mach-nomadik/clock.c +++ b/arch/arm/mach-nomadik/clock.c | |||
@@ -37,6 +37,12 @@ static struct clk clk_48 = { | |||
37 | .rate = 48 * 1000 * 1000, | 37 | .rate = 48 * 1000 * 1000, |
38 | }; | 38 | }; |
39 | 39 | ||
40 | /* | ||
41 | * Catch-all default clock to satisfy drivers using the clk API. We don't | ||
42 | * model the actual hardware clocks yet. | ||
43 | */ | ||
44 | static struct clk clk_default; | ||
45 | |||
40 | #define CLK(_clk, dev) \ | 46 | #define CLK(_clk, dev) \ |
41 | { \ | 47 | { \ |
42 | .clk = _clk, \ | 48 | .clk = _clk, \ |
@@ -46,6 +52,10 @@ static struct clk clk_48 = { | |||
46 | static struct clk_lookup lookups[] = { | 52 | static struct clk_lookup lookups[] = { |
47 | CLK(&clk_48, "uart0"), | 53 | CLK(&clk_48, "uart0"), |
48 | CLK(&clk_48, "uart1"), | 54 | CLK(&clk_48, "uart1"), |
55 | CLK(&clk_default, "gpio.0"), | ||
56 | CLK(&clk_default, "gpio.1"), | ||
57 | CLK(&clk_default, "gpio.2"), | ||
58 | CLK(&clk_default, "gpio.3"), | ||
49 | }; | 59 | }; |
50 | 60 | ||
51 | static int __init clk_init(void) | 61 | static int __init clk_init(void) |
diff --git a/arch/arm/mach-ux500/clock.c b/arch/arm/mach-ux500/clock.c index c325dad1679c..1b2c9890e8b4 100644 --- a/arch/arm/mach-ux500/clock.c +++ b/arch/arm/mach-ux500/clock.c | |||
@@ -364,7 +364,8 @@ static DEFINE_PRCC_CLK(7, cfgreg_ed, 0, -1, NULL); | |||
364 | 364 | ||
365 | static struct clk_lookup u8500_common_clks[] = { | 365 | static struct clk_lookup u8500_common_clks[] = { |
366 | /* Peripheral Cluster #1 */ | 366 | /* Peripheral Cluster #1 */ |
367 | CLK(gpio0, "gpioblock0", NULL), | 367 | CLK(gpio0, "gpio.0", NULL), |
368 | CLK(gpio0, "gpio.1", NULL), | ||
368 | CLK(slimbus0, "slimbus0", NULL), | 369 | CLK(slimbus0, "slimbus0", NULL), |
369 | CLK(i2c2, "nmk-i2c.2", NULL), | 370 | CLK(i2c2, "nmk-i2c.2", NULL), |
370 | CLK(sdi0, "sdi0", NULL), | 371 | CLK(sdi0, "sdi0", NULL), |
@@ -374,7 +375,10 @@ static struct clk_lookup u8500_common_clks[] = { | |||
374 | CLK(uart0, "uart0", NULL), | 375 | CLK(uart0, "uart0", NULL), |
375 | 376 | ||
376 | /* Peripheral Cluster #3 */ | 377 | /* Peripheral Cluster #3 */ |
377 | CLK(gpio2, "gpioblock2", NULL), | 378 | CLK(gpio2, "gpio.2", NULL), |
379 | CLK(gpio2, "gpio.3", NULL), | ||
380 | CLK(gpio2, "gpio.4", NULL), | ||
381 | CLK(gpio2, "gpio.5", NULL), | ||
378 | CLK(sdi5, "sdi5", NULL), | 382 | CLK(sdi5, "sdi5", NULL), |
379 | CLK(uart2, "uart2", NULL), | 383 | CLK(uart2, "uart2", NULL), |
380 | CLK(ske, "ske", NULL), | 384 | CLK(ske, "ske", NULL), |
@@ -383,7 +387,7 @@ static struct clk_lookup u8500_common_clks[] = { | |||
383 | CLK(fsmc, "fsmc", NULL), | 387 | CLK(fsmc, "fsmc", NULL), |
384 | 388 | ||
385 | /* Peripheral Cluster #5 */ | 389 | /* Peripheral Cluster #5 */ |
386 | CLK(gpio3, "gpioblock3", NULL), | 390 | CLK(gpio3, "gpio.8", NULL), |
387 | 391 | ||
388 | /* Peripheral Cluster #6 */ | 392 | /* Peripheral Cluster #6 */ |
389 | CLK(hash1, "hash1", NULL), | 393 | CLK(hash1, "hash1", NULL), |
@@ -418,7 +422,8 @@ static struct clk_lookup u8500_ed_clks[] = { | |||
418 | CLK(msp1_ed, "msp1", NULL), | 422 | CLK(msp1_ed, "msp1", NULL), |
419 | 423 | ||
420 | /* Peripheral Cluster #2 */ | 424 | /* Peripheral Cluster #2 */ |
421 | CLK(gpio1_ed, "gpioblock1", NULL), | 425 | CLK(gpio1_ed, "gpio.6", NULL), |
426 | CLK(gpio1_ed, "gpio.7", NULL), | ||
422 | CLK(ssitx_ed, "ssitx", NULL), | 427 | CLK(ssitx_ed, "ssitx", NULL), |
423 | CLK(ssirx_ed, "ssirx", NULL), | 428 | CLK(ssirx_ed, "ssirx", NULL), |
424 | CLK(spi0_ed, "spi0", NULL), | 429 | CLK(spi0_ed, "spi0", NULL), |
@@ -458,7 +463,8 @@ static struct clk_lookup u8500_v1_clks[] = { | |||
458 | CLK(msp1_v1, "msp1", NULL), | 463 | CLK(msp1_v1, "msp1", NULL), |
459 | 464 | ||
460 | /* Peripheral Cluster #2 */ | 465 | /* Peripheral Cluster #2 */ |
461 | CLK(gpio1_v1, "gpioblock1", NULL), | 466 | CLK(gpio1_v1, "gpio.6", NULL), |
467 | CLK(gpio1_v1, "gpio.7", NULL), | ||
462 | CLK(ssitx_v1, "ssitx", NULL), | 468 | CLK(ssitx_v1, "ssitx", NULL), |
463 | CLK(ssirx_v1, "ssirx", NULL), | 469 | CLK(ssirx_v1, "ssirx", NULL), |
464 | CLK(spi0_v1, "spi0", NULL), | 470 | CLK(spi0_v1, "spi0", NULL), |
diff --git a/arch/arm/plat-nomadik/gpio.c b/arch/arm/plat-nomadik/gpio.c index eac9c9a7fbf9..d28900cfa541 100644 --- a/arch/arm/plat-nomadik/gpio.c +++ b/arch/arm/plat-nomadik/gpio.c | |||
@@ -15,6 +15,8 @@ | |||
15 | #include <linux/device.h> | 15 | #include <linux/device.h> |
16 | #include <linux/platform_device.h> | 16 | #include <linux/platform_device.h> |
17 | #include <linux/io.h> | 17 | #include <linux/io.h> |
18 | #include <linux/clk.h> | ||
19 | #include <linux/err.h> | ||
18 | #include <linux/gpio.h> | 20 | #include <linux/gpio.h> |
19 | #include <linux/spinlock.h> | 21 | #include <linux/spinlock.h> |
20 | #include <linux/interrupt.h> | 22 | #include <linux/interrupt.h> |
@@ -35,6 +37,7 @@ | |||
35 | struct nmk_gpio_chip { | 37 | struct nmk_gpio_chip { |
36 | struct gpio_chip chip; | 38 | struct gpio_chip chip; |
37 | void __iomem *addr; | 39 | void __iomem *addr; |
40 | struct clk *clk; | ||
38 | unsigned int parent_irq; | 41 | unsigned int parent_irq; |
39 | spinlock_t lock; | 42 | spinlock_t lock; |
40 | /* Keep track of configured edges */ | 43 | /* Keep track of configured edges */ |
@@ -310,6 +313,7 @@ static int __init nmk_gpio_probe(struct platform_device *dev) | |||
310 | struct nmk_gpio_chip *nmk_chip; | 313 | struct nmk_gpio_chip *nmk_chip; |
311 | struct gpio_chip *chip; | 314 | struct gpio_chip *chip; |
312 | struct resource *res; | 315 | struct resource *res; |
316 | struct clk *clk; | ||
313 | int irq; | 317 | int irq; |
314 | int ret; | 318 | int ret; |
315 | 319 | ||
@@ -334,15 +338,24 @@ static int __init nmk_gpio_probe(struct platform_device *dev) | |||
334 | goto out; | 338 | goto out; |
335 | } | 339 | } |
336 | 340 | ||
341 | clk = clk_get(&dev->dev, NULL); | ||
342 | if (IS_ERR(clk)) { | ||
343 | ret = PTR_ERR(clk); | ||
344 | goto out_release; | ||
345 | } | ||
346 | |||
347 | clk_enable(clk); | ||
348 | |||
337 | nmk_chip = kzalloc(sizeof(*nmk_chip), GFP_KERNEL); | 349 | nmk_chip = kzalloc(sizeof(*nmk_chip), GFP_KERNEL); |
338 | if (!nmk_chip) { | 350 | if (!nmk_chip) { |
339 | ret = -ENOMEM; | 351 | ret = -ENOMEM; |
340 | goto out_release; | 352 | goto out_clk; |
341 | } | 353 | } |
342 | /* | 354 | /* |
343 | * The virt address in nmk_chip->addr is in the nomadik register space, | 355 | * The virt address in nmk_chip->addr is in the nomadik register space, |
344 | * so we can simply convert the resource address, without remapping | 356 | * so we can simply convert the resource address, without remapping |
345 | */ | 357 | */ |
358 | nmk_chip->clk = clk; | ||
346 | nmk_chip->addr = io_p2v(res->start); | 359 | nmk_chip->addr = io_p2v(res->start); |
347 | nmk_chip->chip = nmk_gpio_template; | 360 | nmk_chip->chip = nmk_gpio_template; |
348 | nmk_chip->parent_irq = irq; | 361 | nmk_chip->parent_irq = irq; |
@@ -368,6 +381,9 @@ static int __init nmk_gpio_probe(struct platform_device *dev) | |||
368 | 381 | ||
369 | out_free: | 382 | out_free: |
370 | kfree(nmk_chip); | 383 | kfree(nmk_chip); |
384 | out_clk: | ||
385 | clk_disable(clk); | ||
386 | clk_put(clk); | ||
371 | out_release: | 387 | out_release: |
372 | release_mem_region(res->start, resource_size(res)); | 388 | release_mem_region(res->start, resource_size(res)); |
373 | out: | 389 | out: |
@@ -385,6 +401,8 @@ static int __exit nmk_gpio_remove(struct platform_device *dev) | |||
385 | 401 | ||
386 | nmk_chip = platform_get_drvdata(dev); | 402 | nmk_chip = platform_get_drvdata(dev); |
387 | gpiochip_remove(&nmk_chip->chip); | 403 | gpiochip_remove(&nmk_chip->chip); |
404 | clk_disable(nmk_chip->clk); | ||
405 | clk_put(nmk_chip->clk); | ||
388 | kfree(nmk_chip); | 406 | kfree(nmk_chip); |
389 | release_mem_region(res->start, resource_size(res)); | 407 | release_mem_region(res->start, resource_size(res)); |
390 | return 0; | 408 | return 0; |