|
@@ -77,6 +77,31 @@ void rt_thread_inited_sethook(void (*hook)(rt_thread_t thread))
|
|
|
|
|
|
#endif
|
|
#endif
|
|
|
|
|
|
|
|
+/* must be invoke witch rt_hw_interrupt_disable */
|
|
|
|
+static void _thread_cleanup_execute(rt_thread_t thread)
|
|
|
|
+{
|
|
|
|
+ register rt_base_t level;
|
|
|
|
+#ifdef RT_USING_MODULE
|
|
|
|
+ struct rt_dlmodule *module = RT_NULL;
|
|
|
|
+#endif
|
|
|
|
+ level = rt_hw_interrupt_disable();
|
|
|
|
+#ifdef RT_USING_MODULE
|
|
|
|
+ module = (struct rt_dlmodule*)thread->module_id;
|
|
|
|
+ if (module)
|
|
|
|
+ {
|
|
|
|
+ dlmodule_destroy(module);
|
|
|
|
+ }
|
|
|
|
+#endif
|
|
|
|
+ /* invoke thread cleanup */
|
|
|
|
+ if (thread->cleanup != RT_NULL)
|
|
|
|
+ thread->cleanup(thread);
|
|
|
|
+
|
|
|
|
+#ifdef RT_USING_SIGNALS
|
|
|
|
+ rt_thread_free_sig(thread);
|
|
|
|
+#endif
|
|
|
|
+ rt_hw_interrupt_enable(level);
|
|
|
|
+}
|
|
|
|
+
|
|
void rt_thread_exit(void)
|
|
void rt_thread_exit(void)
|
|
{
|
|
{
|
|
struct rt_thread *thread;
|
|
struct rt_thread *thread;
|
|
@@ -88,6 +113,8 @@ void rt_thread_exit(void)
|
|
/* disable interrupt */
|
|
/* disable interrupt */
|
|
level = rt_hw_interrupt_disable();
|
|
level = rt_hw_interrupt_disable();
|
|
|
|
|
|
|
|
+ _thread_cleanup_execute(thread);
|
|
|
|
+
|
|
/* remove from schedule */
|
|
/* remove from schedule */
|
|
rt_schedule_remove_thread(thread);
|
|
rt_schedule_remove_thread(thread);
|
|
/* change stat */
|
|
/* change stat */
|
|
@@ -96,8 +123,7 @@ void rt_thread_exit(void)
|
|
/* remove it from timer list */
|
|
/* remove it from timer list */
|
|
rt_timer_detach(&thread->thread_timer);
|
|
rt_timer_detach(&thread->thread_timer);
|
|
|
|
|
|
- if ((rt_object_is_systemobject((rt_object_t)thread) == RT_TRUE) &&
|
|
|
|
- thread->cleanup == RT_NULL)
|
|
|
|
|
|
+ if (rt_object_is_systemobject((rt_object_t)thread) == RT_TRUE)
|
|
{
|
|
{
|
|
rt_object_detach((rt_object_t)thread);
|
|
rt_object_detach((rt_object_t)thread);
|
|
}
|
|
}
|
|
@@ -347,14 +373,15 @@ rt_err_t rt_thread_detach(rt_thread_t thread)
|
|
rt_schedule_remove_thread(thread);
|
|
rt_schedule_remove_thread(thread);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ _thread_cleanup_execute(thread);
|
|
|
|
+
|
|
/* release thread timer */
|
|
/* release thread timer */
|
|
rt_timer_detach(&(thread->thread_timer));
|
|
rt_timer_detach(&(thread->thread_timer));
|
|
|
|
|
|
/* change stat */
|
|
/* change stat */
|
|
thread->stat = RT_THREAD_CLOSE;
|
|
thread->stat = RT_THREAD_CLOSE;
|
|
|
|
|
|
- if ((rt_object_is_systemobject((rt_object_t)thread) == RT_TRUE) &&
|
|
|
|
- thread->cleanup == RT_NULL)
|
|
|
|
|
|
+ if (rt_object_is_systemobject((rt_object_t)thread) == RT_TRUE)
|
|
{
|
|
{
|
|
rt_object_detach((rt_object_t)thread);
|
|
rt_object_detach((rt_object_t)thread);
|
|
}
|
|
}
|
|
@@ -449,6 +476,8 @@ rt_err_t rt_thread_delete(rt_thread_t thread)
|
|
rt_schedule_remove_thread(thread);
|
|
rt_schedule_remove_thread(thread);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ _thread_cleanup_execute(thread);
|
|
|
|
+
|
|
/* release thread timer */
|
|
/* release thread timer */
|
|
rt_timer_detach(&(thread->thread_timer));
|
|
rt_timer_detach(&(thread->thread_timer));
|
|
|
|
|