NB-IOT远程升级第2弹:软件升级协议、流程

在物联网项目的开发过程中,必不可少的一项功能就是远程升级OTA(Over-the-Air),即使用WIFI、蓝牙、4G、NB-IOT等方式将升级包传输到MCU,MCU进行代码存储,完成升级

本系列文章将介绍基于电信AEP平台进行NB-IOT设备的远程升级,包含stm32内部flash分区、BootLoader代码编写,平台软件升级包制作,平台软件升级协议对接及参考源码等内容,后续几篇文章将陆续介绍

该系列文章目录大纲如下:

image

在上一篇文章:NBIOT远程升级第1弹:BootLoader编写及软件包制作 中,介绍了BootLoader编写的几个要点及电信AEP平台软件包的制作

这一节介绍电信AEP平台远程升级使用的PCP协议,以及使用串口助手模拟远程升级流程,为后面敲代码做准备。

下一节将通过分析一个开源的FOTA代码,进一步加深对PCP协议及平台远程升级流程的理解,方面大家自己做移植

1、 PCP协议介绍

官网介绍:https://help.ctwing.cn/kong-zhi-tai-shou-ce/she-bei-guan-li/sotasheng-ji/ruan-jian-sheng-ji-xie-yi.html

电信AEP平台规定:设备和中国电信物联网开放平台(以下简称“平台”)之间的应用层升级协议(简称PCP协议),用于实现设备的升级。

  • 通讯方式:

    • PCP协议运行在应用层,底层可以是LWM2M/COAP/MQTT或者其他非流式协议。
    • PCP协议消息没有使用单独的端口号,并且不依赖于底层协议,为了和设备业务消息区分,PCP协议固定以0XFFFE作为起始字节。因此要求设备的业务消息的前两个字节不能是0XFFFE。
    • 本协议消息采用一问一答模式,所有请求消息都有一个响应消息
  • 组成部分:PCP协议消息由起始标识位、版本号、消息码、校验码、数据区长度和数据区组成

image
  • 消息结构
image
  • 字段类型
image
  • 消息码
image
  • 结果码定义
image
  • PCP消息识别

由于PCP协议消息和设备业务消息共用一个端口和URL通讯,平台收到设备的消息时,按照如下步骤判断是PCP协议消息还是业务消息:

  • 检查设备是否支持软件升级(根据设备profile的omCapability.upgradeCapability定义),如果不支持,则认为是业务消息。
  • 检查设备软件升级协议是否是PCP,如果不是,则认为是业务消息。
  • 检查消息前两个字节是否为0XFFFE,如果不是,则认为是业务消息。
  • 检查版本号是否合法,如果不合法,则认为是业务消息。
  • 检查消息码是否合法,如果不合法,则认为是业务消息。
  • 检查校验码是否正确,如果不正确,则认为是业务消息。
  • 检查数据区长度是否正确,如果不正确,则认为是业务消息。

如果以上检查都通过,认为是PCP协议消息。

说明:需要设备保证业务消息的起始字节不是0XFFFE。

远程升级注意要点:

  • 升级包下载之后,设备升级前,为保证设备不会因为运行不合法的升级包而导致设备成砖,需要对升级包内容进行合法性校验。
  • 务必使用平台为升级包生成的摘要校验升级包完整性。
  • 目前仅支持LWM2M协议的设备升级。
  • 电信AEP平台仅支持.zip类型的文件作为升级包。
  • 平台规定同一产品下最多创建100个升级包。

2、升级流程

根据平台官网介绍,PCP远程升级协议流程可分为以下几个步骤:查询设备版本、新版本通知、请求升级包、上报升级包下载状态、执行升级、上报升级结果,每一个步骤设备和平台之间均是一问一答的形式。

image

2.1 上传升级包

  • 第一步:登录物联网平台的控制台>产品>远程升级管理,选择SOTA升级>升级包管理>创建升级包,将升级包信息上传至云端。
