ESP32-S3学习笔记<1>:ESP-IDF的安装与命令

ESP32-S3学习笔记<1>:ESP-IDF的安装与命令

  • [1. 下载安装包](#1. 下载安装包)
  • [2. 安装](#2. 安装)
  • [3. 命令简介](#3. 命令简介)
    • [3.1 尝试编译](#3.1 尝试编译)
    • [3.2 创建工程命令](#3.2 创建工程命令)
    • [3.2 创建组件](#3.2 创建组件)
    • [3.3 列出支持的器件/设定目标器件](#3.3 列出支持的器件/设定目标器件)
    • [3.4 编译命令](#3.4 编译命令)
    • [3.5 项目配置](#3.5 项目配置)
    • [3.6 下载](#3.6 下载)

1. 下载安装包

点以下地址获取下载安装包:
下载链接

可以直接点击下方的链接去选择版本,也可以选择右侧的release,选择一个之前的版本。

在新页面中,选择要下载的版本。这里选择带有Espressif-IDE 集成开发环境的ESP-IDF 版本。这个版本安装好之后,除了有ESP-IDF 之外,还有Espressif-IDE这个图形化的开发环境。

2. 安装

以管理员权限运行安装包。

下面这一步,有时候系统没有开启长路径支持,需要修复一下。我这里之前在系统中已经打开了长路径支持,所以没有提示需要修复。ESP-IDF包含大量的文件层级,导致许多文件路径过长。因此一定要使能长路径支持。

选择安装路径。我这里选择安装在D盘目录下。安装包会自动添加一个Espressif的尾缀,从而创建文件夹。

按照需求去勾选一些芯片支持。我取消了一些勾选,发现下方占用空间提示也没有什么变化。因此全勾上也无所谓。

安装完成后,最后出线如下界面。可以都勾上。然后点击完成

完成后,会运行ESP-IDF powershellESP-IDF cmd命令行两个窗口。显示内容是完全一样的。

可以看到,提示Done! You can now compile ESP-IDF projects. 。说明ESP-IDF已经安装成功。

安装包会自动添加环境变量IDF_TOOLS_PATH ,值为D:\Espressif 。之前看到一些教程,还需要手动添加一个环境变量IDF_PATH ,值为D:\Espressif\frameworks\esp-idf-v5.3.1(根据真实路径修改)。

3. 命令简介

3.1 尝试编译

D:\Espressif\frameworks\esp-idf-v5.3.1\examples\get-started 路径下的几个项目例程中拷贝一个放到某个路径下,先输入命令idf.py build 尝试编译一下,看看流程有无问题。第一次编译工程的时间是比较长的,大量的编译工作花费在编译ESP-IDF下的一些组件上。耐心等待。

编译完成,提示可以烧录。

3.2 创建工程命令

bash 复制代码
idf.py create-project aeb

该命令在当前路径下创建一个名为aeb的工程。创建完成后,文件夹下的内容为:

bash 复制代码
aeb 
  |----main
  |       |----aeb.c ---------------------> void app_main(void)
  |       |----CMakeLists.txt
  |----CMakeLists.txt

命令首先创建一个名为 aeb 的文件夹,在文件夹中再创建一个名为 main 的文件夹。这个文件夹包含工程的顶层源码文件 aeb.c ,该文件定义了应用入口函数 void app_main(void)

c 复制代码
#include <stdio.h>

void app_main(void)
{

}

同时该目录下还包含一个编译配置文件 CMakeLists.txtCMAKE 构建工具在linux开发中经常看到,ESP-IDF 显然也借鉴了这种构建方法。该文件将源码文件 aeb.c 注册为编译组件。

bash 复制代码
idf_component_register(SRCS "aeb.c"
                    INCLUDE_DIRS ".")

同时,在项目的根目录下,还有一个 CMakeLists.txt 。这个等于是项目的构建文件,后续 build的时候,编译工具从这个文件开始获取整个工程的信息并编译。

bash 复制代码
cmake_minimum_required(VERSION 3.16)

include($ENV{IDF_PATH}/tools/cmake/project.cmake)
project(aeb)

3.2 创建组件

bash 复制代码
idf.py create-component led

该命令在当前目录下创建项目的一个组件。类似于项目的一个部分,比如某个外围设备的驱动或应用代码。组件和前面创建的main共同构成应用(还有ESP-IDF )。实际上也可以不使用这个命令。用这个命令的好处是会自动创建 CMakeLists.txt 这个构建文件。但是这个文件内容比较简单,因此也完全可以自己写.c/.h文件,手动写一个 CMakeLists.txt文件。

3.3 列出支持的器件/设定目标器件

由于 ESP-IDF 支持乐鑫公司的 ESP32 系列多款处理器(前面安装时可以看到支持的器件)。因此创建的工程究竟使用哪一款处理器是不确定的(默认是 ESP32 )。所以需要设定目标器件。在设定之前,可以用如下命令查看当前 ESP-IDF 支持哪些器件。

bash 复制代码
idf.py --list-targets
bash 复制代码
PS C:\Users\Administrator\Desktop\test\aeb> idf.py --list-targets
esp32
esp32s2
esp32c3
esp32s3
esp32c2
esp32c6
esp32h2
esp32p4
PS C:\Users\Administrator\Desktop\test\aeb>

用如下命令设定目标器件:

bash 复制代码
idf.py set-target esp32s3

执行这条命令后,项目文件夹下会多出一个 sdkconfig 文件和一个 build 文件夹。

3.4 编译命令

bash 复制代码
idf.py build

3.5 项目配置

用如下命令配置工程SDK的相关功能。相当于提供了一套半图形化的界面来配置sdkconfig文件。(有些类似于nrf52开发中的sdk_config)。

bash 复制代码
 idf.py menuconfig

3.6 下载

用如下命令下载目标文件至处理器。

bash 复制代码
 idf.py -p COM9 flash

ESP32-S3的固件一般情况下是用串口烧录的。这里要指定连接到电脑的串口端口号。


相关推荐
思扬09285 小时前
前端学习日记 - 前端函数防抖详解
前端·学习
芥子须弥Office7 小时前
从C++0基础到C++入门 (第二十五节:指针【所占内存空间】)
c语言·开发语言·c++·笔记
Starry_hello world8 小时前
MySql 表的操作
数据库·笔记·mysql
小郝 小郝9 小时前
开启单片机
c语言·单片机·嵌入式硬件·学习·51单片机
使二颗心免于哀伤10 小时前
《设计模式之禅》笔记摘录 - 14.组合模式
笔记·设计模式·组合模式
小杜的生信筆記10 小时前
基于R语言,“上百种机器学习模型”学习教程 | Mime包
开发语言·学习·机器学习·r语言·sci
ZHSH.10 小时前
20250810 | 深度学习入门笔记1
笔记
慕y27410 小时前
Java学习第一百二十二部分——HTTPS
网络协议·学习·https
teeeeeeemo13 小时前
Ajax、Axios、Fetch核心区别
开发语言·前端·javascript·笔记·ajax
鲸鱼在dn13 小时前
RAG-大模型课程《李宏毅 2025》作业1笔记
人工智能·笔记·gpt·搜索引擎·语言模型·chatgpt