data:image/s3,"s3://crabby-images/d844d/d844d2a785b6170e0d4b9419df0c24eb3e280419" alt=""
Where does the seL4 microkernel actually get the timing information it needs to enforce scheduling decisions? I can imagine some sort of interrupt or I/O access is required to get it from the raw hardware. How does it get from the timing hardware to the scheduling code?
data:image/s3,"s3://crabby-images/e83bf/e83bfce53e2eb62935fdd88ec5b51fde8e4af545" alt=""
Hi Raymond, seL4 is controlling the timer device. In the current release version, scheduling is tick-based, i.e. there’s a periodic interrupt that feeds into the scheduler. We’re looking at a tick-less variant (also via timer interrupt), but that might be a while before it makes it into the release. Cheers, Gerwin
On 11 Nov 2015, at 9:19 am, Raymond Jennings <shentino@gmail.com> wrote:
Where does the seL4 microkernel actually get the timing information it needs to enforce scheduling decisions?
I can imagine some sort of interrupt or I/O access is required to get it from the raw hardware.
How does it get from the timing hardware to the scheduling code? _______________________________________________ Devel mailing list Devel@sel4.systems https://sel4.systems/lists/listinfo/devel
________________________________ The information in this e-mail may be confidential and subject to legal professional privilege and/or copyright. National ICT Australia Limited accepts no liability for any damage caused by this email or its attachments.
data:image/s3,"s3://crabby-images/a5a3e/a5a3e5f97999ec6177cf88d79c26ec85f6b13fb2" alt=""
If you look at the abstract spec starting at call_kernel in Syscall_A and working in towards timer_tick in Interrupt_A, you'll see that a timer interrupt results in a call to timer_tick which decrements the current thread's time slice and interacts with the scheduler through reschedule_required if the thread or domain time slice expires. You could investigate to see how closely the C code corresponds. On 11 November 2015 at 16:19, Raymond Jennings <shentino@gmail.com> wrote:
Where does the seL4 microkernel actually get the timing information it needs to enforce scheduling decisions?
I can imagine some sort of interrupt or I/O access is required to get it from the raw hardware.
How does it get from the timing hardware to the scheduling code?
_______________________________________________ Devel mailing list Devel@sel4.systems https://sel4.systems/lists/listinfo/devel
data:image/s3,"s3://crabby-images/d844d/d844d2a785b6170e0d4b9419df0c24eb3e280419" alt=""
So this basically means that the microkernel has its own driver code for the timing hardware? On Wed, Nov 11, 2015 at 1:05 AM, Harry Butterworth <heb1001@gmail.com> wrote:
If you look at the abstract spec starting at call_kernel in Syscall_A and working in towards timer_tick in Interrupt_A, you'll see that a timer interrupt results in a call to timer_tick which decrements the current thread's time slice and interacts with the scheduler through reschedule_required if the thread or domain time slice expires. You could investigate to see how closely the C code corresponds.
On 11 November 2015 at 16:19, Raymond Jennings <shentino@gmail.com> wrote:
Where does the seL4 microkernel actually get the timing information it needs to enforce scheduling decisions?
I can imagine some sort of interrupt or I/O access is required to get it from the raw hardware.
How does it get from the timing hardware to the scheduling code?
_______________________________________________ Devel mailing list Devel@sel4.systems https://sel4.systems/lists/listinfo/devel
data:image/s3,"s3://crabby-images/1b22b/1b22bdd177cb1c0859d5d7840cba78bf64d3030b" alt=""
On 12 Nov 2015, at 19:38 , Raymond Jennings <shentino@gmail.com<mailto:shentino@gmail.com>> wrote: So this basically means that the microkernel has its own driver code for the timing hardware? Yes. The microkernel has two drivers: the interrupt controller (needed to assign interrupts to handlers) and a timer (needed for preemption). When compiled for debugging there’s also a serial driver. Gernot ________________________________ The information in this e-mail may be confidential and subject to legal professional privilege and/or copyright. National ICT Australia Limited accepts no liability for any damage caused by this email or its attachments.
participants (4)
-
Gernot Heiser
-
Gerwin Klein
-
Harry Butterworth
-
Raymond Jennings