Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 17 Jul 2010 16:49:03 +0300
From:      Alexander Motin <mav@FreeBSD.org>
To:        "Jayachandran C." <c.jayachandran@gmail.com>
Cc:        Neel Natu <neel@freebsd.org>, freebsd-mips@freebsd.org
Subject:   Re: [RFC] Event timers on MIPS
Message-ID:  <4C41B4CF.6080409@FreeBSD.org>
In-Reply-To: <AANLkTilKYw4UqmfEee9zHGosEDzy4hiFob1d8R9jcB25@mail.gmail.com>
References:  <4C41A248.8090605@FreeBSD.org> <AANLkTilKYw4UqmfEee9zHGosEDzy4hiFob1d8R9jcB25@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
Jayachandran C. wrote:
> 2010/7/17 Alexander Motin <mav@freebsd.org>:
>> I've made a patch, updating MIPS timer code (except RMI) to utilize new
>> MI event timer infrastructure. I've successfully built QEMU and XLR
>> kernels with the patch. Unluckily I can't test how it works, unless
>> somebody teach me how to cook QEMU to run it. I also haven't ported RMI
>> timers drivers, as I am not sure how that hardware is intended to work.
>>
>> Patch for HEAD can be found here:
>> http://people.freebsd.org/~mav/timers_mips.patch
>>
>> Could somebody falimiar with MIPS review/test my patch and extend it to
>> RMI hardware?
> 
> XLR uses an on-chip PIC clock (running at 66MHz) for cpu 0 and
> count/compare clock (running at CPU freq) for the other CPUs, hope
> this is supported with the new code.

I suppose that one type of timers should run on all CPUs (either one
timer per CPU, or one timer for all of them + IPI for distribution).
Theoretically you can implement "single" per-CPU timer implemented in
different fashion for different CPUs, though I don't understand why it
is needed. If these timers are independent, I would register every of
them as-is: on-chip PIC clock as global timer (infrastructure will
automatically manage rebroadcasting it's events via IPIs) and per-CPU
comparators as another per-CPU timer. This give independent hardclock
and statclock for less aliased time accounting.

> Other than that, I should be able to merge the code into XLR specific
> rmi/tick.c rmi/clock.c, if it works on other MIPS platforms.

rmi/tick.c looks somewhat strange to me, registering timecounter with
the same "MIPS32" name, but with different meaning.

-- 
Alexander Motin



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4C41B4CF.6080409>