image
image
  • 升级包版本名称自定义即可

  • 升级包版本包需与上一节制作的软件包配置文件UpgradeDesc.json文件中的version字段内容一致

  • 升级包即上一节制作好的升级包

  • 第二步:选择SOTA升级>创建任务,开始创建升级任务

image
  • 第三步:选择SOTA升级>升级设备管理,开始加入待升级设备
image
  • 第四步:确认已选择设备。
image
  • 第五步:选择SOTA升级>开始启动,开始启动升级任务。
image
  • 第六步:选择FOTA升级>查看设备升级详情,可以查看设备升级的状态和结果。
image

任务状态说明:

  • 未执行:任务未启动

  • 执行中:正在升级,存在未完成的任务

  • 已完毕:全部升级任务都达到终止状态,升级完成或升级失败

2.2 查询设备版本

平台启动远程升级任务之后,设备上报任意数据后触发远程升级,物联网平台向设备下发查询版本号信息,设备进行应答

image

串口助手AT指令内容:

image

注意:此处如果平台没有下发新版本通知的话,大概率是校验码不正确

物联网平台发送消息:

物联网平台向设备发送查询设备版本号命令:FFFE01134C9A0000

各消息字段解析如下:

  • 起始标识:固定为FFFE。
  • 版本号:数据类型为1个字节整数,且固定为1,即在消息流中为01。
  • 消息码:13,转换为10进制为19。
  • 校验码:4C9A
  • 数据区长度:0000
  • 数据区:无需数据区字段。

设备返回的应答消息:

设备收到物联网平台要查询设备的软件版本号消息,设备要向物联网平台反馈查询的结果

各消息字段的填写如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:与请求的消息码一致,为13。
  • 校验码:CRC16计算前先用0000替代。
  • 数据区长度:根据数据区的字段的数据类型得出数据区长度为17个字节,转换为十六进制为:0011。
  • 数据区:根据数据区的定义可知,处理成功的结果码为00,版本号信息假设为V1.0,将V1.0进行ASCII转码得到56312E30,由于版本号的数据类型为BYTE[16],即16个字节,当前只有4个字节,因此需要在版本号数据后面补0,得到56312E300000000000000000000000000。因此,数据区合并后为0056312E30000000000000000000000000。
image

将查询版本信息的消息流组合起来得到:FFFE 01 13 0000 0011 0056312E30000000000000000000000000需要将消息流进行CRC16算法计算得到校验码为7AB3。

因此,物联网平台向设备查询版本号信息,设备向平台返回的消息流为FFFE01137AB300110056312E30000000000000000000000000。

平台状态显示:

image

2.3 新版本通知

查询完版本号,接收到设备上报的版本号消息后,平台主动对设备端发起新版本通知。

image

串口助手AT指令内容:

image

物联网平台发送消息:

物联网平台向设备下发下载新版本软件包通知:FFFE01141019001656312E300000000000000000000000000100013D6534

各消息字段的解析如下:

  • 起始标识固定为:FFFE。

  • 版本号固定为:01。

  • 消息码:14,转换为十进制为20

  • 校验码:1019。

  • 数据区长度:0016

  • 数据区:根据数据区的定义可知。

    • 目标版本号:由16个字节组成,此处56312E30000000000000000000000000转换为字符即是V1.0,代表平台的升级包版本号为V1.0。
    • 升级包分片大小:由2个字节组成,单位为byte,用户上传软件包时可以手动输入升级包分片大小,如果不设置默认为500byte,大小为32~500之间。此处为0100,转换为十进制为256,即一个分片包大小为256个字节。
    • 升级包分片总数:由2个字节组成,由软件包大小除以每个分片的大小并向上取整获得。此处解析软件包分片总数为013D,转换为十进制后为317。
    • 文件检验码:由2个字节组成,为软件包配置文件中的versioncheckcode 字段值,6534,转换为字符后为e4。
