Blame view

drivers/rtc/rtc-generic.c 1.32 KB
3afe6d046   Geert Uytterhoeven   parisc: rtc: Rena...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
  /* rtc-generic: RTC driver using the generic RTC abstraction
   *
   * Copyright (C) 2008 Kyle McMartin <kyle@mcmartin.ca>
   */
  
  #include <linux/kernel.h>
  #include <linux/module.h>
  #include <linux/time.h>
  #include <linux/platform_device.h>
  #include <linux/rtc.h>
  
  #include <asm/rtc.h>
  
  static int generic_get_time(struct device *dev, struct rtc_time *tm)
  {
  	unsigned int ret = get_rtc_time(tm);
  
  	if (ret & RTC_BATT_BAD)
  		return -EOPNOTSUPP;
  
  	return rtc_valid_tm(tm);
  }
  
  static int generic_set_time(struct device *dev, struct rtc_time *tm)
  {
  	if (set_rtc_time(tm) < 0)
  		return -EOPNOTSUPP;
  
  	return 0;
  }
  
  static const struct rtc_class_ops generic_rtc_ops = {
  	.read_time = generic_get_time,
  	.set_time = generic_set_time,
  };
  
  static int __init generic_rtc_probe(struct platform_device *dev)
  {
  	struct rtc_device *rtc;
360fe134e   Jingoo Han   rtc: rtc-generic:...
40
41
  	rtc = devm_rtc_device_register(&dev->dev, "rtc-generic",
  					&generic_rtc_ops, THIS_MODULE);
3afe6d046   Geert Uytterhoeven   parisc: rtc: Rena...
42
43
44
45
46
47
48
  	if (IS_ERR(rtc))
  		return PTR_ERR(rtc);
  
  	platform_set_drvdata(dev, rtc);
  
  	return 0;
  }
3afe6d046   Geert Uytterhoeven   parisc: rtc: Rena...
49
50
51
52
53
  static struct platform_driver generic_rtc_driver = {
  	.driver = {
  		.name = "rtc-generic",
  		.owner = THIS_MODULE,
  	},
3afe6d046   Geert Uytterhoeven   parisc: rtc: Rena...
54
  };
a53f9a4ee   Jingoo Han   rtc: rtc-generic:...
55
  module_platform_driver_probe(generic_rtc_driver, generic_rtc_probe);
3afe6d046   Geert Uytterhoeven   parisc: rtc: Rena...
56
57
58
59
60
  
  MODULE_AUTHOR("Kyle McMartin <kyle@mcmartin.ca>");
  MODULE_LICENSE("GPL");
  MODULE_DESCRIPTION("Generic RTC driver");
  MODULE_ALIAS("platform:rtc-generic");