1 Star 1 Fork 0

何亚红/Air724UDemo

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
MIT

简介

本工程是一个使用Luat_CSDK_Air724U(非官方修改版)进行开发的Demo程序。

资源文件

类似于桌面程序的资源文件。源代码实现的目录为 rc

在固件编写中,很多时候需要大量的固定数据,直接手工嵌入到C文件里比较麻烦。

通过读取文件转换到对应C文件可大大节省时间,可添加常用的文件(如各种证书)或者不适宜放在可读写的文件系统中的文件(如需要在格式化中保留或者初始参数)。转换程序源代码为rc/fsgen.cpp

使用步骤如下:

  • 将待添加的文件放入 rc/fs目录下。

  • 使用文件名调用以下函数(需包含相应头文件RC.h):

    //通过名称获取资源大小
    size_t RCGetSize(const char * name);
    
    //通过名称获取资源指针
    const unsigned char * RCGetHandle(const char * name);

SFFS

SFFS是由CSDK支持的预先放置文件的方法。添加文件的目录为sffs/sffs,即目录下的文件将添加至文件系统根目录中,通过iot_fs.h中的API访问。与资源文件不同的是,文件系统中文件可读写,也可存放较大的文件(受APP代码空间限制,资源文件不可存放较大的文件)。

已知问题

  • C++静态类的构造函数不可用(由应用代码支持,注意C++初始化执行的时机)。
  • C++全局类的构造函数不可用(由应用代码支持,注意C++初始化执行的时机)。

源代码下载

由于本源代码包含第三方源代码,故直接下载可能有部分源代码缺失,需要通过以下方法解决:

  • 在进行git clone 使用--recurse-submodules参数。

  • 若已通过git clone下载,则在源代码目录中执行以下命令下载子模块:

     git submodule update --init --recursive

测试截图

默认

Air724UDemo-1

启用OneNET MQTT直连设备测试

使用menuconfig.bat将MQTT切换至OneNETDevice。

OneNET_Device_Kconfig

测试结果

OneNET_Device_UartDebug

OneNET_Device_OneNET

编译

  • 操作系统: Windows 10
  • SDK:Luat_CSDK_Air724U 。

脚本说明

  • build.bat:构建工程文件(codeblocks工程文件在build目录中)并编译。
  • buildenv.bat:构建工程文件并打开一个cmd.exe窗口(编译环境,此环境中可使用sdk中的工具)。
  • menuconfig.bat:配置Kconfig。

Code::Blocks工程文件使用说明

运行buildenv.bat后,工程文件在build目录下,后缀名为cbp。若出现失败提示可能没有此文件,此时源代码可能有误。

若直接使用codeblocks打开时,只能编辑源代码,而不能执行编译命令测试源代码(有些命令未使用绝对路径,需要在编译环境中执行)。

若要正常使用编译命令,请按以下步骤操作:

  • 安装好Code::Blocks。注意:需要能够正常编译的Code::Blocks,即需要带Mingw工具链,如不确定,可建一个helloworld工程测试,如能成功编译则正常。
  • 执行buildenv.bat。执行完成后,会有一个cmd.exe的窗口。
  • 将Code::Blocks的快捷方式或者codeblocks.exe本身拖入cmd.exe的窗口,按回车执行。
  • 打开Code::Blocks后,可关闭cmd.exe窗口,此时使用Code::Blocks打开build目录下的cbp文件即可正常编译源代码。

固件烧录

正常编译完成后,最终的固件在 build/hex 目录下,后缀名为pac。

此时可直接使用合宙官方的Luatools的固件下载烧录,烧录方式有以下两种:

  • 免USB BOOT烧录。使用USB连接PC后直接下载。注意:这需要原有固件正常时才能使用,如有死机或者不断重启时可能不可用。
  • USB BOOT烧录。使用USB连接PC,拉高USB BOOT引脚后(正常运行时需取消拉高操作)进行一次复位,然后直接下载。通常开发过程中需使用这种方式。

软件说明

调试输出(UART)

采用UART2输出调试信息,通过串口调试查看。波特率:921600 8N1。

调试输出(USB AP Log)

USB虚拟的AP端口的日志(官方默认的方式)。由于官方默认的日志信息较多,需要使用 applog 作为关键字筛选日志。

注意:由于USB虚拟端口需要时间启动(上位机枚举)及程序崩溃后USB虚拟端口立即失效,少数日志可能抓不到。

MIT License Copyright (c) 2022 何亚红 Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

简介

暂无描述 展开 收起
MIT
取消

发行版 (1)

全部

贡献者

全部

近期动态

加载更多
不能加载更多了
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/HEYAHONG/Air724UDemo.git
git@gitee.com:HEYAHONG/Air724UDemo.git
HEYAHONG
Air724UDemo
Air724UDemo
HYH

搜索帮助

Cb406eda 1850385 E526c682 1850385