ucosIII下创建任务读取DS18B20采集到的温度数据

news2025/1/12 22:01:54

学习链接:ucosIII下创建任务读取并输出DHT11采集到的温湿度数据

相关代码及事项:

首先,需要添加下面两个文件,
在这里插入图片描述
其次,main.c 中如下的代码:

#include "led.h"
#include "delay.h"
#include "sys.h"
#include "usart.h"
#include "ds18b20.h"
#include "includes.h"

//UCOSIII中以下优先级, 用户程序不能使用.
//将这些优先级分配给了UCOSIII的5个系统内部任务
//优先级0:中断服务服务管理任务 OS_IntQTask()
//优先级1:时钟节拍任务 OS_TickTask()
//优先级2:定时任务 OS_TmrTask()
//优先级OS_CFG_PRIO_MAX-2:统计任务 OS_StatTask()
//优先级OS_CFG_PRIO_MAX-1:空闲任务 OS_IdleTask()

u8 rom1[]={0x28, 0x95, 0x73, 0xe5, 0x07, 0x00, 0x00, 0xd5,}; //64 ROM
u8 rom2[]={0x28, 0x13, 0xbf, 0x45, 0xd4, 0x49, 0x66, 0x4b,};

//任务优先级
#define START_TASK_PRIO		3
// 定义任务堆栈大小	
#define START_STK_SIZE 		512
// 定义任务控制块
OS_TCB StartTaskTCB;	// OS_TCB是结构体类型
// 任务堆栈	
CPU_STK START_TASK_STK[START_STK_SIZE]; // CPU_STK 是重新定义的数据类型 实质是 unsigned int
// 声明任务函数实体
void start_task(void *p_arg);

//任务优先级
#define LED0_TASK_PRIO		4
//任务堆栈大小	
#define LED0_STK_SIZE 		128
//任务控制块
OS_TCB Led0TaskTCB;
//任务堆栈 CPU_STK 为 CPU_INT32U 类型, 也就是 unsigned int 类型, 为4 Byte,
CPU_STK LED0_TASK_STK[LED0_STK_SIZE];  //  那么任务堆栈 LED0_TASK_STK 的大小为 128 * 4 = 512 Byte.
//声明任务函数实体
void led0_task(void *p_arg);

//任务优先级
#define LED1_TASK_PRIO		5
//任务堆栈大小	
#define LED1_STK_SIZE 		128
//任务控制块
OS_TCB Led1TaskTCB;
//任务堆栈	
CPU_STK LED1_TASK_STK[LED1_STK_SIZE];
//声明任务函数实体
void led1_task(void *p_arg);

//任务优先级
#define FLOAT_TASK_PRIO		6
//任务堆栈大小
#define FLOAT_STK_SIZE		128
//任务控制块
OS_TCB	FloatTaskTCB;
//任务堆栈
__align(8) CPU_STK	FLOAT_TASK_STK[FLOAT_STK_SIZE];
//声明任务函数实体
void float_task(void *p_arg);

//任务优先级
#define DS18B20_TASK_PRIO		6
//任务堆栈大小
#define DS18B20_STK_SIZE		128
//任务控制块
OS_TCB	DS18B20TaskTCB;
//任务堆栈
CPU_STK	DS18B20_TASK_STK[DS18B20_STK_SIZE];
//声明任务函数实体
void ds18b20_task(void *p_arg);

int main(void)
{
	OS_ERR err;  // 定义返回错误的变量
	
	CPU_SR_ALLOC();
	
	delay_init();       //延时初始化
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); //中断分组配置
	uart_init(115200);    //串口波特率设置
	LED_Init();         //LED初始化
	
	printf("System Going !\r\n");
	
	OSInit(&err);		//初始化UCOSIII系统及其相关的全局变量 
	
	OS_CRITICAL_ENTER();//进入临界区
	
	/*
		任务的栈,任务的函数实体,任务的TCB最终需要联系起来才能由系统统一调度。
		这个联系工作就由任务创建函数OSTaskCreat来实现。
		任务创建函数OSTaskCreat在os_task.c中。
	 */
	OSTaskCreate((OS_TCB 	* )&StartTaskTCB,					//任务控制块
							 (CPU_CHAR	* )"start task", 				//任务名字
							 (OS_TASK_PTR )start_task, 					//任务函数
							 (void		* )0,											//传递给任务函数的参数,无参数指向NULL,即 0
							 (OS_PRIO	  )START_TASK_PRIO,     	//任务优先级
							 (CPU_STK   * )&START_TASK_STK[0],	//任务堆栈基地址
							 (CPU_STK_SIZE)START_STK_SIZE/10,		//任务堆栈深度限位, 意思是当任务堆栈剩余多少时, 就表示任务堆栈快用完了。通常为堆栈大小的 1/10
							 (CPU_STK_SIZE)START_STK_SIZE,			//任务堆栈大小
							 (OS_MSG_QTY  )0,										//任务内部消息队列能够接收的最大消息数目,为0时禁止接收消息
							 (OS_TICK	  )0,											//当使能时间片轮转时的时间片长度,为0时为默认长度,
							 (void   	* )0,											//用户补充的存储区
							 (OS_OPT      )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR, //任务选项
							 (OS_ERR 	* )&err);									//存放该函数错误时的返回值
	OS_CRITICAL_EXIT();															//退出临界区	 
							 
	OSStart(&err);  																//开启UCOSIII, 将不再返回
	while(1);
}

