rtc-parisc.c 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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 0;
  18. }
  19. static int parisc_set_time(struct device *dev, struct rtc_time *tm)
  20. {
  21. int ret;
  22. ret = set_rtc_time(tm);
  23. if (ret < 0)
  24. return -EOPNOTSUPP;
  25. return 0;
  26. }
  27. static const struct rtc_class_ops parisc_rtc_ops = {
  28. .read_time = parisc_get_time,
  29. .set_time = parisc_set_time,
  30. };
  31. static int __devinit parisc_rtc_probe(struct platform_device *dev)
  32. {
  33. struct rtc_device *p;
  34. p = kzalloc(sizeof (*p), GFP_KERNEL);
  35. if (!p)
  36. return -ENOMEM;
  37. p = rtc_device_register("rtc-parisc", &dev->dev, &parisc_rtc_ops,
  38. THIS_MODULE);
  39. if (IS_ERR(p)) {
  40. int err = PTR_ERR(p);
  41. kfree(p);
  42. return err;
  43. }
  44. platform_set_drvdata(dev, p);
  45. return 0;
  46. }
  47. static int __devexit parisc_rtc_remove(struct platform_device *dev)
  48. {
  49. struct rtc_device *p = platform_get_drvdata(dev);
  50. rtc_device_unregister(p);
  51. kfree(p);
  52. return 0;
  53. }
  54. static struct platform_driver parisc_rtc_driver = {
  55. .driver = {
  56. .name = "rtc-parisc",
  57. .owner = THIS_MODULE,
  58. },
  59. .probe = parisc_rtc_probe,
  60. .remove = __devexit_p(parisc_rtc_remove),
  61. };
  62. static int __init parisc_rtc_init(void)
  63. {
  64. return platform_driver_register(&parisc_rtc_driver);
  65. }
  66. static void __exit parisc_rtc_fini(void)
  67. {
  68. platform_driver_unregister(&parisc_rtc_driver);
  69. }
  70. module_init(parisc_rtc_init);
  71. module_exit(parisc_rtc_fini);
  72. MODULE_AUTHOR("Kyle McMartin <kyle@mcmartin.ca>");
  73. MODULE_LICENSE("GPL");
  74. MODULE_DESCRIPTION("HP PA-RISC RTC driver");