OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4670|回复: 7

求以太网远程更新的完备方案

[复制链接]

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
发表于 2017-4-12 08:34:40 | 显示全部楼层 |阅读模式
5金钱
如题。
我用过两种以太网远程更新的方案。核心部分都是:芯片flash分成两段:IAP程序段和APP程序段,IAP程序通过网页接收文件,然后写入APP程序段。


第一种方案是:APP程序通过以太网接收特定的更新程序指令然后跳转IAP程序,IAP程序作为服务器,通过一个网页接收文件更新APP程序。
但是第一种方案有一个缺点是:如果在IAP更新APP的过程中发生了掉电,导致APP程序未更新完成,那程序就一去不返了。
第二种方案是:IAP程序上电之后等待30秒,在30秒之内如果有网页连接,就执行远程更新,否则在30秒之后跳转用户程序。
它的缺点就是想更新程序的人必须给芯片复位,然后手忙脚乱的在30秒之内连接到服务器,否则就错过了更新程序的时间。


我想寻求一种稳定可靠的方便的远程更新方案。我自己想了一个方案:
IAP程序把收到更新文件暂存入外部SRAM,等到文件接收完全了并全部存入SRAM后再启动更新,并通过备份寄存器记录程序更新的状态,或者版本号之类的。

请问有人做过类似的操作吗?有什么需要注意的?可以提供一些资料吗?
或者有其他更加成熟的方案吗?
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

50

主题

1805

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
6662
金钱
6662
注册时间
2016-5-29
在线时间
910 小时
发表于 2017-4-12 10:22:53 | 显示全部楼层
更新指令做在APP里面.APP程序收到更新指令.重新启动到IAP程序.IAP更新完成再回到APP执行.解决掉电的问题,可能要有两个程序,一个是备份.
回复

使用道具 举报

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
 楼主| 发表于 2017-4-12 10:30:05 | 显示全部楼层
操作系统 发表于 2017-4-12 10:22
更新指令做在APP里面.APP程序收到更新指令.重新启动到IAP程序.IAP更新完成再回到APP执行.解决掉电的问题,可 ...

两个APP程序?每次更新程序的时候覆盖掉一个,另一个做备份?
请问这个方案用于产品过吗?
那样的话对于用户每次更新的程序中断向量偏移地址都不同,另外程序如果太大也不好吧。
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
回复

使用道具 举报

50

主题

1805

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
6662
金钱
6662
注册时间
2016-5-29
在线时间
910 小时
发表于 2017-4-12 11:04:50 | 显示全部楼层
XUZJWWSZ 发表于 2017-4-12 10:30
两个APP程序?每次更新程序的时候覆盖掉一个,另一个做备份?
请问这个方案用于产品过吗?
那样的话对 ...

看来楼主还是有两下子的.两个APP,你不会玩备份与还原吗?为什么只会玩中断向量呢.
回复

使用道具 举报

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
 楼主| 发表于 2017-4-13 08:35:36 | 显示全部楼层
操作系统 发表于 2017-4-12 11:04
看来楼主还是有两下子的.两个APP,你不会玩备份与还原吗?为什么只会玩中断向量呢.

没玩过,程序的备份与还原应该怎么做呢?
(另外最佳答案不是我设置的,我还有问题没解决,今早上来看到结贴了我一脸黑线)
另一个问题是假如用户刷新的APP 程序是错的,新的APP程序根本无法接收刷新程序指令该怎么办呢?
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
回复

使用道具 举报

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
 楼主| 发表于 2017-4-13 08:36:30 | 显示全部楼层
yklstudent 发表于 2017-4-12 08:34
楼上的很明确,flash划分三个区,IAP、APP1和APP2;APP2就是备份区;更新的时候就在APP1区里更新你的APP2区 ...

请看一下六楼
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
回复

使用道具 举报

1

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-11-24
在线时间
15 小时
发表于 2017-4-13 14:53:31 | 显示全部楼层
我现有产品已使用
407+ucos+lwip 外地的终端产品全部链接到我公司的服务器 随时都能查询状态和更新程序
方案
分区:FLASH_SECTOR_0 boot区   FLASH_SECTOR_3 参数区   56扇区为用户app  78也是 在56升级的是78  在78升级56
boot功能
    BSP_IntDisAll();
    延时读参数   
    if(SYS_PARA_.start_adr != USER_FLASH_LOW_ADDRESS)   SYS_PARA_.start_adr = USER_FLASH_HIGH_ADDRESS;   
    usr_adr = SYS_PARA_.start_adr;
    if(APP_RST_VALID())   //通过跳线可恢复上一次的程序 防止升级错误
    {
        usr_adr = (usr_adr==USER_FLASH_LOW_ADDRESS) ? USER_FLASH_HIGH_ADDRESS:USER_FLASH_LOW_ADDRESS;
    }
    __disable_irq();
    //IWDG_Init(6,500);
    /* Jump to user application */
    jump_adr = *(__IO uint32_t*) (usr_adr + 4);
    Jump_To_Application = (pFunction)jump_adr;
    /* Initialize user application's Stack Pointer */
    __set_MSP(*(__IO uint32_t*)usr_adr);
   
    SCB->VTOR = usr_adr;
    __set_FAULTMASK(0);      // 关闭所有中端
    Jump_To_Application();
   
    while(1);


用户区在56扇区通过多渠道(网络、总线、rfid)命令来接收升级数据 写入78扇区 写完后crc校验 完毕后把参数区引导位置修改成78扇区 重启 ok
回复

使用道具 举报

33

主题

197

帖子

0

精华

高级会员

Rank: 4

积分
587
金钱
587
注册时间
2015-1-9
在线时间
80 小时
 楼主| 发表于 2017-4-13 16:11:45 | 显示全部楼层
Jason2016 发表于 2017-4-13 14:53
我现有产品已使用
407+ucos+lwip 外地的终端产品全部链接到我公司的服务器 随时都能查询状态和更新程序
...

多谢你,SCB->VTOR = usr_adr。这一句写在IAP程序里让我茅塞顿开。

但是还是要通过手动操作硬件的方式防止APP程序更新错误。我想这也是不可避免的,就算APP程序暂时没错,也难保它半年之后不跑飞。
我有一个减少这种错误的方案的大概思路:
在备份寄存器设置一个新的APP验证完成标志:APP_OK;新的APP执行次数标志:APP_CNT。
1,APP1更新APP2,
     APP_OK=0;
     APP_CNT=0;
     MCU_RESET;

2,IAP程序在APP_CNT==0的情况下,
       APP_CNT=1;
       跳转APP2.
   (下次必须     APP_OK==1    才能继续跳转APP2,否则说明APP2有问题,就跳转APP1)

3,APP2在首次执行的时候要由用户发送指令验证自身的远程更新能力是否有问题,
    如果没问题   APP_OK=1。
君子性非异也,善假于物也
不知常,妄作,凶
纵浪大化中,不喜亦不惧,应尽便须尽,无复独多虑
路漫漫其修远兮,吾将上下而求索
菩萨畏因,凡夫畏果
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-4-9 02:11

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表