ostaskcreate函数作用_认识上中下

ostaskcreate函数作用_认识上中下OSTaskCreate()是学习ucos-Ⅱ操作系统的第一个函数,费了九牛二虎之力,现在感觉差不多可以过了。#ifOS_TASK_CREATE_EN>0INT8UOSTaskCreate(void(*task)(void*p_arg),void*p_arg,OS_STK*ptos,INT8Uprio)/*1*/{ OS_STK…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 OSTaskCreate()是学习ucos-Ⅱ操作系统的第一个函数,费了九牛二虎之力,现在感觉差不多可以过了。


#if OS_TASK_CREATE_EN > 0
INT8U  OSTaskCreate (void (*task)(void *p_arg), void *p_arg, OS_STK *ptos, INT8U prio)/*1*/
{						
    OS_STK    *psp;								/*2*/
    INT8U      err;
	
#if OS_CRITICAL_METHOD == 3                  					/*3*/
    OS_CPU_SR  cpu_sr = 0;
#endif

#if OS_ARG_CHK_EN > 0
    if (prio > OS_LOWEST_PRIO) 
    {              
        return (OS_ERR_PRIO_INVALID);						/*4*/
    }
#endif
	
    OS_ENTER_CRITICAL();
    if (OSIntNesting > 0) 							/*5*/												
    {                  
        OS_EXIT_CRITICAL();
        return (OS_ERR_TASK_CREATE_ISR);
    }
    if (OSTCBPrioTbl[prio] == (OS_TCB *)0)					/*6*/
    {  
        OSTCBPrioTbl[prio] = OS_TCB_RESERVED; 					/*7*/
                                              
        OS_EXIT_CRITICAL();
		
        psp = OSTaskStkInit(task, p_arg, ptos, 0);    				/*8*/
		
        err = OS_TCBInit(prio, psp, (OS_STK *)0, 0, 0, (void *)0, 0);		/*9*/
        if (err == OS_ERR_NONE) 
	{
            if (OSRunning == OS_TRUE) 						/*10*/
	    {       
                OS_Sched();							/*11*/
            }
        } 
	else
	{
            OS_ENTER_CRITICAL();
            OSTCBPrioTbl[prio] = (OS_TCB *)0;	 				/*12*/
            OS_EXIT_CRITICAL();
        }
        return (err);
    }
    else
    {
	OS_EXIT_CRITICAL();
	return (OS_ERR_PRIO_EXIST);						/*13*/
    }
}
#endif

/*1*/

void (*task)(void *p_arg):首先是个函数指针。在调用该函数时,将该任务的函数名(即该任务所占内存的首地址)作为指针传递过来;

void *p_arg:传递的任务参数,一般不用;

OS_STK *ptos,:该任务的堆栈的栈顶指针(堆栈增长的默认方向从上往下,从高地址往低地址);

INT8U prio:该任务的优先级。

/*2*/

OS_STK    *psp:定义一个堆栈类型的指针(该指针一直指向这个任务堆栈的栈顶,也称栈顶指针)。

/*3*/

OS_CPU_SR  cpu_sr = 0:定义一个OS_CPU_SR类型的cpu_sr的局部变量,

该变量描述cpu的状态寄存器的,每次屏蔽中断时,都将cpu状态寄存器的值存进cpu_sr这个变量中,每次打开中断时,再将cpu_sr的值赋值给cpu的状态寄存器。

/*4*/

prio > OS_LOWEST_PRIO:定义的优先级应在允许的范围内,否则不具备有效性。

/*5*/

OSIntNesting > 0:在中断处理程序中,不应进行任务创建,每次进入中断的时候,OSIntNesting ++,若大于0,必然在处理中断程序。

/*6*/

OSTCBPrioTbl[prio]:任务优先级列表是一个数组指针,该数组元素指向该任务控制块的内存地址;

(OS_TCB *)0:表示一个OS_TCB类型的指针,指向0,是一个空指针;

OSTCBPrioTbl[prio] == (OS_TCB *)0:该数组元素指向的内存地址是一个空地址,还没有被使用。

/*7*/

OS_TCB_RESERVED:即(OS_TCB *)1:表示一个OS_TCB类型的指针,指向1,表示非空指针;

OSTCBPrioTbl[prio] == (OS_TCB *)1, 该数组元素指向的内存地址是一个非空地址了,已经被占用了,还没有赋予具体的内存地址,这是一个宣告。

/*8*/

任务堆栈的初始化,并返回当前任务堆栈的栈顶指针。这个函数让我正确认识了堆栈的规则   后进先出,详情见OSTaskStkInit()函数。

/*9*/

任务控制块的初始化,并返回初始化的结果状态。详情见OS_TCBInit()函数。

/*10*/

OSRunning == OS_TRUE:操作系统的状态必须在运行的状态下,才能进行任务调度。操作系统运行过程中,OSRunning 第一次置为OS_TRUE状态是在OSStart()函数中实现的。


/*11*/

OS_Sched():进行任务调度。 详情见 OS_Sched()函数。

/*12*/

OSTCBPrioTbl[prio] = (OS_TCB *)0:若任务控制块初始化不成功,则释放被宣告占有的任务控制块。

/*13*/

return (OS_ERR_PRIO_EXIST):说明该任务控制块的内存地址已经被占用了,或者说该优先级已经被占用了。

上面是我对OSTaskCreate()函数的一些细节的认识,若有理解不对的地方,恳请指正!

好了,第一次写博希望大家多多支持!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196945.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SpringBoot集成Quartz实现定时任务的动态创建、启动、暂停、恢复、删除。

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:毅大师 blog.csdn.net/qq_39648029/article/details/108993476…

    2021年6月26日
    88
  • CSA 第五届研讨会 想象

    CSA 第五届研讨会 想象

    2022年1月12日
    42
  • C# SplitContainer 控件详细用法

    C# SplitContainer 控件详细用法1.可以将Windows窗体SplitContainer控件看作是一个复合体,它是由一个可移动的拆分条分隔的两个面板。当鼠标指针悬停在该拆分条上时,指针将相应地改变形状以显示该拆分条是可移动的。使用SplitContainer控件,可以创建复合的用户界面(通常,在一个面板中的选择决定了在另一个面板中显示哪些对象)。这种排列对于显示和浏览信息非常有用。拥有两个面板使您可以聚合不同区域中的信息,并且用户可以轻松地使用拆分条(也称为“拆分器”)调整面板的大小。另外,还可以嵌套多个SplitC…

    2022年7月18日
    71
  • 深度学习中的自动编码器:TensorFlow示例

    深度学习中的自动编码器:TensorFlow示例什么是自动编码器?  自动编码器是重建输入的绝佳工具。简单来说,机器就是一个图像,可以生成一个密切相关的图片。这种神经网络中的输入是未标记的,这意味着网络能够在没有监督的情况下进行学习。更准确地说,输入由网络编码,仅关注最关键的特征。这是自动编码器因降维而流行的原因之一。此外,自动编码器可用于生成生成学习模型。例如,神经网络可以用一组面部训练,然后可以产生新的面部。Autoencoder如何工…

    2022年6月3日
    40
  • hvie hbase各自的使用场景

    hvie hbase各自的使用场景hvie hbase各自的使用场景

    2022年4月23日
    61
  • Python实现排列组合算法

    Python实现排列组合算法实现组合算法C(n,k),可以用递归实现:importcopy#实现list的深复制defcombine(lst,l):result=[]tmp=[0]*llength=len(lst)defnext_num(li=0,ni=0):ifni==l:result.append…

    2022年10月20日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号