Espressif 物联网开发框架

2023-10-07 03:10
文章标签 开发 框架 联网 espressif

本文主要是介绍Espressif 物联网开发框架,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ESP-IDF 是乐鑫官方推出的物联网开发框架,支持 Windows、Linux 和 macOS 操作系统。

文章目录

  • ESP-IDF 与乐鑫芯片
  • 使用 ESP-IDF 进行开发
    • 搭建 ESP-IDF 开发环境
      • 非 GitHub 分叉的 ESP-IDF 项目
    • 寻找项目
  • 快速参考(一些常用命令)
    • 设置构建环境
    • 配置项目
    • 编译项目
    • 烧写项目
    • 观察串口输入
    • 仅编译并烧写应用程序
    • 擦除 Flash
  • 其它参考资源

ESP-IDF 与乐鑫芯片

下表总结了乐鑫芯片在 ESP-IDF 各版本中的支持状态,其中 alt text 代表已支持,alt text 代表目前处于预览支持状态。在预览支持阶段,因为新芯片尚未完全添加到构建系统目录,所以一些重要的内容(如文档和技术规格书等)可能会缺失。请确保使用与芯片相匹配的 ESP-IDF 版本。

芯片v3.3v4.0v4.1v4.2v4.3v4.4
ESP32alt textalt textalt textalt textalt textalt text
ESP32-S2alt textalt textalt text
ESP32-C3alt textalt text
ESP32-S3alt textalt text芯片发布公告
ESP32-H2alt text芯片发布公告

对于 2016 年之前发布的乐鑫芯片(包括 ESP8266 和 ESP8285),请参考 RTOS SDK。

使用 ESP-IDF 进行开发

搭建 ESP-IDF 开发环境

关于不同芯片如何搭建 ESP-IDF 的开发环境,请参考 https://idf.espressif.com/ 。

注意: 不同系列芯片和不同 ESP-IDF 版本都有其对应的文档。请参阅版本部分,获得关于如何查找文档以及如何检出 ESP-IDF 的特定发行版的详细信息。

非 GitHub 分叉的 ESP-IDF 项目

ESP-IDF 中的子模块采用相对路径(详见 .gitmodules 文件),所以它们会指向 GitHub。
如果 ESP-IDF 被分叉到的仓库不在 GitHub 上,那么你需要在克隆结束后运行该脚本 tools/set-submodules-to-github.sh。

这个脚本会为所有的子模块设置绝对路径,接着可以通过 git submodule update --init --recursive 完成子模块的更新。
如果 ESP-IDF 是从 GitHub 上克隆得到,则不需要此步骤。

寻找项目

除了入门指南中提到的 esp-idf 模板项目,ESP-IDF 的 examples 目录下还带有很多其它示例项目。

一旦找到了需要的项目,便可以进入该目录,执行配置和构建操作。

如果要基于示例工程开始你自己的项目,请将示例工程复制到 ESP-IDF 目录之外。

快速参考(一些常用命令)

详细的使用方法请参考上面入门指南的链接,这里仅仅列举一些 ESP-IDF 项目开发中常用的命令:

设置构建环境

请参考入门指南中列出的详细步骤。

  • 在主机中安装入门指南中提到的构建所依赖的工具。
  • 运行安装脚本来设置构建环境。可为 Windows shell 选择 install.batinstall.ps1,为 Unix shell 选择 install.shinstall.fish
  • 在使用 ESP-IDF 之前,需要在 shell 中运行导出脚本。Windows 下可运行 export.bat,Unix 下可运行 source export.sh

配置项目

  • idf.py set-target <chip_name> 可将项目的目标芯片设置为 <chip_name>。运行 idf.py set-target,不用带任何参数,可查看所有支持的目标芯片列表。
  • idf.py menuconfig 可打开一个基于文本的配置菜单,可以用来对项目进行配置。

编译项目

idf.py build

编译应用程序,引导程序,并根据配置生成分区表。

烧写项目

当构建结束,终端会打印出一条命令行,告知如何使用 esptool.py 工具烧写项目到芯片中。但你也可以运行下面这条命令来自动烧写:

idf.py -p PORT flash

将其中的 PORT 替换为系统中实际串口的名字(比如 Windows 下的 COM3,Linux 下的 /dev/ttyUSB0,或者 macOS 下的 /dev/cu.usbserial-X。如果省略 -p 选项,idf.py flash 会尝试使用第一个可用的串口进行烧写。

这会烧写整个项目(包括应用程序,引导程序和分区表)到芯片中,此外还可以使用 idf.py menuconfig 来调整串口烧写相关的配置。

不必先运行 idf.py build 再运行 idf.py flashidf.py flash 会根据需要自动重新构建项目。

观察串口输入

idf.py monitor 会调用 idf_monitor 工具来显示乐鑫芯片的串口输出。idf_monitor 还包含一系列的功能来解析程序崩溃后的输出结果并与设备进行交互。更多详细内容,请参阅文档.

输入 Ctrl-] 可退出监视器。

想要一次性执行构建、烧写和监视,可以运行如下命令:

idf.py flash monitor

仅编译并烧写应用程序

在第一次烧写过后,你可能只想构建并烧写你的应用程序,不包括引导程序和分区表:

  • idf.py app - 仅构建应用程序。
  • idf.py app-flash - 仅烧写应用程序。

idf.py app-flash 会自动判断是否有源文件发生了改变然后重新构建应用程序。

(在正常的开发中,即使引导程序和分区表没有发生变化,每次都重新烧写它们并不会带来什么危害。)

擦除 Flash

idf.py flash 并不会擦除 flash 上所有的内容,但是有时候我们需要设备恢复到完全擦除的状态,尤其是分区表发生了变化或者 OTA 应用升级时。要擦除整块 flash 请运行 idf.py erase-flash

这条命令还可以和其余命令整合在一起,idf.py -p PORT erase-flash flash 会擦除一切然后重新烧写新的应用程序、引导程序和分区表。

其它参考资源

  • 最新版的文档:https://docs.espressif.com/projects/esp-idf/ ,该文档是由本仓库 docs 目录 构建得到。

  • 可以前往 esp32.com 论坛 提问,挖掘社区资源。

  • 如果你在使用中发现了错误或者需要新的功能,请先查看 GitHub Issues,确保该问题没有重复提交。

  • 如果你有兴趣为 ESP-IDF 作贡献,请先阅读贡献指南。

这篇关于Espressif 物联网开发框架的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/155681

相关文章

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核