image

数据解析的结果(目标版本号、分片包大小、校验码)与配置文件中的字段一致

设备返回的应答消息

设备收到下载新版本软件包通知后,设备向物联网平台返回应答消息,是否允许设备进行升级。

各消息字段的填写如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:与请求的消息码一致,为14。
  • 校验码:CRC16计算前先用0000替代。
  • 数据区长度:根据数据区的字段的数据类型得出数据区长度为1个字节,转换为十六进制为:0001。
  • 数据区:设备根据自身的情况对平台下发的新版本通知进行响应,本示例以设备应答“允许升级”为例进行介绍,得出数据区为:00。其它应答消息请根据应答消息字段进行适配。
image

注意:此处设备应做判断,设备电量、信号质量是否正常,是否应该允许设备进行升级。

将设备给物联网平台的应答消息流组合起来得到:FFFE 01 14 0000 0001 00。

再将消息流进行CRC16算法计算得到校验码为D768。因此,设备向平台返回的应答消息流为FFFE0114D768000100

平台接收到设备的回复后处理:

  • 正常处理:如果设备不允许升级,平台中止升级任务

  • 异常处理:如果响应超时,而且没收到请求升级包消息,平台中止升级任务

平台状态显示:

image

2.4 请求升级包

物联网平台通知设备有新的软件版本时,设备向物联网平台请求下载软件包,按照分片的序号进行下载分片包

image

串口助手AT指令内容:

image

设备发送的请求消息:

设备向物联网平台发送的请求软件包分片的第一条消息

各消息字段的填写如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:查询消息码表可知请求升级包的消息码为21,转换为十六进制为:15。
  • 校验码:CRC16计算前先用0000替代。
  • 数据区长度:根据数据区的字段的数据类型得出数据区长度为18个字节,转换为十六进制为:0012。
  • 数据区:目标版本号为平台下发的新版本通知版本号,即v1.0,转换为十六进制为56312E30000000000000000000000000,分片序号为第0个分片,即0000。
image

设备向物联网平台发送请求软件包分片的第一条消息为:FFFE 01 15 0000 0012 56312E30000000000000000000000000 0000(CRC16校验前)

经CRC16计算得到校验码为:5618。则替换校验码后设备发送的第一条请求分片消息为:FFFE01155618001256312E300000000000000000000000000000。

其它分片请求的消息流只需要替换分片序号后,重新计算并替换CRC16校验码即可,此处就不再展开。

物联网平台的应答消息:

物联网平台收到设备的请求软件包分片消息后,将会给设备下发分片的数据。物联网平台向设备响应的第一条请求分片的消息:FFFE0115xxxx0103000000byte[256]

各消息字段的解析如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:与请求的消息码一致:15。
  • 校验码:xxxx。
  • 数据区长度:0103,即259字节
  • 结果码:00,
  • 分片序号:0000,第0个分片,
  • 分片数据:byte[256]的数据。
image

平台状态显示:
image

此处应请求下载所有的分片包,共317个分片包,后面的具体指令过程略过,和请求第一片分片包指令类似,但注意校验码必须正确,否则平台不会下发分片包内容

2.5 上报升级包下载状态

当设备接收完所有分片数据并组装完软件包后,需要向物联网平台上报软件包的下载结果,让平台知道升级包是否已经都下载完成。

image

串口助手AT指令内容:

image

设备发送的请求消息:

设备向物联网平台发送的上报软件包下载结果消息

各个消息字段的填写如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:与请求的消息码一致,为16。
  • 校验码:CRC16计算前先用0000替代。
  • 数据区长度:根据数据区的字段的数据类型得出数据区长度为1个字节,转换为十六进制为:0001。
  • 数据区:上报软件包的下载结果,比如下载成功,设备侧上报00。
image

设备向物联网平台发送升级包下载结果的消息为:FFFE 01 16 0000 0001 00(CRC16校验前)

