Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
[第二期 空气质量分析仪]第3周作业
发布于 2019-09-13 00:45:30 浏览:1756
订阅该版
任务 1:实现异步日志 ![1234.png](/uploads/201909/13/003010v9bwby8mb9gwmn6y.png) 完成该任务时遇到两个问题需要注意: 第一个是使用邮箱开始不知道要初始化邮箱,运行时出现以下错误,增加邮箱初始化就好了。 (rt_object_get_type(&mb->parent.parent) == RT_Object_Class_MailBox) assertion failed at function:rt_mb_recv, line number:1604 第二个是在void mylog(char *tag, rt_uint32_t data)函数中如果没有添加rt_thread_mdelay,在main函数里面测试mylog没有问题,但是在其他地方测试打出来的就是乱码如下图所示。 ![qqq.png](/uploads/201909/13/003504kxq3dqpc5fecnp42.png) 代码如下: ```void mylog(char *tag, rt_uint32_t data) { struct log_msg msg; msg.tag = tag; msg.data = data; rt_mb_send(&g_mb, (rt_ubase_t)&msg); rt_thread_mdelay(100); } static rt_thread_t mylog_thread = RT_NULL; static void mylog_thread_entry(void *parameter) { struct log_msg *str; while(1) { if (rt_mb_recv(&g_mb, (rt_ubase_t *)&str, RT_WAITING_FOREVER) == RT_EOK) { rt_kprintf("[%s] data is : %d
", str->tag, str->data); } } } void mylog_init(void) { mylog_thread = rt_thread_create("mylog_thread", mylog_thread_entry, RT_NULL, 512, 4, 20); if (mylog_thread != RT_NULL) rt_thread_startup(mylog_thread); else return; } ``` 任务2:系统跑起来 由于本周都在外地出差,无法操作开发板,只能远程操作家里的电脑,使用finsh命令代替按键,不同的按键发送不同的事件集,在led线程里面接收事件并触发线程,运行结果如下所示,注意事件也要初始化,否则会出现跟上面第一个类似的问题。 ![111.png](/uploads/201909/13/003812llhqu883i6ddgqkg.png) 代码如下 ```#include "drv_key.h" void key_sample(void) { rt_pin_mode(KEY0_PIN_NUM , PIN_MODE_INPUT); rt_pin_irq_enable(KEY0_PIN_NUM, PIN_IRQ_ENABLE); rt_pin_attach_irq(KEY0_PIN_NUM, PIN_IRQ_MODE_FALLING, key_isr, RT_NULL); rt_pin_mode(KEY1_PIN_NUM , PIN_MODE_INPUT); rt_pin_irq_enable(KEY1_PIN_NUM, PIN_IRQ_ENABLE); rt_pin_attach_irq(KEY1_PIN_NUM, PIN_IRQ_MODE_FALLING, key_isr, RT_NULL); rt_pin_mode(KEY2_PIN_NUM , PIN_MODE_INPUT); rt_pin_irq_enable(KEY2_PIN_NUM, PIN_IRQ_ENABLE); rt_pin_attach_irq(KEY2_PIN_NUM, PIN_IRQ_MODE_FALLING, key_isr, RT_NULL); rt_pin_mode(KEYUP_PIN_NUM , PIN_MODE_INPUT); rt_pin_irq_enable(KEYUP_PIN_NUM, PIN_IRQ_ENABLE); rt_pin_attach_irq(KEYUP_PIN_NUM, PIN_IRQ_MODE_RISING, key_isr, RT_NULL); } MSH_CMD_EXPORT(key_sample, key_sample); void key_isr(void *args) { if (rt_pin_read(KEY0_PIN_NUM) == PIN_LOW) { rt_thread_mdelay(100); if (rt_pin_read(KEY0_PIN_NUM) == PIN_LOW) { rt_event_send(&event, KEY_EVENT_FLAG0); rt_kprintf("KEY0 pressed!
"); } } else if (rt_pin_read(KEY1_PIN_NUM) == PIN_LOW) { rt_thread_mdelay(100); if (rt_pin_read(KEY1_PIN_NUM) == PIN_LOW) { rt_event_send(&event, KEY_EVENT_FLAG1); rt_kprintf("KEY1 pressed!
"); } } else if (rt_pin_read(KEY2_PIN_NUM) == PIN_LOW) { rt_thread_mdelay(100); if (rt_pin_read(KEY2_PIN_NUM) == PIN_LOW) { rt_event_send(&event, KEY_EVENT_FLAG2); rt_kprintf("KEY2 pressed!
"); } } else if (rt_pin_read(KEYUP_PIN_NUM) == PIN_HIGH) { rt_thread_mdelay(100); if (rt_pin_read(KEYUP_PIN_NUM) == PIN_HIGH) { rt_event_send(&event, KEY_EVENT_FLAG3); rt_kprintf("KEYUP pressed!
"); } } } void key0(void) { rt_event_send(&event, KEY_EVENT_FLAG0); rt_kprintf("KEY0 pressed!
"); } MSH_CMD_EXPORT(key0, key0); void key1(void) { rt_event_send(&event, KEY_EVENT_FLAG1); rt_kprintf("KEY1 pressed!
"); } MSH_CMD_EXPORT(key1, key1); void key2(void) { rt_event_send(&event, KEY_EVENT_FLAG2); rt_kprintf("KEY2 pressed!
"); } MSH_CMD_EXPORT(key2, key2); void key3(void) { rt_event_send(&event, KEY_EVENT_FLAG3); rt_kprintf("KEY3 pressed!
"); } MSH_CMD_EXPORT(key3, key3); ``````static void led_thread_entry(void* parameter) { rt_uint32_t e; while(1) { if (rt_event_recv(&event, KEY_EVENT_FLAG0, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR, RT_WAITING_FOREVER, &e) == RT_EOK) { g_LEDStatus = 1 << 0; rt_kprintf("led_thread running event0
"); } if (rt_event_recv(&event, KEY_EVENT_FLAG1, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR, RT_WAITING_FOREVER, &e) == RT_EOK) { g_LEDStatus = 1 << 1; rt_kprintf("led_thread running event1
"); } if (rt_event_recv(&event, KEY_EVENT_FLAG2, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR, RT_WAITING_FOREVER, &e) == RT_EOK) { g_LEDStatus = 1 << 2; rt_kprintf("led_thread running event2
"); } if (rt_event_recv(&event, KEY_EVENT_FLAG3, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR, RT_WAITING_FOREVER, &e) == RT_EOK) { g_LEDStatus = 7 << 0; rt_kprintf("led_thread running event3
"); } led_status(g_LEDStatus); rt_thread_delay(500); } } ```
查看更多
1
个回答
默认排序
按发布时间排序
CCXX
2019-09-13
这家伙很懒,什么也没写!
补充一下,任务一的第二个问题后来发现是main里面已经有rt_thread_mdelay函数了。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.8k
关于作者
CCXX
这家伙很懒,什么也没写!
提问
4
回答
4
被采纳
0
关注TA
发私信
相关问题
推荐文章
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
RT-Thread项目助手v0.2.0 - 支持Env Windows
2
RttreadV5.10上,GD32F450Z RTC时间显示问题
3
rt-smart启动流程分析
4
EtherKit快速上手PROFINET
5
RTThread USB转串口无法接收数据
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部