为什么需要IAP
- 固件在用户那里通过串口或USB升级不方便
- 通过ISP让用户体验不好
- 可以省去邮寄固件升级的麻烦
固件程序的场景
- 初次量产的时候
- 需要升级的时候
在这两种场景需要 hex 文件是不同的,出厂的时候需要把 IAP 程序和真正的业务固件程序一起生成一个HEX ,然后发给工厂量产.
升级的时候,因为业务固件程序的问题,导致板子需要重新烧写,需要业务固件程序的HEX文件
第一个场景要了解hex的格式,然后将不同地址空间的hex合并成一个。
第二个场景需要将Hex 转化为一个 bin文件.
如何编写IAP
- IAP 读取 U盘,这里我们支持 FAT32, 读取根目录下的 hardware.bin ,找到了,状态为更新态,将这个文件读取出来烧写到固定地址,然后用户就需要重新启动固件了。
- 当没有找到hardware.bin 的时候,设置状态,为运行态,然后设置 新的irq_handler 和 新的main ,跳转到新的main,然后发生中断的时候,让新的中断程序去处理
IAP试验
- 写简单程序IAP,只支持 串口输出调试信息
- 写另外一个简单程序 xxx,生成 Hex并且转换为bin,再转化为数组
- 将xxx 生成的数组放到 IAP 的程序中
- IAP 程序在上电后判断EEPROM 中某个标志位 FF 则可以升级,将数组的内容写到固定位置,然后设置标志
- 如果标志不是 FF ,则升级完毕,跳转到xxx 所在的位置(注意调整 irq_hander 的处理函数指向新的处理函数)
- IAP 的全局变量要用 __AT 设置为一个固定的SRAM 中,不要和 xxx 中的变量冲突。
试验结果
- 要验证是否写入成功
- 读取出来并打印出来看看