经CRC16计算得到校验码为:850E。则替换校验码后设备发送的升级包下载结果的消息为:FFFE0116850E000100。

物联网平台的应答消息:

物联网平台收到设备上报的软件包下载结果后,将会向设备返回应答消息:FFFE0116850E000100。

各个消息字段的解析如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:与请求的消息码一致:16。
  • 校验码:850E。
  • 数据区长度:0001。
  • 数据区:00,表示处理成功,若处理失败则返回80
image

平台状态显示:

image

2.6 执行升级

设备上报完升级包下载状态后,平台通知设备执行升级。

image

串口助手AT指令内容:
image

物联网平台发送的请求消息:

物联网平台向设备发送执行软件升级消息:FFFE0117CF900000

各个消息字段的解析如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:17,与请求的消息码一致。
  • 校验码:CF90。
  • 数据区长度:0000,即为0字节,无数据区
  • 数据区:无数据区

设备发送的应答消息

设备收到物联网平台下发的执行升级消息后,将对收到消息后的执行动作进行应答

各消息字段的填写如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:与请求的消息码一致:17。
  • 校验码:CRC16计算前先用0000替代。
  • 数据区长度:根据数据区的字段定义得出该数据长度为1个字节,转换为十六进制为:0001。
  • 数据区:处理成功,则返回00,其它处理结果请参考数据区定义。
image

设备向物联网平台应答的消息为:FFFE 01 17 0000 0001 00 (CRC16校验前)

经CRC16计算得到校验码为:B725。则替换校验码后设备返回的响应消息为:FFFE0117B725000100 。

平台状态显示:

image

2.7 上报升级结果

设备在执行完软件升级后,将会向物联网平台上报升级的结果 ,平台上更新设备当前所使用的软件版本。

image

串口助手AT指令内容:

image

设备发送的请求消息:

设备向物联网平台上报升级结果,各个消息字段的填写如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:与请求的消息码一致,为18。
  • 校验码:CRC16计算前先用0000替代。
  • 数据区长度:根据数据区的字段的数据类型得出数据区长度为17字节,转换为十六进制为:0011。
  • 数据区:结果码,以上报升级成功为例,结果码为00。
  • 当前版本号:升级完成后的版本号,与物联网平台下发的软件版本一致,即V1.0,转换为十六进制为:56312E30000000000000000000000000。
image

设备向物联网平台上报升级结果的消息为:FFFE 01 18 0000 0011 0056312E30000000000000000000000000(CRC16校验前)

经CRC16计算得到校验码为:C7D2。则替换校验码后设备向物联网平台上报升级结果码流为:FFFE0118C7D200110056312E30000000000000000000000000。

物联网平台发送的应答消息:

物联网平台收到设备上报的升级结果消息后,将对设备进行应答:FFFE0118AFA1000100

各个消息字段的解析如下:

  • 起始标识固定为:FFFE。
  • 版本号固定为:01。
  • 消息码:18,与请求的消息码一致。
  • 校验码:AFA1。
  • 数据区长度:根据数据区的字段定义得出该数据长度为1个字节,转换为十六进制为:0001。
  • 数据区:处理成功,则返回00,升级任务不存在80。本示例以返回00处理成功为例进行说明。
image

平台状态显示:

image

至此,使用串口助手模拟设备进行远程升级的流程就完成了,写代码的时候根据这个流程进行发送数据,命令解析就可以了,此外平台也提供断点续传的方案,如下图所示:

image

下一节通过分析一份开源的FOTA代码,进一步加深对PCP协议及平台远程升级流程的理解,方面大家自己做移植

如有需要,工众号后台回复 PCP 获取PCP协议代码

我是南风,一个爱折腾的程序袁,工作之余,写写公众号,玩玩视频号,分享我的工作、我的生活

分享是一种博爱的心境,学会分享,就学会了生活

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容