ESP8266_Linux环境搭建

工具链设置

适用于 Linux 的 ESP8266 工具链可从 Espressif 网站下载:

对于 64 位 Linux:

https://dl.espressif.com/dl/xtensa-lx106-elf-gcc8_4_0-esp-2020r3-linux-amd64.tar.gz

对于 32 位 Linux:

https://dl.espressif.com/dl/xtensa-lx106-elf-gcc8_4_0-esp-2020r3-linux-i686.tar.gz

1. 下载此文件,然后将其解压缩到~/esp目录中(不能在widsows下解压!!!):

mkdir -p ~/esp

cd ~/esp

tar -xzf ~/Downloads/xtensa-lx106-elf-linux64-1.22.0-100-ge567ec7-5.2.0.tar.gz

2. 工具链将被提取到~/esp/xtensa-lx106-elf/目录中。

要使用它,您需要更新文件PATH中的环境变量/.profile。要使xtensa-lx106-elf所有终端会话可用,请将以下行添加到您的/.profile文件中(也可以再~/.bashrc中添加化境变量):

export PATH="$PATH:$HOME/esp/xtensa-lx106-elf/bin"

或者,您可以为上述命令创建一个别名。这样您就可以仅在需要时获取工具链。为此,请在~/.profile文件中添加不同的行:

alias get_lx106='export PATH="$PATH:$HOME/esp/xtensa-lx106-elf/bin"'

然后,当您需要工具链时,您可以get_lx106在命令行中键入,工具链将添加到您的PATH.

笔记

如果您已/bin/bash设置为登录 shell,并且两者都.bash_profile存在.profile,则.bash_profile改为更新。

3.注销并重新登录以使.profile更改生效。运行以下命令来验证是否PATH设置正确:>

printenv PATH

您正在寻找在显示字符串末尾包含工具链路径的类似结果:

$ printenv PATH

/home/user-name/bin:/home/user-name/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/home/user-name/esp/xtense-lx106-elf/bin

