sys_clock/microkernel: do not announce ticks until microkernel is up
This is a prologue to reverting:
commit 3c66686
Author: Benjamin Walsh <benjamin.walsh@windriver.com>
Date: Tue Feb 9 17:34:02 2016 -0500
sys_clock: start the microkernel ticker in the MICROKERNEL init level
to allow the devices initializing in pre-MICROKERNEL init levels to poll
the hi-res clock (sys_cycle_get_32()), which relies on the system clock
having been started.
This change allows starting the system clock in the NANOKERNEL init
level by delaying announcing the ticks until the MICROKERNEL init level.
Change-Id: I43d54bb5e2f182d4edd880da0124a0817f911943
Signed-off-by: Benjamin Walsh <benjamin.walsh@windriver.com>
This commit is contained in:
parent
974c88513c
commit
038790a945
|
@ -60,8 +60,9 @@ extern uint32_t _nano_get_earliest_deadline(void);
|
||||||
extern void _nano_sys_clock_tick_announce(int32_t ticks);
|
extern void _nano_sys_clock_tick_announce(int32_t ticks);
|
||||||
|
|
||||||
#ifdef CONFIG_MICROKERNEL
|
#ifdef CONFIG_MICROKERNEL
|
||||||
|
extern void (*_do_sys_clock_tick_announce)(kevent_t);
|
||||||
#define _sys_clock_tick_announce() \
|
#define _sys_clock_tick_announce() \
|
||||||
isr_event_send(TICK_EVENT)
|
_do_sys_clock_tick_announce(TICK_EVENT)
|
||||||
#else
|
#else
|
||||||
extern int32_t _sys_idle_elapsed_ticks;
|
extern int32_t _sys_idle_elapsed_ticks;
|
||||||
#define _sys_clock_tick_announce() \
|
#define _sys_clock_tick_announce() \
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
#include <microkernel/ticks.h>
|
#include <microkernel/ticks.h>
|
||||||
#include <toolchain.h>
|
#include <toolchain.h>
|
||||||
#include <sections.h>
|
#include <sections.h>
|
||||||
|
#include <init.h>
|
||||||
|
|
||||||
#ifdef CONFIG_TIMESLICING
|
#ifdef CONFIG_TIMESLICING
|
||||||
static int32_t slice_count = (int32_t)0;
|
static int32_t slice_count = (int32_t)0;
|
||||||
|
@ -146,6 +147,26 @@ int _k_ticker(int event)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_SYS_CLOCK_EXISTS
|
||||||
|
static void _sys_clock_tick_announce_pre_micro_nop(kevent_t e)
|
||||||
|
{
|
||||||
|
ARG_UNUSED(e);
|
||||||
|
/* do nothing */
|
||||||
|
}
|
||||||
|
|
||||||
|
void (*_do_sys_clock_tick_announce)(kevent_t) =
|
||||||
|
_sys_clock_tick_announce_pre_micro_nop;
|
||||||
|
|
||||||
|
static int _sys_clock_tick_announce_install(struct device *dev)
|
||||||
|
{
|
||||||
|
ARG_UNUSED(dev);
|
||||||
|
_do_sys_clock_tick_announce = isr_event_send;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
SYS_INIT(_sys_clock_tick_announce_install, MICROKERNEL, 0);
|
||||||
|
#endif /* CONFIG_SYS_CLOCK_EXISTS */
|
||||||
|
|
||||||
#ifdef CONFIG_TIMESLICING
|
#ifdef CONFIG_TIMESLICING
|
||||||
|
|
||||||
void sys_scheduler_time_slice_set(int32_t t, kpriority_t p)
|
void sys_scheduler_time_slice_set(int32_t t, kpriority_t p)
|
||||||
|
|
Loading…
Reference in a new issue