//开始任务函数
void start_task(void *p_arg)
{
	OS_ERR err;
	CPU_SR_ALLOC();// 进入临界区代码须调用该函数来声明一个变量。
	p_arg = p_arg; // 因为参数 p_arg 没有使用, 这样做之后是为了防止编译器报警告。

	CPU_Init();
#if OS_CFG_STAT_TASK_EN > 0u
   OSStatTaskCPUUsageInit(&err);  	//统计任务                
#endif
	
#ifdef CPU_CFG_INT_DIS_MEAS_EN		//如果使能了测量中断关闭时间
    CPU_IntDisMeasMaxCurReset();	
#endif
	
#if	OS_CFG_SCHED_ROUND_ROBIN_EN  //当使用时间片轮转的时候
	 //使能时间片轮转调度功能,时间片长度为1个系统时钟节拍,既1*5=5ms
	OSSchedRoundRobinCfg(DEF_ENABLED,1,&err);  
#endif		
	
	OS_CRITICAL_ENTER();	//进入临界区
	
	//创建LED0任务
	OSTaskCreate ((OS_TCB 	* )		&Led0TaskTCB,		
							 (CPU_CHAR	* )		"led0 task", 		
							 (OS_TASK_PTR )		led0_task, 			
							 (	void		* )		0,									// 无参数写0即可
							 (	OS_PRIO	  )		LED0_TASK_PRIO,     
							 (CPU_STK   * )		&LED0_TASK_STK[0],	// 任务栈的基地址
							 (CPU_STK_SIZE)		LED0_STK_SIZE/10,	
							 (CPU_STK_SIZE)		LED0_STK_SIZE,		
							 (OS_MSG_QTY  )		0,					
							 (OS_TICK	  	)		0,					
							 (void   	* 	)		0,					
							 (OS_OPT    	)		OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR,
							 (OS_ERR 	* )&err);				
				 
	//创建LED1任务
	OSTaskCreate((OS_TCB 	* )&Led1TaskTCB,		
							 (CPU_CHAR	* )"led1 task", 		
							 (OS_TASK_PTR )led1_task, 			
							 (void		* )0,					
							 (OS_PRIO	  )LED1_TASK_PRIO,     	
							 (CPU_STK   * )&LED1_TASK_STK[0],	
							 (CPU_STK_SIZE)LED1_STK_SIZE/10,	
							 (CPU_STK_SIZE)LED1_STK_SIZE,		
							 (OS_MSG_QTY  )0,					
							 (OS_TICK	  )0,					
							 (void   	* )0,				
							 (OS_OPT      )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR, 
							 (OS_ERR 	* )&err);	
			 
	//创建浮点数任务
	OSTaskCreate((OS_TCB 	* )&FloatTaskTCB,		
							 (CPU_CHAR	* )"float task", 		
							 (OS_TASK_PTR )float_task, 			
							 (void		* )0,					
							 (OS_PRIO	  )FLOAT_TASK_PRIO,     	
							 (CPU_STK   * )&FLOAT_TASK_STK[0],	
							 (CPU_STK_SIZE)FLOAT_STK_SIZE/10,	
							 (CPU_STK_SIZE)FLOAT_STK_SIZE,		
							 (OS_MSG_QTY  )0,					
							 (OS_TICK	  )0,					
							 (void   	* )0,				
							 (OS_OPT      )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR, 
							 (OS_ERR 	* )&err);				
							 
	//创建温度读取任务
	OSTaskCreate((OS_TCB 	* )&DS18B20TaskTCB,		
							 (CPU_CHAR	* )"ds18b20 task", 		
							 (OS_TASK_PTR )ds18b20_task, 			
							 (void		* )0,					
							 (OS_PRIO	  )DS18B20_TASK_PRIO,     	
							 (CPU_STK   * )&DS18B20_TASK_STK[0],	
							 (CPU_STK_SIZE)DS18B20_STK_SIZE/10,	
							 (CPU_STK_SIZE)DS18B20_STK_SIZE,		
							 (OS_MSG_QTY  )0,					
							 (OS_TICK	  )0,					
							 (void   	* )0,				
							 (OS_OPT      )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR, 
							 (OS_ERR 	* )&err);				
							 
	OS_TaskSuspend((OS_TCB*)&StartTaskTCB,&err);		//挂起开始任务			 
	OS_CRITICAL_EXIT();	//退出临界区
}

