diff options
| author | Jeff Garzik <jeff@garzik.org> | 2006-03-20 04:38:03 -0500 | 
|---|---|---|
| committer | Jeff Garzik <jeff@garzik.org> | 2006-03-20 04:38:03 -0500 | 
| commit | d378aca6ec708bfb24df5c47801b1f2399efc481 (patch) | |
| tree | 7535f96bf34314df071698d2e06054b8d5223ebb /arch/mips/kernel/time.c | |
| parent | abc71c46dc0a12ab7fddc18cfe4f4aa26808c79b (diff) | |
| parent | 7705a8792b0fc82fd7d4dd923724606bbfd9fb20 (diff) | |
Merge branch 'master'
Diffstat (limited to 'arch/mips/kernel/time.c')
| -rw-r--r-- | arch/mips/kernel/time.c | 6 | 
1 files changed, 4 insertions, 2 deletions
| diff --git a/arch/mips/kernel/time.c b/arch/mips/kernel/time.c index 42c94c771afb..51273b7297a7 100644 --- a/arch/mips/kernel/time.c +++ b/arch/mips/kernel/time.c | |||
| @@ -424,6 +424,8 @@ irqreturn_t timer_interrupt(int irq, void *dev_id, struct pt_regs *regs) | |||
| 424 | unsigned long j; | 424 | unsigned long j; | 
| 425 | unsigned int count; | 425 | unsigned int count; | 
| 426 | 426 | ||
| 427 | write_seqlock(&xtime_lock); | ||
| 428 | |||
| 427 | count = mips_hpt_read(); | 429 | count = mips_hpt_read(); | 
| 428 | mips_timer_ack(); | 430 | mips_timer_ack(); | 
| 429 | 431 | ||
| @@ -441,7 +443,6 @@ irqreturn_t timer_interrupt(int irq, void *dev_id, struct pt_regs *regs) | |||
| 441 | * CMOS clock accordingly every ~11 minutes. rtc_set_time() has to be | 443 | * CMOS clock accordingly every ~11 minutes. rtc_set_time() has to be | 
| 442 | * called as close as possible to 500 ms before the new second starts. | 444 | * called as close as possible to 500 ms before the new second starts. | 
| 443 | */ | 445 | */ | 
| 444 | write_seqlock(&xtime_lock); | ||
| 445 | if (ntp_synced() && | 446 | if (ntp_synced() && | 
| 446 | xtime.tv_sec > last_rtc_update + 660 && | 447 | xtime.tv_sec > last_rtc_update + 660 && | 
| 447 | (xtime.tv_nsec / 1000) >= 500000 - ((unsigned) TICK_SIZE) / 2 && | 448 | (xtime.tv_nsec / 1000) >= 500000 - ((unsigned) TICK_SIZE) / 2 && | 
| @@ -453,7 +454,6 @@ irqreturn_t timer_interrupt(int irq, void *dev_id, struct pt_regs *regs) | |||
| 453 | last_rtc_update = xtime.tv_sec - 600; | 454 | last_rtc_update = xtime.tv_sec - 600; | 
| 454 | } | 455 | } | 
| 455 | } | 456 | } | 
| 456 | write_sequnlock(&xtime_lock); | ||
| 457 | 457 | ||
| 458 | /* | 458 | /* | 
| 459 | * If jiffies has overflown in this timer_interrupt, we must | 459 | * If jiffies has overflown in this timer_interrupt, we must | 
| @@ -496,6 +496,8 @@ irqreturn_t timer_interrupt(int irq, void *dev_id, struct pt_regs *regs) | |||
| 496 | } | 496 | } | 
| 497 | } | 497 | } | 
| 498 | 498 | ||
| 499 | write_sequnlock(&xtime_lock); | ||
| 500 | |||
| 499 | /* | 501 | /* | 
| 500 | * In UP mode, we call local_timer_interrupt() to do profiling | 502 | * In UP mode, we call local_timer_interrupt() to do profiling | 
| 501 | * and process accouting. | 503 | * and process accouting. | 
