我爱编程向智者致敬程序员

ESP8266学习笔记(二)

2016-09-25  本文已影响0人  JaydenOnly

上一周讲了ESP8266的初步开发,也就是AT模式工作,这种模式是最适合初学者使用的,因为wifi模块内部的函数都已经封装好了,无论你用什么mcu,都可以直接调用指令来实现你所需要的功能。

当然,如果仅仅是有这种模式,那么这块芯片就不至于那么火了。这块芯片的神奇之处在于它本身是一个mcu,而且生产公司对部分的函数免费开源,给了开发者很大的发挥空间。也就是说,本来需要在51或者arduino单片机上运行的程序可以直接烧录进wifi芯片,让芯片充当单片机,这样在产品开发时就节省了成本和空间,可以做出更高效美观的作品。所以,下面我就讲讲ESP8266的深度开发。

开发前的准备

  1. usb转TTL模块,或者单片机开发板,直接使用它的串口通讯引脚,用来烧录程序和进行串口信息打印;

  2. 从乐鑫官网下载ESP8266_NONOS_SDK,虽然官方有提供在linux下的开发平台,但是我还是推荐用安信可的IDE开发工具,它把make指令等都集成在eclipse上,直接通过build project就可以编译出bin文件,当然,安信可的工具集里面是有包括烧录工具的,所以不须另外下载。

开发步骤

  1. 将sdk导入安信可IDE,点导入工程,浏览到一个要编译的工程,编译器选 Cygwin;
  2. 导入example进行改写或者自己编写user_main.c;
  3. 执行build project,生成bin文件;
  4. 使用烧录工具,将blank.bin,flash.bin,irom_text.bin和init_data_default.bin导入对应的地址中,将芯片的GPIO0口置于低电平,按照说明连接串口,点击一键烧录;
  5. 烧录完毕后,将GPIO0口置空,芯片处于正常工作模式。

项目结构

项目结构.jpg

关于makefile

一般makefile的关注点有以下几个:

编译模式控制(针对根目录makefile)
image.png

这是在linux系统下编译控制的选择项,不过在IDE下只需修改makefile文件就可以如愿地控制编译,如果不使用ota升级功能的话那么就用上图给的编译方式就行了。

包含头文件(所有makefile)
image.png

这是makefile编译时会包含的头文件,用户可以根据自己存放头文件的位置自行对includes 后的内容进行修改。

SUBDIRS(针对app文件夹下的makefile)
image.png
变量SUBDIRS : 指定当前目录下,要递归编译的子目录。用户需根据自己app文件夹下的子目录名称和个数,分别添加到SUBDIRS变量中,例如你的app目录如下图所示,那么对应的makefile就与上图一致。
image.png
COMPONENTS_eagle.app.v6(针对app文件夹下的makefile)
image.png

该变量是表明将引用那些app文件夹下的静态链接库,一般是与用户自己编写的文件夹名称相对应,所以用户根据需要自行修改,否则会出现函数未定义的错误。

LINKFLAGS_eagle.app.v6(针对app文件夹下的makefile)
image.png

该变量是表明将引用那些lib文件夹下的静态链接库,与lib文件夹下的文件名称相对应,所以用户根据需要自行调用修改,否则也会出现函数未定义的错误。

总之,makefile是一个很重要的文件,管理依赖和控制编译的整个过程。如果感兴趣的话,可以去学习它的语法,简直就是自动化编译的神器 ~

总结

这次大概讲了ESP8266的深度开发的一些准备工作和整体框架,关于具体的开发和烧录等细节将在后续的文章中为大家阐明。

上一篇下一篇

猜你喜欢

热点阅读