/*
************************************************************************************************************************
*                                函数实体 --- 任务是一个独立的函数,函数主体无限循环且不能返回。
************************************************************************************************************************
*/

//led0任务函数
void led0_task(void *p_arg)
{
	OS_ERR err;
	p_arg = p_arg;
	while(1)
	{
		LED0=0;
		OSTimeDlyHMSM(0,0,0,200,OS_OPT_TIME_HMSM_STRICT,&err); //延时200ms
		LED0=1;
		OSTimeDlyHMSM(0,0,0,500,OS_OPT_TIME_HMSM_STRICT,&err); //延时500ms
	}
}

//led1任务函数
void led1_task(void *p_arg)
{
	OS_ERR err;
	p_arg = p_arg;
	while(1)
	{
		LED1=~LED1;
		OSTimeDlyHMSM(0,0,0,500,OS_OPT_TIME_HMSM_STRICT,&err); //延时500ms
	}
}

//浮点测试任务
void float_task(void *p_arg)
{
	CPU_SR_ALLOC();
	static float float_num=0.01;
	while(1)
	{
		float_num+=0.01f;
		OS_CRITICAL_ENTER();	//进入临界区
		printf("float_num的值为: %.4f\r\n",float_num);
		OS_CRITICAL_EXIT();		//退出临界区
		delay_ms(500);			//延时500ms
	}
}

