Merge branch 'timers/for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip

* 'timers/for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip:
  x86: add PCI ID for 6300ESB force hpet
  x86: add another PCI ID for ICH6 force-hpet
  kernel-paramaters: document pmtmr= command line option
  acpi_pm clccksource: fix printk format warning
  nohz: don't stop idle tick if softirqs are pending.
  pmtmr: allow command line override of ioport
  nohz: reduce jiffies polling overhead
  hrtimer: Remove unused variables in ktime_divns()
  hrtimer: remove warning in hres_timers_resume
  posix-timers: print RT watchdog message
This commit is contained in:
Linus Torvalds 2008-07-15 10:39:57 -07:00
commit da6e88f496
6 changed files with 38 additions and 5 deletions

View File

@ -1612,6 +1612,10 @@ and is between 256 and 4096 characters. It is defined in the file
Format: { parport<nr> | timid | 0 } Format: { parport<nr> | timid | 0 }
See also Documentation/parport.txt. See also Documentation/parport.txt.
pmtmr= [X86] Manual setup of pmtmr I/O Port.
Override pmtimer IOPort with a hex value.
e.g. pmtmr=0x508
pnpacpi= [ACPI] pnpacpi= [ACPI]
{ off } { off }

View File

@ -266,6 +266,8 @@ static void old_ich_force_enable_hpet_user(struct pci_dev *dev)
hpet_print_force_info(); hpet_print_force_info();
} }
DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB_1,
old_ich_force_enable_hpet_user);
DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_0, DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_0,
old_ich_force_enable_hpet_user); old_ich_force_enable_hpet_user);
DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_12, DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_12,

View File

@ -215,3 +215,22 @@ pm_good:
* but we still need to load before device_initcall * but we still need to load before device_initcall
*/ */
fs_initcall(init_acpi_pm_clocksource); fs_initcall(init_acpi_pm_clocksource);
/*
* Allow an override of the IOPort. Stupid BIOSes do not tell us about
* the PMTimer, but we might know where it is.
*/
static int __init parse_pmtmr(char *arg)
{
unsigned long base;
if (strict_strtoul(arg, 16, &base))
return -EINVAL;
printk(KERN_INFO "PMTMR IOPort override: 0x%04x -> 0x%04x\n",
(unsigned int)pmtmr_ioport, base);
pmtmr_ioport = base;
return 1;
}
__setup("pmtmr=", parse_pmtmr);

View File

@ -300,11 +300,10 @@ EXPORT_SYMBOL_GPL(ktime_sub_ns);
*/ */
u64 ktime_divns(const ktime_t kt, s64 div) u64 ktime_divns(const ktime_t kt, s64 div)
{ {
u64 dclc, inc, dns; u64 dclc;
int sft = 0; int sft = 0;
dclc = dns = ktime_to_ns(kt); dclc = ktime_to_ns(kt);
inc = div;
/* Make sure the divisor is less than 2^32: */ /* Make sure the divisor is less than 2^32: */
while (div >> 32) { while (div >> 32) {
sft++; sft++;
@ -632,8 +631,6 @@ void clock_was_set(void)
*/ */
void hres_timers_resume(void) void hres_timers_resume(void)
{ {
WARN_ON_ONCE(num_online_cpus() > 1);
/* Retrigger the CPU local events: */ /* Retrigger the CPU local events: */
retrigger_next_event(NULL); retrigger_next_event(NULL);
} }

View File

@ -1037,6 +1037,9 @@ static void check_thread_timers(struct task_struct *tsk,
sig->rlim[RLIMIT_RTTIME].rlim_cur += sig->rlim[RLIMIT_RTTIME].rlim_cur +=
USEC_PER_SEC; USEC_PER_SEC;
} }
printk(KERN_INFO
"RT Watchdog Timeout: %s[%d]\n",
tsk->comm, task_pid_nr(tsk));
__group_send_sig_info(SIGXCPU, SEND_SIG_PRIV, tsk); __group_send_sig_info(SIGXCPU, SEND_SIG_PRIV, tsk);
} }
} }

View File

@ -48,6 +48,13 @@ static void tick_do_update_jiffies64(ktime_t now)
unsigned long ticks = 0; unsigned long ticks = 0;
ktime_t delta; ktime_t delta;
/*
* Do a quick check without holding xtime_lock:
*/
delta = ktime_sub(now, last_jiffies_update);
if (delta.tv64 < tick_period.tv64)
return;
/* Reevalute with xtime_lock held */ /* Reevalute with xtime_lock held */
write_seqlock(&xtime_lock); write_seqlock(&xtime_lock);
@ -228,6 +235,7 @@ void tick_nohz_stop_sched_tick(void)
local_softirq_pending()); local_softirq_pending());
ratelimit++; ratelimit++;
} }
goto end;
} }
ts->idle_calls++; ts->idle_calls++;