CSDK开发FOTA难?没有自己的服务器?——合宙云平台FULL-OTA解烦忧

描述

 

功耗低、性能好、联网快——基于移芯EC618平台的合宙低功耗4G-Cat.1系列模组,支持标准AT/LuatOS/C-SDK多样化开发方式,可满足用户不同开发需求。其中C-SDK仓库提供给客户自己编译,版本自由度较高,FOTA远程升级应用只需做好版本管理——不仅支持使用自己的服务器,还支持使用合宙IoT云平台来升级模组,为不方便搭建服务器的客户提供免费便捷的服务。

本文分享基于合宙IoT服务器的CSDK FULL-OTA全量升级示例

 

 

1

FULL-OTA测试准备


 

FULL-OTA远程升级是对整包进行升级,在下载到的CSDK仓库内找到 “/project/example_full_ota” ,本教程将以此example为例。

注意:CSDK的原始版本必须为V0002及以上。
 

GITEE仓库链接:
https://gitee.com/openLuat/luatos-soc-2022

1.1 生成1.0.0版本的binpkg文件:

首先需要先将代码中的 "PROJECT_KEY",更改成自己在合宙IoT云平台上的PROJECT_KEY。

 

#define PROJECT_VERSION  "1.0.1"       //使用合宙iot升级的话此字段必须存在,并且强制固定格式为x.x.x, x可以为任意的数字

#define PROJECT_KEY "47pzTpR9bxS04TiMJQ72RVg9tbtmQ8vw"  //修改为自己iot上面的PRODUCT_KEY,这里是一个错误的,使用合宙iot升级的话此字段必须存在

#define PROJECT_NAME "example_full_ota"                 //使用合宙iot升级的话此字段必须存在,可以任意修改,但和升级包的必须一致

 

 

打开用合宙IoT服务器升级的代码部分,默认没版本号打印,这里在下面一行加了打印,如下所示:

 

#if 1

    const char remote_domain [ ] = "iot.openluat.com";

    const char ota_file_name[200];

    char imei[16] = {0};

    luat_mobile_get_imei(0, imei, 15);

    snprintf_(ota_file_name, 200, "api/site/firmware_upgrade?project_key=%s&imei=%s&device_key=&firmware_name=%s_LuatOS_CSDK_EC618&version=%s", PROJECT_KEY, imei, PROJECT_NAME, PROJECT_VERSION);

#endif

    LUAT_DEBUG_PRINT("file name %s", ota_file_name);

 

 

 

然后保存编译,生成1.0.0版本的binpkg文件(可以手动修改文件名作为区分)。

服务器

1.2 生成1.0.1版本的binpkg文件:

对代码进行修改,修改完成后build生成1.0.1 binpkg,然后保存编译,生成1.0.1版本的binpkg文件(可以手动修改文件名作为区分)。

服务器

 

 

 

2

生成升级包


 

本节使用合宙LuaTools生成升级包,注意:LuaTools需要2.2.0及以上版本。

 

2.1 制作升级包:

运行LuaTools,进入选项及工具->SOC差分/整包升级包制作工具。
 

服务器

在工具窗口的新版固件栏选择要升级的binpkg,然后设置输出路径并填入用户标识(即:固件新版本号),点击开始执行,即可生成对应的升级包。

服务器

2.2 更改后缀名:

在本地对应路径中找到生成的.sota升级包文件,将其后缀名更为.bin备用。

服务器

 

 

 

3

上传升级包


 

升级包生成成功后需要上传到服务器中,打开合宙IoT云平台iot.openluat.com并登录:

3.1 点击我的项目-固件列表,然后创建固件:
 

服务器

3.2 创建固件相关设置:

在创建固件窗口,选择上文中后缀改为.bin的升级包,点击上传;系统会自动生成对应固件版本名称和版本号。

服务器

3.3 点击确定,固件上传成功:

服务器

3.4 添加指定设备imei:

因为升级全部设备一栏选择了【否】,所以接下来需要指定设备,将待升级设备的imei添加即可。

服务器

3.5 烧录测试升级:

然后只需要使用烧录工具烧录基础版本(1.0.0)的binpkg:

服务器

等待样例通过URL请求升级包的方式测试FOTA升级,升级成功标志除升级接口正确返回外,还可通过升级前后不同的打印内容来辅助判断是否升级成功。

如下显示说明升级成功:

服务器

这里做测试的旧版本所打印的version=1.0.0,更新成功到新版本的打印变成了1.0.1。如在升级成功后再次请求同一升级包,由于不匹配会提示升级包校验错误,不予升级。

后台升级日志的查询结果如下:

服务器

 

 

 

FULL-OTA注意事项

 

 


 

文件大小:
生成的ap.bin大小不能超过1984KB,生成的升级包不能超过1472KB。

设置要点:
LuaTools需要2.2.0及以上版本;进入选项及工具—SOC差分/整包升级包制作工具,新版固件选择要升级的binpkg,用户标识可以填版本号,也可以不填,看自己的代码对升级版本是否有控制。如果用合宙IOT升级服务,则必须填写版本号!

选好输出路径,点生成,在输出目录下生成相应的xxx.sota文件为升级包,更新后缀为.bin上传至服务器即可升级。

流量消耗:
升级一次流量1MB~1.5MB之间,注意流量消耗。

版本要求:
CSDK的原始版本必须是V0002及以上,V0001升级到V0002也不行,因为涉及到了bootloader修改。

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分