diff options
| author | Johan Hovold <johan@kernel.org> | 2014-12-10 18:52:43 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-12-10 20:41:13 -0500 |
| commit | 4390ce002b02f3ddea2dcd1850a45b332dfd8792 (patch) | |
| tree | 3b56995ed66dd996c066ecb2b49a0f036a6e3e02 /drivers/rtc | |
| parent | 437b37a66a224471b669e9d3c791e908e47e804d (diff) | |
rtc: omap: fix class-device registration
Make sure not to register the class device until after the device has
been configured.
Currently, the device is not fully configured (e.g. 24-hour mode) when
the class device is registered, something which involves driver
callbacks for example to read the current time.
Signed-off-by: Johan Hovold <johan@kernel.org>
Cc: Alessandro Zummo <a.zummo@towertech.it>
Cc: Tony Lindgren <tony@atomide.com>
Cc: Benot Cousson <bcousson@baylibre.com>
Cc: Lokesh Vutla <lokeshvutla@ti.com>
Cc: Guenter Roeck <linux@roeck-us.net>
Cc: Sekhar Nori <nsekhar@ti.com>
Cc: Tero Kristo <t-kristo@ti.com>
Cc: Keerthy J <j-keerthy@ti.com>
Tested-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/rtc')
| -rw-r--r-- | drivers/rtc/rtc-omap.c | 46 |
1 files changed, 23 insertions, 23 deletions
diff --git a/drivers/rtc/rtc-omap.c b/drivers/rtc/rtc-omap.c index 6b10db5a5702..813bed270867 100644 --- a/drivers/rtc/rtc-omap.c +++ b/drivers/rtc/rtc-omap.c | |||
| @@ -413,16 +413,6 @@ static int __init omap_rtc_probe(struct platform_device *pdev) | |||
| 413 | rtc_writel(KICK1_VALUE, OMAP_RTC_KICK1_REG); | 413 | rtc_writel(KICK1_VALUE, OMAP_RTC_KICK1_REG); |
| 414 | } | 414 | } |
| 415 | 415 | ||
| 416 | device_init_wakeup(&pdev->dev, true); | ||
| 417 | |||
| 418 | rtc = devm_rtc_device_register(&pdev->dev, pdev->name, | ||
| 419 | &omap_rtc_ops, THIS_MODULE); | ||
| 420 | if (IS_ERR(rtc)) { | ||
| 421 | ret = PTR_ERR(rtc); | ||
| 422 | goto err; | ||
| 423 | } | ||
| 424 | platform_set_drvdata(pdev, rtc); | ||
| 425 | |||
| 426 | /* | 416 | /* |
| 427 | * disable interrupts | 417 | * disable interrupts |
| 428 | * | 418 | * |
| @@ -446,19 +436,6 @@ static int __init omap_rtc_probe(struct platform_device *pdev) | |||
| 446 | if (reg & (u8) OMAP_RTC_STATUS_ALARM) | 436 | if (reg & (u8) OMAP_RTC_STATUS_ALARM) |
| 447 | rtc_write(OMAP_RTC_STATUS_ALARM, OMAP_RTC_STATUS_REG); | 437 | rtc_write(OMAP_RTC_STATUS_ALARM, OMAP_RTC_STATUS_REG); |
| 448 | 438 | ||
| 449 | /* handle periodic and alarm irqs */ | ||
| 450 | ret = devm_request_irq(&pdev->dev, omap_rtc_timer, rtc_irq, 0, | ||
| 451 | dev_name(&rtc->dev), rtc); | ||
| 452 | if (ret) | ||
| 453 | goto err; | ||
| 454 | |||
| 455 | if (omap_rtc_timer != omap_rtc_alarm) { | ||
| 456 | ret = devm_request_irq(&pdev->dev, omap_rtc_alarm, rtc_irq, 0, | ||
| 457 | dev_name(&rtc->dev), rtc); | ||
| 458 | if (ret) | ||
| 459 | goto err; | ||
| 460 | } | ||
| 461 | |||
| 462 | /* On boards with split power, RTC_ON_NOFF won't reset the RTC */ | 439 | /* On boards with split power, RTC_ON_NOFF won't reset the RTC */ |
| 463 | reg = rtc_read(OMAP_RTC_CTRL_REG); | 440 | reg = rtc_read(OMAP_RTC_CTRL_REG); |
| 464 | if (reg & (u8) OMAP_RTC_CTRL_STOP) | 441 | if (reg & (u8) OMAP_RTC_CTRL_STOP) |
| @@ -488,6 +465,29 @@ static int __init omap_rtc_probe(struct platform_device *pdev) | |||
| 488 | if (reg != new_ctrl) | 465 | if (reg != new_ctrl) |
| 489 | rtc_write(new_ctrl, OMAP_RTC_CTRL_REG); | 466 | rtc_write(new_ctrl, OMAP_RTC_CTRL_REG); |
| 490 | 467 | ||
| 468 | device_init_wakeup(&pdev->dev, true); | ||
| 469 | |||
| 470 | rtc = devm_rtc_device_register(&pdev->dev, pdev->name, | ||
| 471 | &omap_rtc_ops, THIS_MODULE); | ||
| 472 | if (IS_ERR(rtc)) { | ||
| 473 | ret = PTR_ERR(rtc); | ||
| 474 | goto err; | ||
| 475 | } | ||
| 476 | platform_set_drvdata(pdev, rtc); | ||
| 477 | |||
| 478 | /* handle periodic and alarm irqs */ | ||
| 479 | ret = devm_request_irq(&pdev->dev, omap_rtc_timer, rtc_irq, 0, | ||
| 480 | dev_name(&rtc->dev), rtc); | ||
| 481 | if (ret) | ||
| 482 | goto err; | ||
| 483 | |||
| 484 | if (omap_rtc_timer != omap_rtc_alarm) { | ||
| 485 | ret = devm_request_irq(&pdev->dev, omap_rtc_alarm, rtc_irq, 0, | ||
| 486 | dev_name(&rtc->dev), rtc); | ||
| 487 | if (ret) | ||
| 488 | goto err; | ||
| 489 | } | ||
| 490 | |||
| 491 | return 0; | 491 | return 0; |
| 492 | 492 | ||
| 493 | err: | 493 | err: |
