ESP32开发教程(1)— 搭建开发环境(Ubuntu简易版)

简介: ESP32开发教程(1)— 搭建开发环境(Ubuntu简易版)

前言

       本文基于 Ubuntu 20.04 和 ESP-IDF 5.1,搭建 ESP32 最新代码的编译环境。记录搭建环境的整个流程步骤和必要的安装命令。如果需要学习更加详细的搭建环境知识,可参考官方 ESP-IDF 编程指南

1 安装准备

编译 ESP-IDF 需要以下软件包支持,输入指令进行安装;

sudo apt-get install git wget flex bison gperf python3 python3-venv python3-setuptools cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0

以上软件包安装成功以后,我们还需要确定两个软件包的版本是否满足 ESP-IDF 的需求。

1.1 Python版本

目前,ESP-IDF 4.3 以上的版本都是基于 python3 进行构建。所以我们需要检查一下 python3 有没有安装成功。输入指令查看:

python3 --version

当输出 Python 3.x.x 时,python3 软件包安装成功。如果输出 Python 2.x.x,那么需要重新输入命令安装 python3,或者去 python 官网下载软件包手动安装。

1.2 Cmake版本

使用 ESP-IDF (5.1)需要 CMake 3.16 或以上版本,输入指令查看:

cmake --version

当输出 cmake version 3.x.x (高于 3.16)时,camke 软件包安装成功。

2 获取 ESP-IDF

在围绕 ESP32 构建应用程序之前,需要先获取乐鑫提供的软件库文件 ESP-IDF 仓库

获取 ESP-IDF 的本地副本:打开终端,切换到要保存 ESP-IDF 的工作目录,使用 git clone 命令克隆远程仓库。

打开终端,输入以下命令:

mkdir -p ~/esp
cd ~/esp
git clone --recursive https://github.com/espressif/esp-idf.git

ESP-IDF 将下载至 ~/esp/esp-idf。

3 设置工具

除了 ESP-IDF 本身,还需要为支持 ESP32 的项目安装 ESP-IDF 使用的各种工具,比如编译器、调试器、Python 包等。

ESP32 官方为我们提供了安装脚本 install.sh,输入以下指令安装:

cd ~/esp/esp-idf
export IDF_GITHUB_ASSETS="dl.espressif.com/github_assets"
./install.sh esp32

上述命令仅仅为 ESP32 安装所需工具。如果需要为多个目标芯片开发项目,则可以一次性指定多个目标,如下所示:

cd ~/esp/esp-idf
export IDF_GITHUB_ASSETS="dl.espressif.com/github_assets"
./install.sh esp32,esp32s2

如果需要一次性为所有支持的目标芯片安装工具,可以运行如下命令:

cd ~/esp/esp-idf
export IDF_GITHUB_ASSETS="dl.espressif.com/github_assets"
./install.sh all

ESP-IDF 工具安装器会下载 Github 发布版本中附带的一些工具,如果访问 Github 较为缓慢,可以设置一个环境变量,从而优先选择 Espressif 的下载服务器进行 Github 资源下载。

(上述我们已经使用了:export IDF_GITHUB_ASSETS="dl.espressif.com/github_assets")

4 设置环境变量

此时,刚刚安装的工具尚未添加至 PATH 环境变量,无法通过“命令窗口”使用这些工具。因此,必须设置一些环境变量。这可以通过 ESP-IDF 提供的另一个脚本进行设置。

在需要运行 ESP-IDF 的终端窗口运行以下命令:

. $HOME/esp/esp-idf/export.sh

这样比较麻烦,每次获取 esp-idf 环境,都需要输入一大段命令。我们可以为执行 export.sh 创建一个别名,具体步骤如下:

(1) 使用 gedit 打开 .bashrc 配置文件;

sudo gedit ~/.bashrc

(2) 复制并粘贴以下命令到 .bashrc 配置文件中;

alias get_idf='. $HOME/esp/esp-idf/export.sh'

粘贴完成后,使用 CTRL+S 快捷键保存内容,然后点击右上角“x”,关闭 .bashrc 文档。

(3) 输入指令,刷新配置环境并重启;

1. source ~/.bashrc
2. reboot

这样我们可以在任何终端窗口中运行 get_idf 来设置或刷新 esp-idf 环境。

5 开始创建工程

我们可以从 ESP-IDF 中 examples 目录下的 get-started/hello_world 工程开始。

get-started/hello_world 工程复制至本地的 ~/esp 目录下:

1. cd ~/esp
2. cp -r $IDF_PATH/examples/get-started/hello_world .

6 连接设备

将 ESP32 开发板连接到 PC(虚拟机中),输入指令查看开发板使用的串口。

sudo ls /dev/tty*

一般设备名称的最后一个,就是 ESP32 开发板在虚拟机上映射的串口名称(如 ttyUSB0 或者 ttyACM0)。记住该串口名,后续烧录和监控中需要使用。

7 配置工程

进入 hello_world 目录,设置 ESP32 为目标芯片,然后运行工程配置工具 menuconfig。

cd ~/esp/hello_world
idf.py set-target esp32
idf.py menuconfig

打开一个新工程后,应首先使用 idf.py set-target esp32 设置“目标”芯片。注意,此操作将清除并初始化项目之前的编译和配置(如有) 。

可以使用 menuconfig 设置项目的具体变量,包括 Wi-Fi 网络名称、密码和处理器速度等。hello_world 示例项目会以默认配置运行,因此在这一项目中,可以跳过使用 menuconfig 进行项目配置这一步骤。

8 编译工程

使用以下指令,编译烧录工程:

idf.py build

