目录
开发环境
- 沁恒CH32V307官方测试版R1、RT-Thread Studio、使用AT设备连接wifi(esp8266-01s)、paho mqtt软件包
问题与解决
在使用pahomqtt的测试例程时,执行完mqtt_start命令,没有任何显示信息。调试打开后发现是rt_thread_create
函数这里出现问题,返回的tid为0,线程根本没有创建成功。
进去函数之后发现是在RT_KERNEL_MALLOC
这里出错了,动态内存分配失败咯,看来是堆不够用了,有两种解决方法:
- 加大堆内存
- 减少动态分配的内存
mqtt线程设置分配的是4096的栈大小,堆动态分配不够用,我选择将4096变为2048,然后编译下载,连接确实成功了,但是有了新问题。
其它线程还有需要动态分配内存,堆还是不够用,可以在msh
用free
命令看看堆的使用情况:
没办法了,只能加大堆内存了。打开board.c
文件,在这里可以修改堆内存的大小,可以看到,我加大了一点点,从4096*4字节
到了6144*4字节
。
然后编译、下载,mqtt成功连接了。