public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [Q] Is 64bit LVTT screwed
@ 2008-07-02 18:40 Cyrill Gorcunov
  2008-07-07 22:08 ` Maciej W. Rozycki
  0 siblings, 1 reply; 4+ messages in thread
From: Cyrill Gorcunov @ 2008-07-02 18:40 UTC (permalink / raw)
  To: Maciej W. Rozycki; +Cc: LKML

Hi Maciej,

while I'm in path of unification apic code I found a bit
strange code snippet

apic_32.c
---------
#define APIC_DIVISOR 16
static void __setup_APIC_LVTT(unsigned int clocks, int oneshot, int irqen)
{
	...
	if (!oneshot)
		apic_write_around(APIC_TMICT, clocks / APIC_DIVISOR);

}

apic_64.c
---------
static void __setup_APIC_LVTT(unsigned int clocks, int oneshot, int irqen)
{
        ...
	if (!oneshot)
		apic_write_around(APIC_TMICT, clocks);
}

but in both cases we use "divide by 16" in divide register. The only
explanation I imagine - for 64bit mode we are required to 'stuck'
for a bit longer (by 16 times longer to be precise). Am I right?
Or there is another reason why we dont use APIC_DIVISOR here. Actually,
as I see it not fair to a caller. For 64bit mode APIC timer is requested
to count 250000000 ticks but in real it will count 250000000 * 16.
Not sure who is right there. I think the better would be to
use 4000000000 and APIC_DIVISOR in 64bit mode. How do you think?

		- Cyrill -

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2008-07-08 19:10 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-07-02 18:40 [Q] Is 64bit LVTT screwed Cyrill Gorcunov
2008-07-07 22:08 ` Maciej W. Rozycki
2008-07-08 11:38   ` Cyrill Gorcunov
2008-07-08 19:09   ` Cyrill Gorcunov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox