Windows下最简单的ESP8266_ROTS_ESP-IDF环境搭建与腾讯云SDK编译
off999 2025-07-19 22:00 25 浏览 0 评论
前言
其实也没啥可说的,只是我感觉ESP-IDF对新手来说很不友好,很容易踩坑,尤其是对业余DIY爱好者搭建环境非常困难,即使有官方文档,或者网上的其他文档,但是还是很容易踩坑,多研究,记住两点就行了, 一个是编译的工具链,二个是SDK编译所需的一些软件或者库,搞清楚了,还是蛮简单的.本人如此精心的细心地写了这篇文章,若你还是无法完成,那我也帮不了你了.
在windows上安装ubuntu
本文主要针对在linux环境编译,所以首先需要在你的winsows上,安装linux,在windows上安装linux方式有很多,选择你觉得合适的方式即可,你可以采用msys2,或者虚拟机,本文直接采用win10的系统功能,这样更加方便
1.打开控制面板,进入程序和功能(你也可以直接使用 Win键 + R键 输入 appwiz.cpl 确定)
2.点击左侧,启动或关闭Windows功能
3.勾选列表中的 "适用于 Linux 的 Windows 子系统" 点击确定,重启系统
4.打开Windows应用商店(Microsoft Store),搜索 Ubuntu 下载安装,这个下载与安装结束很快,耐心等待即可
5.通过开始菜单,点击 Ubuntu ,打开进入 Ubuntu (你也可以在Windows应用商店,你刚刚点击下载那里点击启动)
6.首次启动Ubuntu后会输入你的用户名及密码(输入密码时界面上不显示内容),密码需要输入两次,第二次为确认密码
PS:创建完账号后,linux会自动创建相应的用户目录(/home/你的用户名),我这里为hmuyin,后面会用到这个目录
至此Ubuntu安装完毕,可以在控制台看到Ubuntu的版本以及其他信息"Welcome to Ubuntu 20.04.2 LTS (GNU/Linux 4.4.0-19041-Microsoft x86_64)"
7.为了我们后续方便,我们需要对安装好的Ubuntu进行一些设置
首先是更新软件源,这样在国内或者不使用代理的情况下,下载软件更快更方便,本文使用清华大学开源软件源,注意:请根据你的Ubuntu版本选择对应的源.
打开 清华大学开源软件镜像站
https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/在右侧 "选择你的ubuntu版本"复制内容
PS:你可以使用 lsb_release -a 查看Ubuntu版本
然后命令输入
sudo vim /etc/apt/sources.list
打开后全选,按下键盘 : ggVG (注意大写,按键盘顺序 G键-->G键-->大小写键(切到大写)-->V键-->G键),全选后清楚,按下键盘 : dG (注意大写,按键盘顺序 d键-->大小写键(切到大写)-->G键),清除完毕后按下i键进入编辑,点击窗口右键->编辑->粘贴,将复制的内容粘贴进去,最后按下 ESC 键,输入 :wq 保存并退出即可.
最后再输入两条命令更新软件源
sudo apt update
sudo apt upgrade -y
对 Ubuntu 进行汉化 (若你无需汉化,则跳过本步骤)
由于本人英文水平较差,比较喜欢用中文,所以能汉化的东西或者说有中文的东西我一般都是尽量使用中文
1.直接复制以下命令然后在控制台进行粘贴
sudo apt install language-pack-zh-han* -y
sudo locale-gen zh_CN.GB18030 && sudo locale-gen zh_CN.GB2312 && sudo locale-gen zh_CN.UTF8
sudo apt install fontconfig -y
sudo apt install ttf-mscorefonts-installer -y
sudo apt install -y --force-yes --no-install-recommends fonts-wqy-microhei
sudo apt install -y --force-yes --no-install-recommends ttf-wqy-zenhei
等待字体文件下载完毕后,复制以下命令,进入菜单选择zh_CN UTF.8 UTF.8,按空格选中,回车继续,下一个菜单也选这个,完成后重启,变中文了
sudo dpkg-reconfigure locales
搭建ESP-IDF环境
在Linux上安装所需软件,以及配置工具链,这里我将大部分的SDK所需软件都进行统一安装,这样就可以编译大部分的一些SDK,比如腾讯云ESP8266SDK,阿里云ESP-IDF,以及第三方或者其他个人开发的开发的一些SDK,等.(这篇文章为何要写,并且为什么写的这个详细,就是因为如果按照原来的方法搭建或者按照官方的方法,在编译其他SDK的时候就容易报错)
1.先下载工具链,以及官方SDK,(本文使用腾讯云SDK,所以同时将腾讯云SDK也下载)
#先建立一个目录
mkdir esp
cd esp
#官方SDK3.1版本
git clone --single-branch -b release/v3.1 https://github.com/espressif/ESP8266_RTOS_SDK.git
#腾讯云SDK
git clone https://github.com/tencentyun/qcloud-iot-esp-wifi.git
#下载腾讯云工具链并解压
wget https://dl.espressif.com/dl/xtensa-lx106-elf-linux64-1.22.0-92-g8facf4c-5.2.0.tar.gz -O - | tar zxf -
ls
ls 后看到有这三个文件夹,就表示完成了
ESP8266_RTOS_SDK qcloud-iot-esp-wifi xtensa-lx106-elf
2.安装所需编译需要库及软件(如果你的ubunt在20.0及以上) 方法一与方法二任选其一,区别在于方法一安装的为 python3,方法二则安装的python2,由于软件源不再提供pip,取代的是php3,所以这里提供两种方法,根据自己实际需求选择
方法一: python3
sudo apt-get install git wget libncurses-dev flex bison gperf python3 python3-pip python3-setuptools python3-serial python3-cryptography python3-future python3-pyparsing python3-pyelftools cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0
#然后重建映射,方便在python2上的兼容使用
sudo ln -s /usr/bin/python3 /usr/bin/python
方法二: python2
因为要输入密码,所以我们分两次进行安装
sudo apt-get install git wget flex bison gperf python python-setuptools cmake ninja-build ccache libffi-dev libssl-dev libncurses5-dev curl
curl https://bootstrap.pypa.io/pip/2.7/get-pip.py --output get-pip.py
sudo python2 get-pip.py
pip2 --version
pip install pyserial #安装python串口模块
pip install xlrd #安装excel读写模块
将工具链添加到PATH环境变量,以及将IDF编时IDF_PATH的变量添加到系统环境变量
环境变量可以随时切换其他的工具链以及SDK,本文只要编译的是esp8266
sudo vim /etc/profile.d/esp.sh
然后按下 i 键进入编辑
export PATH="$PATH:/home/你的用户目录/esp/xtensa-lx106-elf/bin" #工具链
export IDF_PATH="/home/你的用户目录/esp/ESP8266_RTOS_SDK" #ESP8266 SDK 目录
编辑好后,按下 ESC 键,输入 :wq 保存,然后重启即可生效
注意:这里如果你有多个SDK可以随时切换,或者有多个工具链也可以随时修改来进行切换,如你要编译ESP32则下载ESP32的工具链与SDK,然后在这里修改工具链的目录与SDK目录,即可随时切换
重启后可以通过 echo $IDF_PATH 查看是否正常
vim的操作,可以参考文本第一步的第6小节
PS : 你的用户目录,通常来说也就是安装Ubuntu时你创建的用户名,完整目录一般为 /home/你的用户名
具体可以请参考本文第1步的第6小结
编译腾讯云SDK
编译方式与官方教程一样
切换至腾讯云SDK目录 输入编译配置,保存好后退出,然后进行编译
make menuconfig
make all
看到 To flash all build output, run 'make flash' or 表示编译完成,你可以进行make flash进行下载,如果中途编译有错误的话,是无法看到该提示的,需根据错误进行问题排查.
腾讯云SDK需要配置三元信息以及其他信息,这里本文只是讲解如何正确编译,暂时不做开发类介绍,以后我会专门写一篇关于开发腾讯SDK文章
编译官方SDK
好了,我们再来测试一下编译官方的扩展示例
切换至官方扩展示例目录 输入编译配置,保存好后退出,然后进行编译
make menuconfig
make all
烧写/下载 测试
文本将使用官方SDK的扩展示例 hello word 进行测试
注意:如果你的端口为 COM3 在Ubuntu里面对应则为 /dev/ttyS3
你的COM端口为几,那么/dev/ttyS 就S几
看到 Hard resetting via RTS pin... 后表示下载完成,可以使用 make monitor 打开串口测试
Ubuntu 与 windows 文件共享
现在我们就可以进行创建项目进行程序编写了,但是如何方便地进行访问Linux中的文件呢,这里有两种方式
1.直接打开linux的目录
C:\Users\你的用户名\AppData\Local\Packages\
CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc\LocalState\rootfs
在这个目录下 就是整个linux的目录,你的用户目录在 home 目录下,新建项目与.c 文件操作都可以直接在这个目录下进行,也可以使用 vscode 打开该目录进入到SDK目录下编写.
也可以创建快捷键方式,即可直接进入该目录
2.挂载本机磁盘
直接使用 mount 查看,可以看到磁盘的内容,直接使用 cd /mnt/c 即进入了c盘,在使用ls可查看文件列表
总结
目前发现串口调试也就是 make monitor 还是有一定的问题,目前正在想法解决,如果解决后会修改本文,如需串口调试可以使用其他第三方串口调试工具进行串口调试,这个问题据说是win10 Bug 引起的问题,我们在 idf_monitor.py 从文件中也可以得知
具体问题可以参考
https://github.com/espressif/esp-idf/issues/1136
原创内容,未经许可,禁止随便转载,by:hmuyin
相关推荐
- ipv6无网络访问权限怎么解决
-
ipv6无网络访问权限解决方法如下1、点击电脑左下角的开始,进入到开始的菜单栏,在菜单栏中找到“运行”。或者通过快捷键Windows+R打开运行窗口。 2、打开运行的窗口页面后,在页面上输入“CMD...
- office ltsc版(Office LTSC版本区别)
-
office2021和2021ltsc的区别如下:1.更新策略不同。前者采用每个月月度更新的方法,提供功能更新、安全更新。后者不采用每个月月度更新的方法,且不提供功能更新。2.界面不同。2021采用了...
- 安装win7需要激活吗(现在安装win7旗舰版还需密钥吗)
-
要激活 Windows7如果是预装在计算机中的,买来之后便不用激活,这里预装指的是在厂商那里。正版的Windows7安装到计算机中,有三十天的试用期,若要永久使用,就要使...
- originos 3升级计划公布(originos升级包)
-
2023年2月。1.OriginOS3.0系统第一批升级时间为11月25日。2、包含iQOONeo7,X80系列,S15系列,iQOO9、iQOO10系列,以及折叠屏XFold系列和大屏XNo...
- 鸿蒙系统适配第三方机型(鸿蒙 第三方适配)
-
最新华为官方公布了鸿蒙系统3.0支持的机型名单,具体如下。鸿蒙系统3.0升级名单:1.Mate系列:MateXs2、MateX2、MateXs、Mate40、Mate40Pro、Mate...
- imei怎么下载(imei changer apk)
-
如果您的steam序列号激活了,可以尝试以下方法下载:1.使用steam自带的下载工具,如“下载工具”,在软件的“下载”选项卡中选择“序列号下载”。2.在下载页面中,选择要下载的游戏,然后点击“下...
- 电脑系统优化软件哪个好(系统优化软件排行榜)
-
有必要用,非常好用,WINDOWS优化大师是一个网络上下载率极高的系统维护软件。多年未曾清理过系统和硬盘的电脑,系统内部将产生大量的垃圾文件、临时文件、废旧程序等等win10系统不需要经常更新,关闭...
- 重装系统后硬盘不见了(重装系统后磁盘不见了)
-
硬盘不见可能是因为重装系统时未正确安装驱动程序或未对硬件进行正确设置。你可以按以下步骤排查问题:进入BIOS检查硬盘是否被识别,尝试重新连接数据线和电源线,更新或安装适当的硬件驱动程序,或者使用硬件故...
- 冰封u盘装win7系统教程图解(冰封u盘启动装机教程)
-
1.查找激活工具:通常来说,Win7冰封系统已经包含了必要的驱动,所以如果你的电脑上并没有出现设备错误,那你就可以正常使用。如果你需要添加任何驱动,请尝试从厂商下载相应的驱动并执行自动安装程序。如果...
- uefi模式下找不到硬盘(uefi引导找不到硬盘)
-
首先你的安装盘必须是从UEFI启动的,然后它才能安装为UEFI启动。(条件:Fat32文件系统,efi文件夹)其次你MBR+BIOS的系统想换成GPT+EFI的,分区得做一点改动,腾出来100M的空...
- win7怎么安装蓝牙驱动程序(win7电脑安装蓝牙驱动教程)
-
方法如下: 1、再开始里点击控制版面,点击【硬件和声音】找到【添加设备】 2、之后再选择你要添加的蓝牙耳机。 3、系统就会提示正在与蓝牙适配器连接,然后提示添加成功。 4、点击“开始”-“...
- 怎么装系统win7旗舰版(电脑怎么装win7旗舰版)
-
1、目前支持64位的Wincc版本有:WinccV7Sp3、WinccV11Sp2、WinccV12。2、Wincc的V11与V12两个版本不能共存,即不能同时安装在同一台电脑上。上述这两...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
