Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
DIY综合交流区
[RealTouch 例程]定时器超时
发布于 2012-11-09 08:53:00 浏览:4205
订阅该版
实验目的 ? 熟悉了解定时器超时的应用场景 硬件说明 本实验使用RT-Thread官方的Realtouch开发板作为实验平台。涉及到的硬件主要为 ? 串口3,作为rt_kprintf输出,需要连接JTAG扩展板 具体请参见《Realtouch开发板使用手册》 实验原理及程序结构 实验设计 本实验的主要设计目的是帮助读者了解定时器超时的应用场景,具体是消息队列,关于消息队列内容,可以回看第二章。请读者注意,本实验本身不具有实际的工程参考价值,只是帮助读者快速了解相关API的用法。 源程序说明 本实验对应1_kernel_timer_timeout 系统依赖 在rtconfig.h中需要开启 ? #define RT_USING_HEAP 此项可选,开启此项可以创建动态线程和动态信号量,如果使用静态线程和静态信号量,则此项不是必要的 ? #define RT_USING_CONSOLE 此项必须,本实验使用rt_kprintf向串口打印按键信息,因此需要开启此项 ? #define RT_USING_TIMER_SOFT 此项必须,本实验使用软件定时器,因此必须开启此项 ? #define RT_USING_MESSAGEQUEUE 此项必须,本实验使用了消息队列进行信息传递,因此必须打开此项 主程序说明 这个程序会创建1个动态线程,这个线程会从消息队列中收取消息;另外通过定时器超时函数向消息队列发送消息 ```全局变量 static rt_thread_t tid = RT_NULL; /* 消息队列控制块 */ static struct rt_messagequeue mq; /* 消息队列中用到的放置消息的内存池 */ static char msg_pool[2048]; /* 定时器的控制块 */ static struct rt_timer timer; /*消息的参数,确定消息的顺序*/ static rt_uint16_t no = 0;``` 在初始化函数rt_application_init()中,初始化了消息队列,并创建了一个动态线程。 初始化函数 ```rt_err_t result; /* 初始化消息队列 */ result = rt_mq_init(&mq, "mqt", &msg_pool[0], /* 内存池指向msg_pool */ 128 - sizeof(void*), /* 每个消息的大小是 128 - void* */ sizeof(msg_pool), /* 内存池的大小是msg_pool的大小 */ RT_IPC_FLAG_FIFO); /* 如果有多个线程等待,按照先来先得到的方法分配消息 */ if (result != RT_EOK) { rt_kprintf("init message queue failed. "); return -1; } /* 创建线程 */ tid = rt_thread_create("t", thread_entry, RT_NULL, /* 线程入口是thread_entry, 入口参数是RT_NULL */ 1024, 8, 50); if (tid != RT_NULL) rt_thread_startup(tid); return 0;``` 在线程入口函数thread_entry()中我们初始化了定时器,定时时间为1000 os tick,在开启定时器后就准备就收消息队列中的消息,等待没有超时失败,为一直等待直到消息队列中有消息。 ```char buf[64]; rt_err_t result; /* 初始化定时器 */ rt_timer_init(&timer, "timer", /* 定时器名字是 timer1 */ timer_timeout, /* 超时时回调的处理函数 */ RT_NULL, /* 超时函数的入口参数 */ 1000, /* 定时长度,以OS Tick为单位,即1000个OS Tick */ RT_TIMER_FLAG_PERIODIC); /* 周期性定时器 */ rt_timer_start(&timer); while (1) { rt_memset(&buf[0], 0, sizeof(buf)); /* 从消息队列中接收消息 */ result = rt_mq_recv(&mq, &buf[0], sizeof(buf), RT_WAITING_FOREVER); if (result == RT_EOK) { rt_kprintf("recv msg: %s ", buf); } else if (result == -RT_ETIMEOUT) { rt_kprintf("recv msg timeout "); } }``` 在超时函数timer_timeout()中,让它超时即向消息队列中发送一个消息。 ```char buf[32]; rt_uint32_t length; length = rt_snprintf(buf, sizeof(buf), "message %d", no++); rt_mq_send(&mq, &buf[0], length);``` 上面代码中出现的snprintf(),可以将可变参数按照制定的格式,转化为字符串形式,存在buffer中。 编译调试及观察输出信息 编译请参见《RT-Thread配置开发环境指南》完成编译烧录,参考《Realtouch开发板使用手册》完成硬件连接,连接扩展板上的串口和jlink。 运行后可以看到如下信息: | / - RT - Thread Operating System / | 1.1.0 build Aug 14 2012 2006 - 2012 Copyright by rt-thread team recv msg: message 0 recv msg: message 1 recv msg: message 2 recv msg: message 3 recv msg: message 4 recv msg: message 5 recv msg: message 6 recv msg: message 7 recv msg: message 8 recv msg: message 9 recv msg: message 10 recv msg: message 11 recv msg: message 12 recv msg: message 13 recv msg: message 14 recv msg: message 15 ... 结果分析 有结果很好发现,定时器每1000 os tick超时一次,在超时函数中发送消息给消息队列,而线程则是从消息队列中获取消息将之打印出来。如果将rT_mq_receive()函数的最后一个参数由RT_WAITING_FOREVER改为小于1000的数,那么你会发现出现 recv msg timeout 定时器设定为1000才会向消息队列中发送一个消息,而接收超时设定小于1000的话,必然会有接收超时到的时候定时器的超时函数还未向消息队列发送消息的情况。所以在发送和接收消息的时间上可能需要注意一下。 ![实验4_5定时器超时.pdf](/uploads/88_11ac649f9f8d15e0aa832cef496f4ad8.pdf)
查看更多
1
个回答
默认排序
按发布时间排序
撰写答案
登录
注册新账号
关注者
0
被浏览
4.2k
关于作者
shaolin
这家伙很懒,什么也没写!
提问
115
回答
444
被采纳
0
关注TA
发私信
相关问题
1
[项目]搞个开源的硬件项目
2
硬件计划贴,及时更新,欢迎提意见
3
软件计划贴,及时更新,欢迎提意见::WMA,MOUNT,LWIP等问题急需解决.
4
MMS协议
5
定点的wma解压库-libwma
6
QQ群记录 [20090821]
7
STM32网络收音机PCB报名征集
8
第一版调试记录
9
第二版硬件讨论
10
RADIO项目相关模块规格--欢迎大家自己做板时规格与此兼容,减少重复劳动
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
TinyUSB Demo运行教程
2
RT-Thread学习大礼包一键带走!
3
freemodbus从机调试说明
4
【1024】瑞萨 RA 系列 BSP 制作与适配最新版本的 Keil 、 RSC、固件,较新的 FSP
5
基于 RT-Thread 星火一号开发板的俄罗斯方块
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
ART-Pi
FinSH
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
cubemx
PWM
flash
packages_软件包
freemodbus
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
ulog
C++_cpp
at_device
本月问答贡献
用户名由3_15位
10
个答案
1
次被采纳
KunYi
4
个答案
1
次被采纳
踩姑娘的小蘑菇
2
个答案
1
次被采纳
bernard
1
个答案
1
次被采纳
rv666
1
个答案
1
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
4
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部