Date: Tue, 8 Nov 2005 10:18:51 -0500 From: John Baldwin <jhb@freebsd.org> To: Vaibhave Agarwal <vaibhave@cs.utah.edu> Cc: freebsd-net@freebsd.org, freebsd-acpi@freebsd.org, current@freebsd.org, Nate Lawson <nate@root.org> Subject: Re: Freebsd 6.0 doesnt detect local APIC on a Pentium 3 machine Message-ID: <200511081018.53452.jhb@freebsd.org> In-Reply-To: <Pine.LNX.4.61.0511071830570.4600@trust.cs.utah.edu> References: <20051027233636.GA39380@dmw.hopto.org> <200511071105.58729.jhb@freebsd.org> <Pine.LNX.4.61.0511071830570.4600@trust.cs.utah.edu>
next in thread | previous in thread | raw e-mail | index | archive | help
On Monday 07 November 2005 08:38 pm, Vaibhave Agarwal wrote: > On Mon, 7 Nov 2005, John Baldwin wrote: > > And even then it can't be used for any device interrupts since there > > aren't any I/O APICs. On a UP machine without I/O APICs, it's actually > > probably more optimal to just use irq0 and irq8 for clocks rather than > > the lapic timer anyway. The only real possible gain is the ability to > > use the profiling interrupt from the local APIC. > > I got access to the BIOS of the Pentium 3 machine I am using, but it has > no option to enable/disable the local APIC. Yes, I've not seen any BIOSen that do. > Joseph Koshy is right, Linux enables the local APIC timer while booting > up. I got the following in the bootup log of Linux 2.4 kernel on the same > machine. > > ------------------------- > Local APIC disabled by BIOS -- reenabling. > Found and enabled local APIC! > > Using local APIC timer interrupts. > calibrating APIC timer ... > ------------------------- Just because Linux does for UP doesn't mean it is more optimal for FreeBSD. :) On FreeBSD with the lapic timer you have 2 * hz interrupts per second. With the irq0/irq8 combo you have hz + stathz interrupts per second. The difference is 2000 vs 1128. Granted, the lapic timer interrupt handler doesn't have to talk to hardware out on the LPC bus.. > Though there is no I/O apic in the UP machines, but I only wanted to use > local APIC timer in the lapic_timer_oneshot() mode to schedule few timers > accurately. You can increase the rate of the rtc timer. We run it at profhz (1024) when profiling is enabled for example. -- John Baldwin <jhb@FreeBSD.org> <>< http://www.FreeBSD.org/~jhb/ "Power Users Use the Power to Serve" = http://www.FreeBSD.org
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200511081018.53452.jhb>