百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Windows下最简单的ESP8266_ROTS_ESP-IDF环境搭建与腾讯云SDK编译

itomcoil 2025-03-30 17:43 18 浏览

前言

其实也没啥可说的,只是我感觉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

相关推荐

最强聚类模型,层次聚类 !!_层次聚类的优缺点

哈喽,我是小白~咱们今天聊聊层次聚类,这种聚类方法在后面的使用,也是非常频繁的~首先,聚类很好理解,聚类(Clustering)就是把一堆“东西”自动分组。这些“东西”可以是人、...

python决策树用于分类和回归问题实际应用案例

决策树(DecisionTrees)通过树状结构进行决策,在每个节点上根据特征进行分支。用于分类和回归问题。实际应用案例:预测一个顾客是否会流失。决策树是一种基于树状结构的机器学习算法,用于解决分类...

Python教程(四十五):推荐系统-个性化推荐算法

今日目标o理解推荐系统的基本概念和类型o掌握协同过滤算法(用户和物品)o学会基于内容的推荐方法o了解矩阵分解和深度学习推荐o掌握推荐系统评估和优化技术推荐系统概述推荐系统是信息过滤系统,用于...

简单学Python——NumPy库7——排序和去重

NumPy数组排序主要用sort方法,sort方法只能将数值按升充排列(可以用[::-1]的切片方式实现降序排序),并且不改变原数组。例如:importnumpyasnpa=np.array(...

PyTorch实战:TorchVision目标检测模型微调完

PyTorch实战:TorchVision目标检测模型微调完整教程一、什么是微调(Finetuning)?微调(Finetuning)是指在已经预训练好的模型基础上,使用自己的数据对模型进行进一步训练...

C4.5算法解释_简述c4.5算法的基本思想

C4.5算法是ID3算法的改进版,它在特征选择上采用了信息增益比来解决ID3算法对取值较多的特征有偏好的问题。C4.5算法也是一种用于决策树构建的算法,它同样基于信息熵的概念。C4.5算法的步骤如下:...

Python中的数据聚类及可视化分析实践

探索如何通过聚类分析揭露糖尿病预测数据集的特征!我们将运用Python的强力工具,深入挖掘数据,以直观的可视化揭示不同特征间的关系。一同探索聚类分析在糖尿病预测中的实践!所有这些可视化都可以通过数据操...

用Python来统计大乐透号码的概率分布

用Python来统计大乐透号码的概率分布,可以按照以下步骤进行:导入所需的库:使用Python中的numpy库生成数字序列,使用matplotlib库生成概率分布图。读取大乐透历史数据:从网络上找到大...

python:支持向量机监督学习算法用于二分类和多分类问题示例

监督学习-支持向量机(SVM)支持向量机(SupportVectorMachine,简称SVM)是一种常用的监督学习算法,用于解决分类和回归问题。SVM的目标是找到一个最优的超平面,将不同类别的...

25个例子学会Pandas Groupby 操作

groupby是Pandas在数据分析中最常用的函数之一。它用于根据给定列中的不同值对数据点(即行)进行分组,分组后的数据可以计算生成组的聚合值。如果我们有一个包含汽车品牌和价格信息的数据集,那么可以...

数据挖掘流程_数据挖掘流程主要有哪些步骤

数据挖掘流程1.了解需求,确认目标说一下几点思考方法:做什么?目的是什么?目标是什么?为什么要做?有什么价值和意义?如何去做?完整解决方案是什么?2.获取数据pandas读取数据pd.read.c...

使用Python寻找图像最常见的颜色_python 以图找图

如果我们知道图像或对象最常见的是哪种颜色,那么可以解决图像处理中的几个用例,例如在农业领域,我们可能需要确定水果的成熟度。我们可以简单地检查一下水果的颜色是否在预定的范围内,看看它是成熟的,腐烂的,还...

财务预算分析全网最佳实践:从每月分析到每天分析

原文链接如下:「链接」掌握本文的方法,你就掌握了企业预算精细化分析的能力,全网首发。数据模拟稍微有点问题,不要在意数据细节,先看下最终效果。在编制财务预算或业务预算的过程中,通常预算的所有数据都是按月...

常用数据工具去重方法_数据去重公式

在数据处理中,去除重复数据是确保数据质量和分析准确性的关键步骤。特别是在处理多列数据时,保留唯一值组合能够有效清理数据集,避免冗余信息对分析结果的干扰。不同的工具和编程语言提供了多种方法来实现多列去重...

Python教程(四十):PyTorch深度学习-动态计算图

今日目标o理解PyTorch的基本概念和动态计算图o掌握PyTorch张量操作和自动求导o学会构建神经网络模型o了解PyTorch的高级特性o掌握模型训练和部署PyTorch概述PyTorc...