commit f94d41db30d6430bc6d3e53602258d3933f93103
Author: Jeff Garzik <[EMAIL PROTECTED]>
Date:   Sun Oct 21 01:51:50 2007 -0400

    RTC interrupt handling cleanups
    
    arm/mach-integrator/time: arm_rtc_interrupt() never uses its arguments,
    so pass NULL to make this explicit and potentially reduce future
    confusion.
    
    hpet.c and rtc.c: pass rtc_int_flag through the standard data-passing
    mechanism, dev_id (2nd arg).
    
    rtc-at32ap700x, rtc-m48t59.c: delete pointless cast from void*
    
    rtc-bfin: calling spin_lock_irq() in interrupt handler marked
    IRQF_DISABLED is unwise.  Use safer spin_lock_irqsave() instead.
    
    Signed-off-by: Jeff Garzik <[EMAIL PROTECTED]>

 arch/arm/mach-integrator/time.c |    2 +-
 arch/x86/kernel/hpet.c          |    4 ++--
 drivers/char/rtc.c              |    7 ++++---
 drivers/rtc/rtc-at32ap700x.c    |    2 +-
 drivers/rtc/rtc-bfin.c          |    5 +++--
 drivers/rtc/rtc-m48t59.c        |    2 +-
 6 files changed, 12 insertions(+), 10 deletions(-)

f94d41db30d6430bc6d3e53602258d3933f93103
diff --git a/arch/arm/mach-integrator/time.c b/arch/arm/mach-integrator/time.c
index 5278f58..5235f64 100644
--- a/arch/arm/mach-integrator/time.c
+++ b/arch/arm/mach-integrator/time.c
@@ -125,7 +125,7 @@ static int rtc_probe(struct amba_device *dev, void *id)
        xtime.tv_sec = __raw_readl(rtc_base + RTC_DR);
 
        ret = request_irq(dev->irq[0], arm_rtc_interrupt, IRQF_DISABLED,
-                         "rtc-pl030", dev);
+                         "rtc-pl030", NULL);
        if (ret)
                goto map_out;
 
diff --git a/arch/x86/kernel/hpet.c b/arch/x86/kernel/hpet.c
index 53303f2..7c07653 100644
--- a/arch/x86/kernel/hpet.c
+++ b/arch/x86/kernel/hpet.c
@@ -621,7 +621,7 @@ static void hpet_rtc_timer_reinit(void)
        }
 }
 
-irqreturn_t hpet_rtc_interrupt(int irq, void *dev_id)
+irqreturn_t hpet_rtc_interrupt(int dummy, void *dev_id)
 {
        struct rtc_time curr_time;
        unsigned long rtc_int_flag = 0;
@@ -651,7 +651,7 @@ irqreturn_t hpet_rtc_interrupt(int irq, void *dev_id)
 
        if (rtc_int_flag) {
                rtc_int_flag |= (RTC_IRQF | (RTC_NUM_INTS << 8));
-               rtc_interrupt(rtc_int_flag, dev_id);
+               rtc_interrupt(-1, (void *) rtc_int_flag);
        }
        return IRQ_HANDLED;
 }
diff --git a/drivers/char/rtc.c b/drivers/char/rtc.c
index ec6b65e..533328b 100644
--- a/drivers/char/rtc.c
+++ b/drivers/char/rtc.c
@@ -233,7 +233,7 @@ static inline unsigned char rtc_is_updating(void)
  *     (See ./arch/XXXX/kernel/time.c for the set_rtc_mmss() function.)
  */
 
-irqreturn_t rtc_interrupt(int irq, void *dev_id)
+irqreturn_t rtc_interrupt(int dummy, void *dev_id)
 {
        /*
         *      Can be an alarm interrupt, update complete interrupt,
@@ -246,12 +246,13 @@ irqreturn_t rtc_interrupt(int irq, void *dev_id)
        rtc_irq_data += 0x100;
        rtc_irq_data &= ~0xff;
        if (is_hpet_enabled()) {
+               unsigned long val = (unsigned long) dev_id;
                /*
                 * In this case it is HPET RTC interrupt handler
                 * calling us, with the interrupt information
-                * passed as arg1, instead of irq.
+                * passed as arg2 (dev_id)
                 */
-               rtc_irq_data |= (unsigned long)irq & 0xF0;
+               rtc_irq_data |= val & 0xF0;
        } else {
                rtc_irq_data |= (CMOS_READ(RTC_INTR_FLAGS) & 0xF0);
        }
diff --git a/drivers/rtc/rtc-at32ap700x.c b/drivers/rtc/rtc-at32ap700x.c
index 2999214..2c1890f 100644
--- a/drivers/rtc/rtc-at32ap700x.c
+++ b/drivers/rtc/rtc-at32ap700x.c
@@ -167,7 +167,7 @@ static int at32_rtc_ioctl(struct device *dev, unsigned int 
cmd,
 
 static irqreturn_t at32_rtc_interrupt(int irq, void *dev_id)
 {
-       struct rtc_at32ap700x *rtc = (struct rtc_at32ap700x *)dev_id;
+       struct rtc_at32ap700x *rtc = dev_id;
        unsigned long isr = rtc_readl(rtc, ISR);
        unsigned long events = 0;
        int ret = IRQ_NONE;
diff --git a/drivers/rtc/rtc-bfin.c b/drivers/rtc/rtc-bfin.c
index 1aa709d..5afd24c 100644
--- a/drivers/rtc/rtc-bfin.c
+++ b/drivers/rtc/rtc-bfin.c
@@ -143,10 +143,11 @@ static irqreturn_t bfin_rtc_interrupt(int irq, void 
*dev_id)
        struct bfin_rtc *rtc = platform_get_drvdata(pdev);
        unsigned long events = 0;
        u16 rtc_istat;
+       unsigned long flags;
 
        stampit();
 
-       spin_lock_irq(&rtc->lock);
+       spin_lock_irqsave(&rtc->lock, flags);
 
        rtc_istat = bfin_read_RTC_ISTAT();
 
@@ -168,7 +169,7 @@ static irqreturn_t bfin_rtc_interrupt(int irq, void *dev_id)
 
        rtc_update_irq(rtc->rtc_dev, 1, events);
 
-       spin_unlock_irq(&rtc->lock);
+       spin_unlock_irqrestore(&rtc->lock, flags);
 
        return IRQ_HANDLED;
 }
diff --git a/drivers/rtc/rtc-m48t59.c b/drivers/rtc/rtc-m48t59.c
index bf60d35..934405d 100644
--- a/drivers/rtc/rtc-m48t59.c
+++ b/drivers/rtc/rtc-m48t59.c
@@ -283,7 +283,7 @@ static int m48t59_rtc_proc(struct device *dev, struct 
seq_file *seq)
  */
 static irqreturn_t m48t59_rtc_interrupt(int irq, void *dev_id)
 {
-       struct device *dev = (struct device *)dev_id;
+       struct device *dev = dev_id;
        struct platform_device *pdev = to_platform_device(dev);
        struct m48t59_plat_data *pdata = pdev->dev.platform_data;
        struct m48t59_private *m48t59 = platform_get_drvdata(pdev);
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to