ESP32编译及运行错误记录

news2025/4/6 3:55:00

1、打印格式不对

一般都是因为日志中某个参数打印格式不匹配造成。

ESP_LOGI(TAG, "[APP] Free memory: %lu bytes", esp_get_free_heap_size());//将之前的%d 改为%lu

2、配置载不对 这里选择了蓝牙模块需要引入蓝牙组件才能编译通过

  1. idf.py menuconfig Component config –> Bluebooth –> 消除使能 不添加蓝牙模块直接编译

3、未加载到blufi配网的功能函数,这里我在使用nimble模块后打开blufi功能编译

in function `example_event_callback':
/home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:275: undefined reference to `esp_blufi_adv_start'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:312: undefined reference to `esp_blufi_send_wifi_conn_report'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:255: undefined reference to `esp_blufi_send_error_info'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:257: undefined reference to `esp_blufi_adv_start'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:265: undefined reference to `esp_blufi_adv_stop'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:265: undefined reference to `esp_blufi_send_custom_data'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:291: undefined reference to `esp_blufi_send_error_info'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:306: undefined reference to `esp_blufi_send_wifi_conn_report'
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: /home/huqin/code/GS368/build/../components/sit_lib_network/src/sit_lib_network.c:310: undefined reference to `esp_blufi_send_wifi_conn_report'

找不到组件库文件。

于子模块添加组件库(试过在主函数cmake中添加依然找不到)一般都是缺啥头文件找到IDF中对应的组件库添加进来即可。

df_component_register(SRCS "${component_srcs}"
                       INCLUDE_DIRS "." "include"
                       PRIV_INCLUDE_DIRS ""
                       PRIV_REQUIRES ""
                       REQUIRES  "mbedtls" #添加组件库
                       "fatfs" "nvs_flash" "app_update" "bt" "esp_wifi" "freertos" "json" "esp_http_client" "app_update"  "lwip" "esp_netif" "esp_https_ota"
                       )

出现:若编译出现函数声明找不到可以查看对应头文件是否被宏隔断 一般需要通过配置使能宏才可以使用函数

经测试发现因为配置中未开放此宏导致函数声明找不到。

修改menuconfig后重新编译成功 如下:

4、函数冲突

../user/wifi/blufi_connect.c:391:9: error: implicit declaration of function 'blufiprph_advertise'; did you mean 'bleprph_advertise'? [-Werror=implicit-function-declaration]
  391 |         blufiprph_advertise();
      |         ^~~~~~~~~~~~~~~~~~~
      |         bleprph_advertise
../user/wifi/blufi_connect.c: At top level:
../user/wifi/blufi_connect.c:674:1: warning: conflicting types for 'blufiprph_advertise'; have 'void(void)'
  674 | blufiprph_advertise(void)
      | ^~~~~~~~~~~~~~~~~~~
../user/wifi/blufi_connect.c:674:1: error: static declaration of 'blufiprph_advertise' follows non-static declaration
../user/wifi/blufi_connect.c:391:9: note: previous implicit declaration of 'blufiprph_advertise' with type 'void(void)'
  391 |         blufiprph_advertise();
      |         ^~~~~~~~~~~~~~~~~~~
cc1: some warnings being treated as errors

跟组件中包含的函数冲突,修改函数名后未声明。

5、BLUFI_CUSTOM_DATA 结构体未定义,当时未使用typedef重命名导致找不到。

/user/wifi/blufi_connect.c:668:22: error: expected declaration specifiers or '...' before 'BLUFI_CUSTOM_DATA'

6、OTA固件升级错误 由于使用https下载未加证书验证导致服务器配置不对下载失败。

I (21099) advanced_https_ota_example: Starting Advanced OTA example
I (21109) advanced_https_ota_example: OTA started
E (21119) esp_https_ota: No option for server verification is enabled in esp_http_client config.
E (21129) advanced_https_ota_example: ESP HTTPS OTA Begin failed

7、snprintf入参指针类型不对, 修改uint8_t*改为 char*。

pointer targets in passing argument 1 of 'snprintf' differ in signedness

8、multiple definition of `device_data';多重定义问题

根本原因:由于结构体对象存在多个导致,(我这里因为在头文件中使用结构体类型定义对象,并头文件被多个模块包含,导致存在多个全局对象)

修改:对象定义在对于的源文件中,在其他文件中使用extern 访问对象。

