]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
RTC: twl4030-rtc specific code
authorGirish <girishsg@ti.com>
Tue, 18 Dec 2007 07:29:06 +0000 (12:59 +0530)
committerTony Lindgren <tony@atomide.com>
Thu, 24 Jan 2008 22:26:49 +0000 (14:26 -0800)
This patch adds rtc-twl4030 driver specific code.

Signed-off-by: Girish S G <girishsg@ti.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
drivers/rtc/rtc-twl4030.c

index 4e8bc5b912e6c488e32e1cb40eae7aecb69b15be..b50de5fd376c0e78d4c2e8d0581312539f141d5f 100644 (file)
@@ -353,6 +353,26 @@ out:
        return ret;
 }
 
+/*
+ * We will just handle setting the frequency and make use the framework for
+ * reading the periodic interupts.
+ * @freq: Current periodic IRQ freq
+ */
+static int twl4030_rtc_irq_set_freq(struct device *dev, int freq)
+{
+       struct rtc_device *rtc = dev_get_drvdata(dev);
+
+       if (freq < 0 || freq > 3)
+               return -EINVAL;
+
+       rtc->irq_freq = freq;
+
+       /* set rtc irq freq to user defined value */
+       set_rtc_irq_bit(freq);
+
+       return 0;
+}
+
 #ifdef CONFIG_RTC_INTF_DEV
 
 static int twl4030_rtc_ioctl(struct device *dev, unsigned int cmd,
@@ -364,12 +384,18 @@ static int twl4030_rtc_ioctl(struct device *dev, unsigned int cmd,
                return twl4030_rtc_alarm_irq_set_state(dev, 0);
        case RTC_AIE_ON:
                return twl4030_rtc_alarm_irq_set_state(dev, 1);
+
        case RTC_UIE_OFF:
-               /* Mask ints from RTC updates.  */
+               /* Fall Through */
+       case RTC_PIE_OFF:
+               /* Mask ints from RTC updates.  */
                return twl4030_rtc_irq_set_state(dev, 0);
        case RTC_UIE_ON:
-               /* Allow ints for RTC updates.  */
+               /* Fall Through */
+       case RTC_PIE_ON:
+               /* Allow ints for RTC updates.  */
                return twl4030_rtc_irq_set_state(dev, 1);
+
        case RTC_EPOCH_READ:
                return put_user(epoch, (unsigned long *)arg);
        case RTC_EPOCH_SET:     
@@ -450,11 +476,12 @@ out:
 }
 
 static struct rtc_class_ops twl4030_rtc_ops = {
-       .ioctl = twl4030_rtc_ioctl,
-       .read_time = twl4030_rtc_read_time,
-       .set_time = twl4030_rtc_set_time,
-       .read_alarm = twl4030_rtc_read_alarm,
-       .set_alarm = twl4030_rtc_set_alarm,
+       .ioctl          = twl4030_rtc_ioctl,
+       .read_time      = twl4030_rtc_read_time,
+       .set_time       = twl4030_rtc_set_time,
+       .read_alarm     = twl4030_rtc_read_alarm,
+       .set_alarm      = twl4030_rtc_set_alarm,
+       .irq_set_freq   = twl4030_rtc_irq_set_freq,
 };
 
 static int __devinit twl4030_rtc_probe(struct platform_device *pdev)
@@ -480,6 +507,9 @@ static int __devinit twl4030_rtc_probe(struct platform_device *pdev)
 
        }
 
+       /* Set the irq freq to every second */
+       rtc->irq_freq = 0;
+
        platform_set_drvdata(pdev, rtc);
 
        ret = twl4030_rtc_read_u8(&rd_reg, REG_RTC_STATUS_REG);
@@ -571,6 +601,7 @@ static int __devexit twl4030_rtc_remove(struct platform_device *pdev)
                pdata->exit();
 
        rtc_device_unregister(rtc);
+       platform_set_drvdata(pdev, NULL);
        return 0;
 }