//DS18B20任务函数
void ds18b20_task(void *p_arg)
{
	u16 Temp = 0;
	OS_ERR err;
	CPU_SR_ALLOC();// 进入临界区代码须调用该函数来声明一个变量。
	p_arg = p_arg;
	
	DS18B20_UserConfig();
	
	while(1)
	{
		OSTimeDlyHMSM(0,0,0,500,OS_OPT_TIME_HMSM_STRICT,&err); //延时500ms
				
		OS_CRITICAL_ENTER();	//进入临界区
		DS18B20_Read_Temperature(rom1,&Temp);

		printf("T1- %d.%d%d   ,",Temp/100,((Temp%100)/10),(Temp%100%10));
		
		DS18B20_Read_Temperature(rom2,&Temp);
		printf("T2- %d.%d%d   ,",Temp/100,((Temp%100)/10),(Temp%100%10));
		OS_CRITICAL_EXIT();	//退出临界区
		
	}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1448643.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CPython:表达式的求值顺序(evaluation order)

相关阅读 Pythonhttps://blog.csdn.net/weixin_45791458/category_12403403.html?spm1001.2014.3001.5482 C中表达式的求值 C语言针对表达式的计算,设置了操作符的优先级和结合性这两个特性,优先级用于解析不同优先级的符号,结合性用于解析…

波奇学Linux:软硬链接

ln指令建立链接 软链接 硬链接 所属者的前的数字表示硬链接数,引用计数,file.txt和soft_link是软链接所以都为2 软链接有独立inode,硬链接没有,所以硬链接不是独立文件,软链接是独立文件,且硬链接的属性会…

大模型Layer normalization知识

Layer Norm 的计算公式 Layer Norm(层归一化)是一种用于神经网络中的归一化技术,用于提高模型的训练效果和泛化能力。 RMS Norm 的计算公式 RMS Norm 的作用是通过计算输入 X 的均方根,将每个样本的特征进行归一化,使…

【51单片机】LCD1602(江科大)

1.LCD1602介绍 LCD1602(Liquid Crystal Display)液晶显示屏是一种字符型液晶显示模块,可以显示ASCII码的标准字符和其它的一些内置特殊字符,还可以有8个自定义字符 显示容量:162个字符,每个字符为5*7点阵 2.引脚及应用电路 3.内部结构框图 屏幕: 字模库:类似于数码管的数…

基于 Python 的大数据的电信反诈骗系统

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…

C++:继承与派生基础

引入: 由自然界的动物繁衍的规律(eg: 动物继承父类的一切属性,由父类派生并增加自己的新特征)我们引入C语言在类的使用中描述此类问题。 为解决代码重复使用、提升效率,引入继承机制:允许保留原有类的特性…

STM32 寄存器操作 systick 滴答定时器 与中断

一、什么是 SysTick SysTick—系统定时器是属于CM3内核中的一个外设,内嵌在NVIC中。系统定时器是一个24bit的向下递减的计数器, 计数器每计数一次的时间为1/SYSCLK,一般我们设置系统时钟SYSCLK等于72M。当重装载数值寄存器的值递减到0的时候…

Java:什么是多态,重载与重写?重载与重写有何不同?(带图详解)

目录 一、什么是多态 1、多态的概念 2、多态实现的条件 3、多态的优缺点 二、什么是重写 1、重写的概念 2、方法重写的规则 三、什么是重载 四、重写与重载的不同 一、什么是多态 1、多态的概念 多态通俗来说就是多种形态,具体点就是去完成某个行为&#x…

flask+python儿童福利院管理系统pycharm毕业设计项目

本系统解决了儿童福利院管理事务中的主要问题,包括首页、个人中心、爱心人士管理、员工管理、后勤人员管理、儿童信息管理、院所风采管理、活动管理、食谱管理、领养流程管理、政策法规管理、楼栋管理、宿舍管理、领养申请管理、义工申请管理、捐赠信息管理、宿舍物…

vue3中Pinia

一、pinia的简单使用 vuex和pinia的区别 参考网址:[Vuex] Vuex 5 by kiaking Pull Request #271 vuejs/rfcs GitHub 1.pinia没有mutations,只有:state、getters、actions 2.pinia分模块不需要models(之前vuex分模块需要models…

C++-带你深度理解string类的常见接口

1. 为什么学习string类? C语言中,字符串是以\0结尾的一些字符的集合,为了操作方便,C标准库中提供了一些str系列的库函数,但是这些库函数与字符串是分离开的,不太符合OOP的思想,而且底层空间需…

幻兽帕鲁开服教程:零基础服务器搭建超简单!

幻兽帕鲁官方服务器不稳定?自己搭建幻兽帕鲁服务器,低延迟、稳定不卡,目前阿里云和腾讯云均推出幻兽帕鲁专用服务器,腾讯云直接提供幻兽帕鲁镜像系统,阿里云通过计算巢服务,均可以一键部署,鼠标…

加固平板电脑丨三防智能平板丨工业加固平板丨智能城市管理

随着智能城市的不断发展,人们对于城市管理的要求也在不断提高,这就需要高效、智能的城市管理平台来实现。而三防平板就是一款可以满足这一需求的智能设备。 三防平板是一种集防水、防尘、防摔于一体的智能平板电脑,它可以在复杂的环境下稳定运…

点云旋转(基于PCL)

实现代码为&#xff1a; //以中心化点进行旋转double theta atan(maindirection.a);//计算的是弧度单位for (int i 0; i < origipts.size(); i){pcl::PointXYZ tempone;tempone.x aftercenerlizepts[i].x*cos(theta) aftercenerlizepts[i].y*sin(theta) center.x;temp…

【网工】华为设备命令学习(综合实验一)

实验要求和实验成果如图所示。 LSW2不需要其他配置&#xff0c;其下就一台设备&#xff0c;不需要区分。 LSW3配置如下&#xff1a; <Huawei>sy Enter system view, return user view with CtrlZ. [Huawei]un in en //关闭系统提示信息 Info: Information …

四、OpenAI之文本生成模型(Text Generation)

文本生成模型 OpenAI的文本生成模型(也叫做生成预训练的转换器(Generative pre-trained transformers)或大语言模型)已经被训练成可以理解自然语言、代码和图片的模型。模型提供文本的输出作为输入的响应。对这些模型的输入内容也被称作“提示词”。设计提示词的本质是你如何对…

在Meteor Lake平台上使用NPU进行AI推理加速

在Meteor Lake平台上&#xff0c;英特尔通过神经处理单元 (NPU) 将人工智能直接融入芯片中&#xff0c;实现桌面电脑平台的AI推理功能。神经处理单元 (NPU) 是一种专用人工智能引擎&#xff0c;专为运行持续的人工智能推理工作负载而设计。与即将推出的支持深度人工智能集成的 …

衍生式设计之随机删除Revit幕墙网格

上次教程&#xff0c;我们创建了一个随机的三角形&#xff08;一个小例子&#xff0c;告诉你什么是衍生式设计&#xff09;&#xff0c;用来给大家简单介绍了下啥是衍生式设计&#xff0c;但是三角形是在Dynamo里做的&#xff0c;似乎和Revit没啥关系&#xff0c;那么本次呢&am…

七天入门大模型 :提示词工程 Prompt Engineering,最全的总结来了!

文章目录 技术交流群用通俗易懂方式讲解系列引 言LLM 的超参配置Prompt Engineering指令主要内容少样本学习更加明确的提示善用分隔符思维链提示对输出格式的明确要求 最佳实践案例1. Agent场景&#xff1a;使用prompt实现agent create2. Agent场景&#xff1a;使用system mess…

Unresolved reference: kotlinx 和 Unresolved reference:xxx

Unresolved reference: kotlinx 这个报错是因为build.gradle中忘记apply plugin了 apply plugin: kotlin-android-extensions如下 同步以后再次编译发现报错 Unresolved reference:xxx 是因为用于使用 Gradle 构建的 Kotlin 版本与 IDE 插件中的版本不一样的原因 解决方法 …