而不是/home/user-name应该有一个特定于您的安装的主路径

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7tkLbMew-1675994117884)(file:///C:/Users/Administrator/AppData/Local/Temp/msohtmlclip1/01/clip_image002.jpg)]


获取 ESP8266_RTOS_SDK

除了工具链(包含编译和构建应用程序的程序)之外,您还需要 ESP8266 特定的 API / 库。它们由 Espressif 在ESP8266_RTOS_SDK 存储库中提供。

要获取本地副本:打开终端,导航到要放置 ESP8266_RTOS_SDK 的目录,然后使用命令克隆存储库:git clone

cd ~/esp

git clone --recursive https://github.com/espressif/ESP8266_RTOS_SDK.git

ESP8266_RTOS_SDK 将被下载到~/esp/ESP8266_RTOS_SDK.

笔记

此命令将克隆 master 分支,该分支具有 ESP8266_RTOS_SDK 的最新开发(“前沿”)版本。它功能齐全,每周更新一次,包含最新的功能和错误修复。

笔记

GitHub 的“下载 zip 文件”功能不适用于 ESP8266_RTOS_SDK>,a是必需的。作为后备,可以在没有 Git 的情况下安装稳定版。git clone


开始一个项目

现在您已准备好为 ESP8266 准备应用程序。

为了快速开始,我们将使用IDF示例目录中的get-started/hello_world项目。

将get-started/hello_world复制到~/esp目录:
注意:如果电脑没有安装python,还需要安装python环境

安装:
sudo apt-get install python3.10
sudo apt-get install pip
升级pip版本:
pip3 install --upgrade pip
安装此SDK需要的依赖库
/usr/bin/python -m pip install --user -r /home/gin/ESP8266_RTOS_SDK/requirements.txt
可能会报错找不到python,因为新的python用的是python3
需要自己去软连接一下 ,sudo ln -s /bin/python3 /bin/python
具体路径根据实际修改
cd ~/esp

cp -r $IDF_PATH/examples/get-started/hello_world .  

解释: 复制文件夹到当前目录并更新所有文件的时间戳

您还可以在 ESP-IDF的示例目录下找到一系列示例项目。这些示例项目目录可以按照上述相同的方式进行复制,以开始您自己的项目。

重要的

ESP8266_RTOS_SDK 构建系统不支持 ESP8266_RTOS_SDK 或项目路径中的空格。


连接8266开发板

你快到了。为了能够进一步进行,将 ESP8266 开发板连接到 PC,检查开发板在哪个串行端口下可见,并验证串行通信是否正常。记下端口号,因为下一步需要它。

配置

hello_world在终端窗口中,通过键入转到应用程序目录。然后启动项目配置实用程序:

主要步骤:cd ~/esp/hello_world menuconfig

cd ~/esp/hello_world

make menuconfig
如果报错里面有python等字样,那就是python环境没配置好
而且,menuconfig 需要安装ncurse库
sudo apt-get install ncurses

menuconfig 打不开的原因总结:
python及其依赖没有安装好
不能在windsows下解压工具链
makefile 的IDF_PATH 没有配置
tool_chain路径不能出现两个‘_’的名称,之前我的toolchain写的是esp_tool_chain,编译就找不到编译器,换成esp_toolchain就可以了
menuconfig之前还需要的一些工具:
sudo apt-get install flex
sudo apt-get install bison
sudo apt-get install gperf

如果make menuconfig 之后报错说no rule 啥的,是因为makefile 里面没有添加IDF_PATH,也就是SDK的路径,可以修改makefile>

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RrSNnCT8-1675994117889)(file:///C:/Users/Administrator/AppData/Local/Temp/msohtmlclip1/01/clip_image004.jpg)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wYQTWaEv-1675994117890)(file:///C:/Users/Administrator/AppData/Local/Temp/msohtmlclip1/01/clip_image006.jpg)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lkMznnKG-1675994117891)(file:///C:/Users/Administrator/AppData/Local/Temp/msohtmlclip1/01/clip_image008.jpg)]


Bild和Flash

现在您可以构建并刷新应用程序。run:

make flash

执行之后提示找不到编译工具链>,可以在menuconfig 的工具链配置一栏设置工具链的路径

这将编译应用程序和所有 ESP8266_RTOS_SDK 组件,生成引导加载程序、分区表和应用程序二进制文件,并将这些二进制文件闪存到您的 ESP8266 板。

esptool.py v2.4.0

Flashing binaries to serial port /dev/ttyUSB0 (app at offset 0x10000)…

esptool.py v2.4.0

Connecting…

Chip is ESP8266EX

Features: WiFi

MAC: ec:fa:bc:1d:33:2d

Uploading stub…

Running stub…

Stub running…

Configuring flash size…

Compressed 7952 bytes to 5488…

Wrote 7952 bytes (5488 compressed) at 0x00000000 in 0.5 seconds (effective 129.9 kbit/s)…

Hash of data verified.

Compressed 234800 bytes to 162889…

Wrote 234800 bytes (162889 compressed) at 0x00010000 in 14.4 seconds (effective 130.6 kbit/s)…

Hash of data verified.

Compressed 3072 bytes to 83…

Wrote 3072 bytes (83 compressed) at 0x00008000 in 0.0 seconds (effective 1789.8 kbit/s)…

Hash of data verified.

Leaving…

Hard resetting via RTS pin…

如果没有问题,在构建过程结束时,您应该会看到描述加载过程进度的消息。最后,结束模块将被重置,“hello_world”应用程序将启动。


监视器

要查看“hello_world”应用程序是否确实在运行,请键入。make monitor

$ make monitor MONITOR — idf_monitor on /dev/ttyUSB0 74880 — — 退出:Ctrl+] | 菜单:Ctrl+T | 帮助:Ctrl+T 然后是 Ctrl+H —
ets 2013 年 1 月 8 日,第一个原因:1,启动模式:(3,6)

 

