提交 e9c16503 编写于 作者: armink_ztl's avatar armink_ztl

[kernel][idle] Add idle hook list.

上级 60435316
...@@ -173,7 +173,8 @@ void rt_thread_inited_sethook (void (*hook)(rt_thread_t thread)); ...@@ -173,7 +173,8 @@ void rt_thread_inited_sethook (void (*hook)(rt_thread_t thread));
*/ */
void rt_thread_idle_init(void); void rt_thread_idle_init(void);
#if defined(RT_USING_HOOK) || defined(RT_USING_IDLE_HOOK) #if defined(RT_USING_HOOK) || defined(RT_USING_IDLE_HOOK)
void rt_thread_idle_sethook(void (*hook)(void)); rt_err_t rt_thread_idle_sethook(void (*hook)(void));
rt_err_t rt_thread_idle_delhook(void (*hook)(void));
#endif #endif
void rt_thread_idle_excute(void); void rt_thread_idle_excute(void);
rt_thread_t rt_thread_idle_gethandler(void); rt_thread_t rt_thread_idle_gethandler(void);
......
...@@ -75,6 +75,15 @@ config RT_USING_HOOK ...@@ -75,6 +75,15 @@ config RT_USING_HOOK
Enable the hook function when system running, such as idle thread hook, Enable the hook function when system running, such as idle thread hook,
thread context switch etc. thread context switch etc.
if RT_USING_HOOK
config RT_IDEL_HOOK_LIST_SIZE
int "The max size of idel hook list"
default 4
range 1 16
help
The system has a hook list. This is the hook list size.
endif
config IDLE_THREAD_STACK_SIZE config IDLE_THREAD_STACK_SIZE
int "The stack size of idle thread" int "The stack size of idle thread"
default 256 default 256
......
...@@ -52,7 +52,12 @@ static rt_uint8_t rt_thread_stack[IDLE_THREAD_STACK_SIZE]; ...@@ -52,7 +52,12 @@ static rt_uint8_t rt_thread_stack[IDLE_THREAD_STACK_SIZE];
extern rt_list_t rt_thread_defunct; extern rt_list_t rt_thread_defunct;
#ifdef RT_USING_IDLE_HOOK #ifdef RT_USING_IDLE_HOOK
static void (*rt_thread_idle_hook)();
#ifndef RT_IDEL_HOOK_LIST_SIZE
#define RT_IDEL_HOOK_LIST_SIZE 4
#endif
static void (*idle_hook_list[RT_IDEL_HOOK_LIST_SIZE])();
/** /**
* @ingroup Hook * @ingroup Hook
...@@ -61,12 +66,69 @@ static void (*rt_thread_idle_hook)(); ...@@ -61,12 +66,69 @@ static void (*rt_thread_idle_hook)();
* *
* @param hook the specified hook function * @param hook the specified hook function
* *
* @return RT_EOK: set OK
* -RT_EFULL: hook list is full
*
* @note the hook function must be simple and never be blocked or suspend. * @note the hook function must be simple and never be blocked or suspend.
*/ */
void rt_thread_idle_sethook(void (*hook)(void)) rt_err_t rt_thread_idle_sethook(void (*hook)(void))
{ {
rt_thread_idle_hook = hook; rt_size_t i;
rt_base_t level;
/* disable interrupt */
level = rt_hw_interrupt_disable();
for (i = 0; i < RT_IDEL_HOOK_LIST_SIZE; i++)
{
if (idle_hook_list[i] == RT_NULL)
{
idle_hook_list[i] = hook;
/* enable interrupt */
rt_hw_interrupt_enable(level);
return RT_EOK;
}
}
/* enable interrupt */
rt_hw_interrupt_enable(level);
return -RT_EFULL;
} }
/**
* delete the idle hook on hook list
*
* @param hook the specified hook function
*
* @return RT_EOK: delete OK
* -RT_ENOSYS: hook was not found
*/
rt_err_t rt_thread_idle_delhook(void (*hook)(void))
{
rt_size_t i;
rt_base_t level;
/* disable interrupt */
level = rt_hw_interrupt_disable();
for (i = 0; i < RT_IDEL_HOOK_LIST_SIZE; i++)
{
if (idle_hook_list[i] == hook)
{
idle_hook_list[i] = RT_NULL;
/* enable interrupt */
rt_hw_interrupt_enable(level);
return RT_EOK;
}
}
/* enable interrupt */
rt_hw_interrupt_enable(level);
return -RT_ENOSYS;
}
#endif #endif
/* Return whether there is defunctional thread to be deleted. */ /* Return whether there is defunctional thread to be deleted. */
...@@ -174,12 +236,20 @@ void rt_thread_idle_excute(void) ...@@ -174,12 +236,20 @@ void rt_thread_idle_excute(void)
static void rt_thread_idle_entry(void *parameter) static void rt_thread_idle_entry(void *parameter)
{ {
#ifdef RT_USING_IDLE_HOOK
rt_size_t i;
#endif
while (1) while (1)
{ {
#ifdef RT_USING_IDLE_HOOK #ifdef RT_USING_IDLE_HOOK
if (rt_thread_idle_hook != RT_NULL) for (i = 0; i < RT_IDEL_HOOK_LIST_SIZE; i++)
{ {
rt_thread_idle_hook(); if (idle_hook_list[i] != RT_NULL)
{
idle_hook_list[i]();
}
} }
#endif #endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册