Raw-OS源码分析之任务删除与总结

        分析的内核版本截止到2014-04-15,基于1.05正式版,blogs会及时跟进最新版本的内核开发进度,若源码注释出现”???”字样,则是未深究理解部分。

        Raw-OS官方网站:http://www.raw-os.org/

        Raw-OS托管地址:https://github.com/jorya/raw-os/

        那么,先给出总结的Raw-OS的任务状态转换图,这个图出自:

        http://blog.csdn.net/shengnan_wu/article/details/8536030

Raw-OS源码分析之任务删除与总结_第1张图片


        那么,这个状态图都可以出现RAW_DELETE的状态重点,那么对应的就是任务删除,对于删除任务也有一些限制用法,具体看代码里面的注释

RAW_U16 raw_task_delete(RAW_TASK_OBJ *task_ptr)
{
	RAW_SR_ALLOC();

	#if (RAW_TASK_FUNCTION_CHECK > 0)
	/* 选择被删除的任务TCB不存在,返回 */
	if (task_ptr == 0) {
		return RAW_NULL_OBJECT;
	}

	/* 中断中不允许删除任务 */
	if (raw_int_nesting) {
		return RAW_NOT_CALLED_BY_ISR;
	}
	#endif

	/* IDLE任务不允许删除 */
	if (task_ptr->priority == IDLE_PRIORITY) {
		return RAW_DELETE_TASK_NOT_ALLOWED;
	}

	#if (CONFIG_RAW_TASK_0 > 0)
	/* 如果开启task 0宏例化task 0后,task 0不允许删除 */
	if (task_ptr->priority == 0) {
		return RAW_DELETE_TASK_NOT_ALLOWED;
	}
	#endif

	/* 给系统上锁一次,系统锁标志变量+1 */
	RAW_CRITICAL_ENTER();
	/*
	 * 这里检查系统锁标志变量是否仅仅由上一个语句产生一个叠加操作,如果锁标志位>=2
	 * 说明在这里之前,其他位置已经发生了系统上锁操作,所以这里解除前一语句的上锁操作,返回
	 */
	if (task_ptr == raw_task_active) {
		SYSTEM_LOCK_PROCESS();
	}

	/* 释放任务控制块内的互斥锁,Raw-OS设计的任务内有任务互斥锁,这里要释放,对于互斥锁,后续blog分析 */
	#if (CONFIG_RAW_MUTEX > 0)
	raw_task_free_mutex(task_ptr);
	#endif
	/* 检查被删除任务的任务状态,执行相应操作 */
	switch (task_ptr->task_state) {
		/* 就绪态 */
		case RAW_RDY:
			/* 从就绪队列中移除 */
			remove_ready_list(&raw_ready_queue, task_ptr);
			break;
		/* 挂起态,不存在就绪队列,可以直接删除 */
		case RAW_SUSPENDED:
			break;
		/* 如果任务处于等待超时的tick list中,从tick list中移除 */
		case RAW_DLY:
		case RAW_DLY_SUSPENDED:
			tick_list_remove(task_ptr);
			break;
		/* 这里是任务阻塞状态相关 */
		case RAW_PEND:
		case RAW_PEND_SUSPENDED:
		case RAW_PEND_TIMEOUT:
		case RAW_PEND_TIMEOUT_SUSPENDED:
			/* 从tick list移除阻塞任务 */
			tick_list_remove(task_ptr);
			/* 这里还要list delete???难道阻塞态还存在别的链表中??? */
			list_delete(&task_ptr->task_list);
			/* 互斥锁相关,现在就当自己是初学者,不懂何用??? */
			#if (CONFIG_RAW_MUTEX > 0)
			mutex_state_change(task_ptr);
			#endif
			break;
		default:
			RAW_CRITICAL_EXIT();
			return  RAW_STATE_UNKNOWN;
	}
	/* 任务状态设置为删除态 */
	task_ptr->task_state = RAW_DELETED;

	/* 系统检测??? */
	#if (RAW_SYSTEM_CHECK > 0)
	/* make after_delete_list to right position??? */
	system_debug.after_delete_list = task_ptr->stack_check_list.next;

	if (system_debug.after_delete_list == (&(system_debug.task_head))) {
				system_debug.after_delete_list = system_debug.task_head.next;
	}

	list_delete(&task_ptr->stack_check_list);
	#endif
	/* 将之前上锁操作释放 */
	RAW_CRITICAL_EXIT();
	/* 删除任务时的trace debug??? */
	TRACE_TASK_DELETE(task_ptr);
	/* 移植相关,调用删除任务时的钩子函数 */
	#if (CONFIG_RAW_USER_HOOK > 0)
	raw_task_delete_hook(task_ptr);
	#endif
	/* 删除任务后执行系统调度 */
	raw_sched();
	/* 保留一个疑问,例化任务的时候如果堆栈是静态分配,那么就浪费资源??? */
	return RAW_SUCCESS;
}




你可能感兴趣的:(嵌入式,RAW-OS)