load 0x40100000, len 4400, room 16 0x40100000: _stext at ??:?

 

tail 0 chksum 0x6f load 0x3ffe8408, len 3516, room 8 tail 4 chksum 0x5d …

下面几行,在启动和诊断日志之后,您应该看到应用程序打印出“SDK 版本:xxxxxxx”。

...

SDK version:v3.1-dev-311-g824cd8c8-dirty

要退出监视器,请使用快捷方式Ctrl+]。

笔记

如果您看到的不是上面的消息,而是类似于以下内容的随机垃圾:

e���)([email protected]�y.!��(�PW+)��Hn9a؅/9�!�t5��P�~�k��e�ea�5�jA

~zY��Y(1�,1�� e���)([email protected]�y.!Dr�zY(�jpi�|�+z5Ymvp

要一次性执行,请键入:

make flash make monitor make flash monitor

这就是您开始使用 ESP8266 所需的一切!

现在您已准备好尝试一些其他示例,或者直接开发您自己的应用程序。

环境变量

似于以下内容的随机垃圾:

e���)([email protected]�y.!��(�PW+)��Hn9a؅/9�!�t5��P�~�k��e�ea�5�jA

~zY��Y(1�,1�� e���)([email protected]�y.!Dr�zY(�jpi�|�+z5Ymvp

要一次性执行,请键入:

make flash make monitor make flash monitor

这就是您开始使用 ESP8266 所需的一切!

现在您已准备好尝试一些其他示例,或者直接开发您自己的应用程序。

环境变量

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3y7hShrd-1675994117892)(file:///C:/Users/Administrator/AppData/Local/Temp/msohtmlclip1/01/clip_image010.jpg)]

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ESP32是一款非常流行的嵌入式开发板,支持Wi-Fi和蓝牙模块。在Linux系统上进行ESP32的开发,需要搭建相应的环境。本文将介绍ESP32在Linux系统下的环境搭建方法。 1. 安装Python环境 在Linux系统上进行ESP32的开发,需要安装Python环境。可以通过终端执行以下命令来检查是否已经安装Python环境: ``` python --version ``` 如果没有安装Python环境,可以使用以下命令进行安装: ``` sudo apt-get install python ``` 2. 安装ESP-IDF ESP-IDF是ESP32官方提供的开发框架,包含了ESP32的驱动、库和示例代码。可以通过以下命令来安装ESP-IDF: ``` git clone --recursive https://github.com/espressif/esp-idf.git ``` 安装完成后,还需要配置环境变量。可以在终端中执行以下命令: ``` cd esp-idf ./install.sh ``` 安装完成后,需要重新打开终端,才能让环境变量生效。 3. 安装ESP32工具链 ESP32的开发需要使用到工具链,可以通过以下命令来安装: ``` sudo apt-get install gcc git wget make libncurses-dev flex bison gperf python python-pip python-setuptools python-serial python-cryptography python-future python-pyparsing ``` 4. 安装ESP32依赖库 ESP32的开发还需要安装一些依赖库,可以通过以下命令安装: ``` sudo apt-get install libffi-dev libssl-dev libusb-1.0-0-dev ``` 5. 安装ESP32固件下载工具 ESP32的固件下载需要使用到esptool.py工具,可以通过以下命令进行安装: ``` pip install esptool ``` 6. 设置串口访问权限 ESP32开发板通过串口与计算机进行通信,需要设置访问权限。可以通过以下命令将当前用户添加到dialout用户组中: ``` sudo usermod -a -G dialout $USER ``` 7. 测试环境 完成上述步骤后,可以通过以下命令来测试环境是否搭建成功: ``` cd $IDF_PATH/examples/get-started/hello_world make menuconfig make flash ``` 如果编译和烧录成功,则说明环境已经搭建成功。 以上就是ESP32在Linux系统下的环境搭建方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

漏洞百出

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值