0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于STR730微控制器芯片实现在系统编程的设计方案

电子设计 来源:单片机与嵌入式系统应用 作者:吴嵩,曹乐千 2020-09-25 09:53 次阅读

应用程序的固化是嵌入式产品开发和生产过程中一个重要环节。基于ARM嵌入式系统常用的程序固化方法是,用仿真器通过JTAG口将程序烧录到Flash里,在产品的开发阶段,使用仿真器几乎是必然的;然而到了产品的生产阶段,进行应用程序烧录或升级操作的往往是生产线上的工人,他们不易掌握仿真器的使用方法,而且在生产阶段也需要把JTAG调试口封住以防软件被窥视。在使用意法半导体的STR730开发产品的过程中,设计了一种通过串口进行ISP(In System Programming,在系统编程)的方案。该方案成本低,生产线使用起来也很方便,而且即使升级过程中发生掉电之类的意外也不会影响下一次升级,安全而可靠。

1 硬件连接

ISP方案的硬件连接如图1所示。RS232转接板用来将RS232电平转换为TTL电平,并通过ISP_EN引脚给ARM开发板提供信号,让其进入ISP状态。PC机上运行用VC语言编写的ISP.exe,该程序把需要烧录到F1ash里的.bin文件加密后发送到ARM开发板,同时把烧录的进度提示显示给用户。图1中的阴影部分具有固定的程序。

2 Flash烧录原理

2.1 存储器分配

STR730是意法半导体生产的基于ARM7TDMI的微控制器芯片,内置16 KB RAM(0xa0000000~Oxa0003fff)和256 KB Flash(Ox80000000~Ox8003ffff)。内置256 KB Flash的分配情况如图2所示。按照图2中存储器的分配编写Scatter文件,在生成可执行文件时链接器会根据Scatter文件的内容把相关代码段定位到特定的地址上。该例中,程序从Flash启动,且没有使用存储器重映射,因此中断向量必须定位到Flash的起始位置。

扇区O的内容需要事先通过JTAG口烧入,此后就可以利用扇区O中的烧录程序Programrher.o通过串口进行ISP。在整个ISP过程中扇区0的内容是保持不变的,这样就可以防止ISP过程中出现掉电之类的意外,导致初始化代码Startup或烧录程序Programmer受到损坏而无法再一次进行ISP。

无论对嵌入式产品添加新功能还是修改原有的软件BUG,涉及的都只是用户应用程序的改动,初始化代码Startup.s是无需改动的,所以扇区O的内容在ISP过程中可否保持不变,关键是能否使首次编译生成的Vector.0始终与以后多次编译的App.o相匹配。

需要特别指出的是,当用户应用程序发生改变时,实际的中断服务函数(一般是C语言函数)很可能发生了改变,或者是实际的中断服务函数的入口地址发生了改变,怎么通过固定不变的中断向量Vector.o找到变化的中断服务函数的入口呢?只要这个问题解决了,就可以使首次编译生成的Vector.o始终和以后多次编译的App.o相匹配,这是该方案可行性的关键所在。为解决这个问题,笔者在Flash的固定位置(0x80002000~0x800020ff)做了一个中断映射表,实际上里面存放的是一条条跳转指令。由于中断映射表INTMap.s和用户应用程序App.c是一同编译、链接的,里面的跳转指令当然可以准确找到实际的中断服务程序入口;而位于扇区O的中断向量Vector.s虽然不和用户应用程序一起编译,但中断向量里的跳转指令是绝对跳转到固定的中断映射表区域。这样通过2次跳转就可以准确找到中断服务程序的入口。

可以通过图3看出快中断的处理流程(其他的中断处理流程类似)。

2.2 ISP执行的步骤

把起到烧录Flash作用的程序单独作为一个工程编译、链接,生成.bin文件;然后把.bin文件转化成一个unsigned char型的数组,并把该数组放在一个单独的文件Programmet.c中;最后利用Scatter文件把Programmer.o定位在固定的地址空间(0x80001000~Ox80001fff,如图2所示)。这样一来,就可以编写汇编程序,把烧录程序Pro—grammer.o拷贝到RAM中,并让PC指针跳转到RAM中执行烧录。由于STR730没有外部Flash,要烧录Flash程序必须在RAM中运行,所以拷贝Programmer.o到RAM中是必需的。以下代码摘取自Startup.s。

CMP r1,#1

烧录程序Programmet的软件流程如图4所示。

需要说明的是:

①擦除Flash并不是完全擦除,而是擦除扇区0之外的其他扇区;

②数据缓冲区有限,每次只接收指定大小的数据,这样接收和烧录就可以并行进行,提高了ISP的速度;

③为了提高软件的安全性,原始的.bin文件是经过加密的,在烧录前需要将原始数据解密。

结 语

