svn commit: r184293 - in head/sys: amd64/amd64 i386/i386
Maxim Sobolev
sobomax at FreeBSD.org
Sun Oct 26 11:58:04 PDT 2008
Author: sobomax
Date: Sun Oct 26 18:58:04 2008
New Revision: 184293
URL: http://svn.freebsd.org/changeset/base/184293
Log:
Fix division by zero panic if kern.hz less than 32.
MFC after: 1 day
Modified:
head/sys/amd64/amd64/local_apic.c
head/sys/i386/i386/local_apic.c
Modified: head/sys/amd64/amd64/local_apic.c
==============================================================================
--- head/sys/amd64/amd64/local_apic.c Sun Oct 26 17:20:37 2008 (r184292)
+++ head/sys/amd64/amd64/local_apic.c Sun Oct 26 18:58:04 2008 (r184293)
@@ -401,7 +401,11 @@ lapic_setup_clock(void)
lapic_timer_hz = hz * 2;
else
lapic_timer_hz = hz * 4;
- stathz = lapic_timer_hz / (lapic_timer_hz / 128);
+ if (lapic_timer_hz < 128) {
+ stathz = 128;
+ } else {
+ stathz = lapic_timer_hz / (lapic_timer_hz / 128);
+ }
profhz = lapic_timer_hz;
lapic_timer_period = value / lapic_timer_hz;
Modified: head/sys/i386/i386/local_apic.c
==============================================================================
--- head/sys/i386/i386/local_apic.c Sun Oct 26 17:20:37 2008 (r184292)
+++ head/sys/i386/i386/local_apic.c Sun Oct 26 18:58:04 2008 (r184293)
@@ -403,7 +403,11 @@ lapic_setup_clock(void)
lapic_timer_hz = hz * 2;
else
lapic_timer_hz = hz * 4;
- stathz = lapic_timer_hz / (lapic_timer_hz / 128);
+ if (lapic_timer_hz < 128) {
+ stathz = 128;
+ } else {
+ stathz = lapic_timer_hz / (lapic_timer_hz / 128);
+ }
profhz = lapic_timer_hz;
lapic_timer_period = value / lapic_timer_hz;
More information about the svn-src-head
mailing list