硬汉嵌入式论坛

 找回密码
 立即注册
查看: 393|回复: 3
收起左侧

[技术讨论] freertos临时变量踩坑记

[复制链接]

1

主题

2

回帖

5

积分

新手上路

积分
5
发表于 2024-4-4 17:29:41 | 显示全部楼层 |阅读模式
本帖最后由 chaos_ 于 2024-4-5 11:52 编辑

我在stm32f103上运行了freertos。我的所有自定义的任务优先级都设置为了5,在我的一个线程中,我创建了一个AT数据的解析线程,如图1所示。这个线程不会vtaskdelay,只会在systick中断里让出时间片。
问题来了,当我把下面代码部分,vtaskdelay(2)注释去掉整个工程工作的很好。但我一旦把他注释掉,程序会在创建线程后立马挂掉,进入HardFault。
[C] 纯文本查看 复制代码
#if defined(AT_OS_USED) && defined(MULTITHREAD_ENABLED)
    //  create thread for at parser
    if (NULL != client->parser) {
#define AT_PARSER_THREAD_STACK 1024
#define AT_PARSER_THREAD_PRIORITY 5
      ThreadParams thread_params = {0};
      thread_params.thread_func = client->parser;
      thread_params.thread_name = "at_client_parser";
      thread_params.user_arg = client;
      thread_params.stack_size = AT_PARSER_THREAD_STACK;
      thread_params.priority = AT_PARSER_THREAD_PRIORITY;

      result = HAL_ThreadCreate(&thread_params);
      vTaskDelay(2);
      if (QCLOUD_RET_SUCCESS == result) {
        Log_d("create at_parser thread success!");
      } else {
        Log_i("create at_parser thread fail!");
      }


经过segger的rtos trace分析发现创建线程后第一次切换到at_client_parse线程时上下文切换挂掉了,如图1所示
经过调试发现上下文切换时函数跳转没问题,但是传过来的void *没问题,void *指向的内容变了。如图2所示
加上vtaskdelay(2),创建线程之后给main2延时一下,整个工程工作的很好
串口1被重定向,且被临界区保护。希望有大哥能指点一下。



另外我不是很理解图2里main2线程为什么不1ms发生一次systick中断了,我在这里没关中断啊。

图2

图2

图1

图1
回复

使用道具 举报

1

主题

2

回帖

5

积分

新手上路

积分
5
 楼主| 发表于 2024-4-4 19:43:10 | 显示全部楼层
咋没有图片,咋插入啊
回复

使用道具 举报

1

主题

2

回帖

5

积分

新手上路

积分
5
 楼主| 发表于 2024-4-5 09:22:06 | 显示全部楼层
本帖最后由 chaos_ 于 2024-4-5 10:38 编辑

不知道怎么插图片了
回复

使用道具 举报

1万

主题

6万

回帖

10万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
106771
QQ
发表于 2024-4-5 10:04:18 | 显示全部楼层
chaos_ 发表于 2024-4-4 19:43
咋没有图片,咋插入啊

图片要单独上传,论坛bug了,复制粘贴不行了,进入高级编辑后,单独上传就可以了。
回复

使用道具 举报

1

主题

2

回帖

5

积分

新手上路

积分
5
 楼主| 发表于 2024-4-5 11:42:34 | 显示全部楼层
哦卧槽,ThreadParams thread_params = {0};这玩意是局部变量,不加延时函数运行完空间直接被回收了。改成全局变量果然好使了。一直怀疑是调度的问题,原来是这个原因,segger的这个trace工具确实好用
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|Archiver|手机版|硬汉嵌入式论坛

GMT+8, 2024-5-5 20:14 , Processed in 0.270375 second(s), 29 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表