本文阐述的这种通过串口ISP的方法已经在实际的开发生产过程中使用。实践证明,相比其他烧录Flash的方法有很多优势,比如成本低、硬件连接简单、操作方便、增强软件的安全性等。使用的MCU是STR730,稍做改动也可以把这种ISP方法推广到其他ARM体系结构的MCU上去。

责任编辑:gt

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

    关注

    48

    文章

    7627

    浏览量

    151775
  • 芯片
    +关注

    关注

    456

    文章

    51059

    浏览量

    425695
  • ARM
    ARM
    +关注

    关注

    134

    文章

    9143

    浏览量

    368332
收藏 人收藏

    评论

    相关推荐

    什么是微控制器

    就执行自动波特率功能,并与主机的波特率同步。如图1所示是在系统编程的物理连接.简单的引导加载程序接口允许使用几种方法来实现PC机与目标微控制  间的通信。最简单的方法是使用Dalla
    发表于 11-14 14:30

    中文应用笔记-使用外部微控制器给PSoC编程

    中文应用笔记-使用外部微控制器给PSoC编程主机源串口编程 (HSSP) 是使用在系统串行编程 (ISSP) 协议进行 PSoC® 1 器件
    发表于 11-22 16:31

    基于STM32的12个设计方案(电机控制,LED,触摸屏,多路电...

    一种STM32微控制器电机控制方案设计与实现嵌入式设计:以STM32为控制核心的数码相框设计方案
    发表于 03-25 15:21

    如何去设计并实现在系统编程的软件?

    基于Neuron芯片控制节点是什么?它有什么功能?如何去设计并实现在系统编程的软件?
    发表于 04-27 06:44

    使用MCU微控制器实现对物联网设备的控制

    **PacketTracer模拟器物联网教程2—MCU微控制器编程**一、目的使用MCU微控制器实现对物联网设备的控制二、设备1.台灯2.S
    发表于 11-01 07:36

    STM32H730xB微控制器的数据手册

    本文档提供有关STM32H730xB微控制器的信息,例如描述、功能概述、引脚分配和定义、封装和订购信息。
    发表于 11-25 07:12

    利用Ethernet通信接口实现在应用编程的解决方案

    本应用笔记适用于STM32F2x7微控制器,介绍利用Ethernet通信接口实现在应用编程实现方案
    发表于 12-01 07:21

    基于LonWorks的在系统编程技术

    LonWorks 技术的应用使得在系统编程的内涵得以更充分的体现。本文在概要介绍ISP 以及LonWorks 技术的基础上, 详细说明采用基于Neuron 芯片控制节点实现对CPLD
    发表于 04-16 14:12 8次下载

    PSD813F用作嵌入式微控制器68HC11外围的设计方案

    PSD813F用作嵌入式微控制器68HC11外围的设计方案
    发表于 05-13 11:23 6次下载
    PSD813F用作嵌入式<b class='flag-5'>微控制器</b>68HC11外围的<b class='flag-5'>设计方案</b>

    基于8051的微控制器系统编程

    摘要:在系统编程是一种有价值的功能,在无需拆解嵌入式系统替换存储的情况下,就可以对系统固件进行升级。Maxim大多数基于8051的微控制器
    发表于 04-23 14:00 785次阅读
    基于8051的<b class='flag-5'>微控制器</b>在<b class='flag-5'>系统编程</b>

    如何使用8051的微控制器系统进行编程

    Dallas Semiconductor基于8051的微控制器类产品中,许多型号都支持通过通用RS-232串口实现在系统编程。在系统编程意味着程序和/或数据存储
    发表于 02-21 16:48 6次下载
    如何使用8051的<b class='flag-5'>微控制器</b>在<b class='flag-5'>系统</b>进行<b class='flag-5'>编程</b>

    基于STM32微控制器的物联网节点设计

    在物联网端点中,外部SPI闪存器件是实现大型数据查找表的有效解决方案。这种方法可轻松实现在系统重新编程和升级,并且最大限度地减少
    的头像 发表于 09-29 15:05 3427次阅读
    基于STM32<b class='flag-5'>微控制器</b>的物联网节点设计

    什么是微控制器?如何编程微控制器

    微控制器进行编程或刻录意味着“将程序从编译传输到微控制器的存储”。微控制器的程序通常是用C
    的头像 发表于 08-21 15:40 1w次阅读

    微控制器中各式各样的编程语言

    在上一篇文章中,我们探索了微控制器中的软件与硬件,并分析了为何微控制器的软件和硬件相辅相成缺一不可。我们知道,微控制器的硬件在出厂时是基本已经确定的,所以操控微控制器并满足不同应用的需
    的头像 发表于 05-19 19:58 2716次阅读

    ARM驱动的微控制器STR91xF数据手册

    电子发烧友网站提供《ARM驱动的微控制器STR91xF数据手册.pdf》资料免费下载
    发表于 11-09 09:20 0次下载
    ARM驱动的<b class='flag-5'>微控制器</b><b class='flag-5'>STR</b>91xF数据手册