运行以上指令可以编译应用程序和所有 ESP-IDF 组件,接着生成引导加载程序(bootloader.bin)、分区表(partition-table.bin)和应用程序二进制文件(xxxx.bin)。

如果一切正常,编译完成后将生成 .bin 文件。

9 烧录到设备

运行以下指令,将刚刚生成的二进制文件烧录至 ESP32 开发板:

idf.py -p /dev/ttyUSB0 flash

如果一切顺利,烧录完成后,开发板将会复位,应用程序 “hello_world” 开始运行。

10 监视输出

可以使用 idf.py -p PORT monitor 命令,监视 “hello_world” 工程的运行情况。注意,不要忘记将 PORT 替换为第 6 步查看的串口名称。

idf.py -p /dev/ttyUSB0 monitor

运行该命令后,IDF 监视器 应用程序将启动。

此时,就可以在启动日志和诊断日志之后,看到打印的 “Hello world!” 了。

可使用快捷键 Ctrl+],退出 IDF 监视器

11 清除工程

当我们需要清除刚刚编译和配置的文件时,ESP-IDF 提供了两种清除指令。

11.1 idf.py clean

可以使用 idf.py clean 命令从生成目录中删除项目生成输出文件。

该项目将在下次构建时被完全重建。使用这个方法并不会删除构建文件夹中的 CMake 配置输出。

11.2 idf.py fullclean

运行此命令将删除整个 "build" 目录的内容。这包括所有的 CMake 配置输出。下次构建项目时,CMake 将从头开始配置它。注意,这个选项会递归地删除构建目录中的所有文件,所以要小心使用。项目配置不会被删除。

总结

       完成以上 ESP-IDF 编译环境的搭建和 hello_world 工程的编译—>下载—>运行—>监控。恭喜,您已完成 ESP32 的入门学习!



相关文章
|
7月前
|
人工智能 Ubuntu 数据可视化
【详细教程】如何在Ubuntu上本地部署Dify?
Dify 是一个开源的大语言模型应用开发平台,支持低代码/无代码开发,提供多模型接入、Agent框架、RAG检索增强生成等功能,助力快速构建AI应用。支持本地部署,提供详尽文档与可视化界面,适用于聊天助手、文本生成、自动化任务等多种场景。
8033 124
|
7月前
|
人工智能 安全 Ubuntu
保姆级教程 | 在Ubuntu上部署Claude CodeUI全过程
Claude Code Plan Mode 是 Anthropic 推出的智能编程助手功能,采用只读分析模式,保障代码安全的同时提供AI驱动的项目规划与风险评估。该模式平均每周为开发者节省27小时,显著提升开发效率与项目成功率,是AI编程领域的重要创新。
9058 10
|
9月前
|
IDE Ubuntu Java
在Ubuntu18.04安装兼容JDK 8的Eclipse集成开发环境的指南。
完成以上步骤后,您将在Ubuntu 18.04系统上成功安装并配置了Eclipse IDE,它将与JDK 8兼容,可以开始进行Java开发工作。如果遇到任何问题,请确保每一步骤都正确执行,并检查是否所有路径都与您的具体情况相匹配。
413 11
|
9月前
|
Kubernetes 负载均衡 Ubuntu
Kubernetes安装详细教程 Ubuntu版
本教程基于Ubuntu 22.04配置Kubernetes环境,涵盖依赖安装、swap关闭、内核参数调整、containerd与Kubernetes组件安装、集群初始化及CNI网络插件部署等内容,并提供常见问题处理方法和相关工具推荐。
|
8月前
|
Ubuntu Linux Shell
Ubuntu GRUB菜单密码重置教程
本文详细介绍了在Ubuntu 16.04系统中通过GRUB菜单找回密码的方法。包括进入GRUB引导菜单、修改内核参数、重置用户密码及完成重启的完整步骤,帮助用户快速恢复系统访问权限。
883 0
|
11月前
|
Ubuntu 搜索推荐 Linux
详解Ubuntu的strings与grep命令:Linux开发的实用工具。
这就是Ubuntu中的strings和grep命令,透明且强大。我希望你喜欢这个神奇的世界,并能在你的Linux开发旅程上,通过它们找到你的方向。记住,你的电脑是你的舞台,在上面你可以做任何你想做的事,只要你敢于尝试。
504 32
|
10月前
|
存储 缓存 Ubuntu
Ubuntu 20.04修改swap交换空间教程
记得时不时回顾和调整这些设置,来保持你的Ubuntu系统运行得像一只猎豹—迅捷无比。现在,你已经成功地为你的Ubuntu系统完成了大脑扩容手术,让它有了更多的空间去处理更复杂的思维任务。舒服地坐回到你的椅子上,享受更加流畅的电脑体验吧!
687 12
|
10月前
|
Ubuntu Linux 数据安全/隐私保护
Windows中安装WSL 2和Ubuntu系统的教程
回看这一路,有趣吧?你已经跨界成为了一个Windows和Linux的桥梁。期待在代码的世界里,把一切玩得风生水起!
548 13
|
8月前
|
Ubuntu 网络协议 Unix
Linux教程(Ubuntu为蓝本)之Linux介绍篇
SuSE嫁到了Novell,SCO继续顶着骂名四处强行“化缘”, Asianux, MandrakeSoft也在五年中首次宣布季度赢利。3月,SGI宣布成功实现了Linux操作系统支持256个Itanium 2处理器。[1-2]
|
8月前
|
Ubuntu Linux 数据安全/隐私保护
Win10安装Linux子系统教程!如何在Win10系统中安装Ubuntu!
登录系统后,输入cd /返回上一级,然后再输入“ls”查看一下系统文件目录,看看对不对!