rtc-parisc.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /* rtc-parisc: RTC for HP PA-RISC firmware
  2. *
  3. * Copyright (C) 2008 Kyle McMartin <kyle@mcmartin.ca>
  4. */
  5. #include <linux/kernel.h>
  6. #include <linux/module.h>
  7. #include <linux/time.h>
  8. #include <linux/platform_device.h>
  9. #include <linux/rtc.h>
  10. #include <asm/rtc.h>
  11. static int parisc_get_time(struct device *dev, struct rtc_time *tm)
  12. {
  13. unsigned long ret;
  14. ret = get_rtc_time(tm);
  15. if (ret & RTC_BATT_BAD)
  16. return -EOPNOTSUPP;
  17. return rtc_valid_tm(tm);
  18. }
  19. static int parisc_set_time(struct device *dev, struct rtc_time *tm)
  20. {
  21. if (set_rtc_time(tm) < 0)
  22. return -EOPNOTSUPP;
  23. return 0;
  24. }
  25. static const struct rtc_class_ops parisc_rtc_ops = {
  26. .read_time = parisc_get_time,
  27. .set_time = parisc_set_time,
  28. };
  29. static int __init parisc_rtc_probe(struct platform_device *dev)
  30. {
  31. struct rtc_device *rtc;
  32. rtc = rtc_device_register("rtc-parisc", &dev->dev, &parisc_rtc_ops,
  33. THIS_MODULE);
  34. if (IS_ERR(rtc))
  35. return PTR_ERR(rtc);
  36. platform_set_drvdata(dev, rtc);
  37. return 0;
  38. }
  39. static int __exit parisc_rtc_remove(struct platform_device *dev)
  40. {
  41. struct rtc_device *rtc = platform_get_drvdata(dev);
  42. rtc_device_unregister(rtc);
  43. return 0;
  44. }
  45. static struct platform_driver parisc_rtc_driver = {
  46. .driver = {
  47. .name = "rtc-parisc",
  48. .owner = THIS_MODULE,
  49. },
  50. .probe = parisc_rtc_probe,
  51. .remove = __devexit_p(parisc_rtc_remove),
  52. };
  53. static int __init parisc_rtc_init(void)
  54. {
  55. return platform_driver_probe(&parisc_rtc_driver, parisc_rtc_probe);
  56. }
  57. static void __exit parisc_rtc_fini(void)
  58. {
  59. platform_driver_unregister(&parisc_rtc_driver);
  60. }
  61. module_init(parisc_rtc_init);
  62. module_exit(parisc_rtc_fini);
  63. MODULE_AUTHOR("Kyle McMartin <kyle@mcmartin.ca>");
  64. MODULE_LICENSE("GPL");
  65. MODULE_DESCRIPTION("HP PA-RISC RTC driver");