9.undefined reference to `vTaskList'

原因:未找到函数 没有配置需要按照如下设置。

10、重复定义 在一个头文件中定义的全局变量被多个源文件包含 会出现多处定义。

/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: esp-idf/main/libmain.a(sit_app_networkTask.c.obj):
/home/huqin/code/GS368/build/../components/sit_lib_network/include/sit_flash.h:21: multiple definition of `SerialNumber'; 
esp-idf/main/libmain.a(GS368_main.c.obj):/home/huqin/code/GS368/build/../components/sit_lib_network/include/sit_flash.h:21: first defined here
/home/huqin/.espressif/tools/riscv32-esp-elf/esp-2022r1-11.2.0/riscv32-esp-elf/bin/../lib/gcc/riscv32-esp-elf/11.2.0/../../../../riscv32-esp-elf/bin/ld: esp-idf/main/libmain.a(sit_aws_iot_main.c.obj):
/home/huqin/code/GS368/build/../components/sit_lib_network/include/sit_flash.h:21: multiple definition of `SerialNumber'; 
esp-idf/main/libmain.a(GS368_main.c.obj):/home/huqin/code/GS368/build/../components/sit_lib_network/include/sit_flash.h:21: first defined here

11.mbedTLS未找到加密函数

解决:使能DMH的配置文件

12、连接服务器一直会在ssl创建会话验证证书时失败 内存申请失败

更改动态申请后有时也会出现 Dynamic Impl: alloc(zu bytes) failed

I (11916) coreMQTT: Establishing a TLS session to a22kpq659tmps7-ats.iot.us-west-2.amazonaws.com:8883.
E (14496) Dynamic Impl: alloc(zu bytes) failed
E (14496) esp-tls-mbedtls: mbedtls_ssl_handshake returned -0x7F00
I (14496) esp-tls-mbedtls: Certificate verified.
E (14506) esp-tls: Failed to open new connection

最后是因为蓝牙协议栈开启导致占用内存太多,配网后重启不初始化并开启蓝牙解决问题。(以上配置未使用)

13、内存使用检测方法

图形化检测内存使用情况

需要依靠 vscode 或者 eclipse 来实现。

vTaskList() 可以用来分析操作系统当前 task 状态:

FreeRTOS 接口: vTaskList() - 可优化内存和 task 栈溢出定位_乐鑫科技 Espressif的博客-CSDN博客

vTaskGetRunTimeStats() 可以用来分析操作系统当前 task CPU 占用状态:

FreeRTOS 接口: vTaskGetRunTimeStats() - 可解决 task watchdog 和调优 task 优先级_乐鑫科技 Espressif的博客-CSDN博客

14、使用memcpy给结构体赋值时C语言,结构体,打印某个结构体成员值会带有其它结构体成员的值!

结构体成员不是一个以\0结尾的字符串,而%s只能用来输出以\0结尾的字符串,因为它只有遇到\0才会停下来。

解决方法:将结构图成员大小进行增大,初始化为0时会默认赋值\0.

15、获取ESP设备信息方式

espefuse.py -p /dev/ttyUSB0 summary //efuse设备信息
使用esptool.py --no-stub get_security_info读取的信息

 16、固件太大使用内存变多

参考这个链接减少 heap 使用:Minimizing RAM Usage - ESP32-C3 - — ESP-IDF Programming Guide latest documentation"

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

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

相关文章

项目中的MD5、盐值加密

首先介绍一下MD5,而项目中用的是MD5和盐值来确保密码的安全性; 1. md5简介 md5的全称是md5信息摘要算法(英文:MD5 Message-Digest Algorithm ),一种被广泛使用的密码散列函数,可以产生一个128位…

css-盒模型

巧妙运用margin负值盒模型和怪异盒模型(border padding 包含在内)display: block 能让textarea input 水平尺寸自适应父容器? – 不能 * {box-sizing: border-box; // bs: bb }<textarea/> 是替换元素,尺寸由内部元素决定,不受display水平影响. 当然可以直接设置宽度10…

React(三):脚手架、组件化、生命周期、父子组件通信、插槽、Context

React&#xff08;三&#xff09;一、脚手架安装和创建1.安装脚手架2.创建脚手架3.看看脚手架目录4.运行脚手架二、脚手架下从0开始写代码三、组件化1.类组件2.函数组件四、React的生命周期1.认识生命周期2.图解生命周期&#xff08;1&#xff09;Constructor&#xff08;2&…

Allegro如何导入第一方网表操作指导

Allegro如何导入第一方网表操作指导 在启动PCB设计之前,网表的导入是首要的流程,第一方网表内容如下图 如何将第一方网表导入到PCB中,具体操作如下 点击File点击Import

【项目】用户管理系统

一、需求分析完成一个简单的用户信息管理系统&#xff0c;超级管理员可以登录本系统&#xff0c;查询用户信息、实现用户的管理功能。1.1功能&#xff1a;主要操作和管理的对象&#xff1a;用户。用户分为两类&#xff1a;超级管理员/普通用户。登录功能&#xff08;只针对超管…

深入理解多进程

多进程 一、进程状态 二、创建子进程 - fork 1、函数接口 #include <unistd.h>pid_t fork(void);2、基本概述 成功后&#xff0c;子进程的 PID 在父进程中返回&#xff0c;在子进程中返回 0。 失败时&#xff0c;在父进程中返回 -1&#xff0c;不创建子进程&#xff0c…

MyBatis——进阶操作(2)

标签 if标签 当提交的表单中有些为非必填项&#xff0c;用户并没有上传这些属性的值&#xff0c;那么程序可以上传NUll&#xff0c;也可以用if标签判断用户有没有上传这个值 <if test"参数!null">操作 </if>其中test中填写一条语句&#xff0c;如果得…

uniapp实现地图点聚合功能

前言 在工作中接到的一个任务&#xff0c;在app端实现如下功能&#xff1a; 地图点聚合地图页面支持tab切换&#xff08;设备、劳务、人员&#xff09;支持人员搜索显示分布 但是uniapp原有的map标签不支持点聚合功能&#xff08;最新的版本支持了点聚合功能&#xff09;&am…

爬虫碎碎念

20230304 - &#xff08;非专业人士&#xff0c;简单记录自己的需求和思考&#xff09; 0. 引言 平时看到一些网站的照片什么的&#xff0c;有那种批量下载的需求&#xff0c;当然有些也是视频网站的图片介绍什么的&#xff0c;也即是说&#xff0c;我需要把这些网站的照片批…

剑指 Offer II 013. 二维子矩阵的和

题目链接 剑指 Offer II 013. 二维子矩阵的和 mid 题目描述 给定一个二维矩阵 matrix&#xff0c;以下类型的多个请求&#xff1a; 计算其子矩形范围内元素的总和&#xff0c;该子矩阵的左上角为 (row1, col1)&#xff0c;右下角为 (row2, col2)。 实现 NumMatrix类&#xf…

测开:前端基础-css

一、CSS介绍和引用 1.1 css概述 层叠样式表&#xff0c;是一种样式表语言&#xff0c;用来描述HTML和XML文档的呈现。 CSS 用于简化HTML标签&#xff0c;把关于样式部分的内容提取出来&#xff0c;进行单独的控制&#xff0c;使结构与样式分离开发。 CSS 是以HTML为基础&…

docker环境下安装jenkins

前言 废话不多说&#xff0c;上来就是干&#xff0c;jenkins是干嘛用的&#xff0c;小白的话&#xff0c;自己去查&#xff0c;首先我的环境时centos7&#xff0c;自己在vmware建立的一套centos虚拟机环境。docker版本如图所示: 第一步 其实可以先查看一下又那些镜像jenkin…

DC-5 靶场学习

文章目录环境配置&#xff1a;信息搜集&#xff1a;漏洞测试&#xff1a;漏洞利用&#xff1a;提权&#xff1a;得到flag&#xff1a;下载地址&#xff1a;环境配置&#xff1a; 直接将其与攻击机放在同一网段。 信息搜集&#xff1a; arp-scan -l nmap -sP 192.168.28.0/24漏…

基于SSH的网上图书俱乐部的设计与实现

技术&#xff1a;Java、JSP等摘要&#xff1a;网上图书俱乐部是一个虚拟的书友会&#xff0c;该平台是为了给那些爱好读书的人提供一个网上交流的场所。以服务广大读者朋友为主&#xff0c;强调互动性、知识性、趣味性&#xff0c;是读书、会友的好去处&#xff0c;读者可以在线…

【Spring学习】Spring自定义标签详细步骤

目录标题前言一、自定义标签步骤1、定义属性POJO2、定义XSD文件描述组件内容3、定义标签解析器4、注册标签解析器5、定义spring.handlers和spring.schemas文件6、user.xml文件配置7、测试类二、仓库位置总结前言 Spring中除了http://www.springframework.org/schema/beans命名…

pytorch-在竞赛中去摸索用法,用房价预测比赛了解数据处理流程

实战Kaggle比赛&#xff1a;房价预测 让我们动手实战一个Kaggle比赛&#xff1a;房价预测House Prices - Advanced Regression Techniques | Kaggle。本文将提供未经调优的数据的预处理、模型的设计和超参数的选择。通过动手操作、仔细观察实验现象、认真分析实验结果并不断调…

5分钟被美团面试官请出去,3年测试经验被这几个题问到心虚

5分钟前&#xff1a;“哥们我去美团面试了&#xff01;祝我好运~”5分钟后&#xff1a;“刚从美团走出来&#xff0c;被自动化测试的一些面试题难到了…”“越想越觉得可惜回想面试经过&#xff0c;在几个关键的问题没有给到面试官想要的答案。”“我不是不会&#xff0c;我都干…

工业互联网标识解析二节节点平台_能源管理工业互联网大数据平台

能源管理工业互联网大数据平台项目&#xff0c;是由吉佳通达负责建设的&#xff0c;通过建设形成能源管理的数字化产业基地&#xff0c;推动能源数字化转型升级&#xff0c;形成大数据运营平台。以能源管理与各个企业节点进行数据对接后&#xff0c;利用工业互联网唯一标识身份…

几个C语言容易忽略的问题

1 取模符号自增问题 我们不妨尝试写这样的程序 #include<stdio.h> int main(){int n,t5;printf("%d\n",7%(-3));//1printf("%d\n",(-7)%3);//-1while(--t)printf("%d\n",t);t5;while(t--)printf("%d\n",t);return 0; } 运行…

十、Spring IoC注解式开发

1 声明Bean的注解 负责声明Bean的注解&#xff0c;常见的包括四个&#xff1a; ComponentControllerServiceRepository Controller、Service、Repository这三个注解都是Component注解的别名。 也就是说&#xff1a;这四个注解的功能都一样。用哪个都可以。 只是为了增强程序…