基于ARM嵌入式系统的ISP设计

发布者:幸福的老农最新更新时间:2021-05-18 来源: eefocus关键字:ARM  嵌入式系统  ISP设计 手机看文章 扫描二维码
随时随地手机看文章

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


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上去


关键字:ARM  嵌入式系统  ISP设计 引用地址:基于ARM嵌入式系统的ISP设计

上一篇:采用超声波的移动机器人导航设计
下一篇:基于ARM+μC/OS-Ⅱ的斜井防跑车控制器设计

推荐阅读最新更新时间:2024-11-11 07:17

ARM、DSP、FPGA的技术特点和区别有哪些
ARM、DSP、FPGA与什么区别?各自有什么特点?这是一个很基础的问题,本文对ARM、DSP、FPGA的各自特点和技术进行了分析。 ARM(Advanced RISC Machines)是微处理器行业的一家知名企业,设计了大量高性能、廉价、耗能低的RISC处理器、相关技术及软 件。ARM架构是面向低预算市场设计的第一款RISC微处理器,基本是32位单片机的行业标准,它提供一系列内核、体系扩展、微处理器和系统芯片方案,四 个功能模块可供生产厂商根据不同用户的要求来配置生产。由于所有产品均采用一个通用的软件体系,所以相同的软件可在所有产品中运行。目前ARM在手持设备 市场占有90以上的份额,可以有效地缩短应用程序开发与测试
[单片机]
ARM9(S3C2440) UART
数据通信的方式 数据通信的方式基本分为: (1)、并行通信:多条数据线将数据的各位同属传送。 特点:传输速度快,适用于短距离通信。 (2)、串行通信:一条数据线将数据一位一位的顺序传送。 特点:线路简单,低成本,适用于远距离通信。 一: 异步通信: 以一个字符为传输单位,通信中两个字符间的时间间隔是不固定的,然而同一个字符中的两个相邻位之间的时间间隔是固定的。 二: 通信协议 指双方约定的一些规则。在异步通讯时,对数据格式有如下的约定:有空闲位,起始位,资料位,奇偶校验位,停止位。 (1)、起始位:先发送一个逻辑信号“0”信号,表示传输字符的开始。 (2)、数据位:紧接在起始位之后。数
[单片机]
多年来苹果基于ARM的Mac并不遥远
今日,外媒MacRumors发文表示,苹果公司目前在Mac系列产品中使用的处理器都依赖于英特尔,但这种情况可能很快会改变。 ARM与Intel 目前,苹果在所有Mac产品中都使用了Intel的x86芯片,iPhone和iPad则使用基于Arm的芯片。x86芯片和Arm芯片使用了不同的架构。 英特尔的芯片是CISC(复杂指令集)架构,而Arm芯片是RISC(精简指令集)架构。顾名思义,RISC指令比CISC指令更小、更简单。这也意味着Arm处理器所需的功率更少,且执行计算任务的效率更高。 从历史上看,Arm芯片的功能并不强大,因为x86芯片是为台式机设计,而Arm芯片则是为低功耗应用(如移动设备)设计的。过去,Arm一直专注于电
[手机便携]
基于ARM的北斗导航 GPRS GIS车辆监控系统设计
  1 系统需求及应用分析   随着我国城镇化进程加快,地铁、轻轨、快速公交等现代化公共交通快速发展,轨道和公共交通成为城市交通的骨干。目前,我国现代化轨道交通和公共交通的建设仍存在资金需求量大、融资难,以及投产后车辆管理调用、维护效率低等问题。传统车辆监控系统一般采用单片机作为数据采集终端、短消息服务 ( Short Messaging Service,SMS ) 作为通信手段、MapInfo作为地理信息系统( Geographic Information System,GIS ) 平台。由于单片机无操作系统,程序移植性差,已难以胜任车辆监控系统功能快速发展的要求;同时,受带宽的影响,SMS 通信链路已无法扩展图像、语音数据传
[单片机]
基于<font color='red'>ARM</font>的北斗导航 GPRS GIS车辆监控系统<font color='red'>设计</font>
Linux之ARM(IMX6U)裸机C语言蜂鸣器驱动实验--驱动编写,编译
前几篇博文试验中的驱动 LED 灯亮灭属于 GPIO 的输出控制,本章再巩固一下 I.MX6U 的 GPIO输出控制,在 I.MX6U-ALPHA 开发板上有一个有源蜂鸣器,通过 IO 输出高低电平即可控制蜂鸣器的开关,本质上也属于 GPIO 的输出控制 1、有源蜂鸣器简介 蜂鸣器常用于计算机、打印机、报警器、电子玩具等电子产品中,常用的蜂鸣器有两种:有源蜂鸣器和无源蜂鸣器,这里的有“源”不是电源,而是震荡源,有源蜂鸣器内部带有震荡源,所以有源蜂鸣器只要通电就会叫。无源蜂鸣器内部不带震荡源,直接用直流电是驱动不起来的,需要 2K-5K 的方波去驱动。 I.MX6U-ALPHA 开发板使用的是有源蜂鸣器,因此只要给其供电就会工作
[单片机]
Linux之<font color='red'>ARM</font>(IMX6U)裸机C语言蜂鸣器驱动实验--驱动编写,编译
轻松学ARM系列之玩转蜂鸣器
今天我们来学习轻松学arm系列之玩转蜂鸣器,基于arm的cortex_a8内核的三星S5PV210开发平台。 那么我们来看一下如何学习使用pwm控制蜂鸣器? 一、总体架构图 搞定蜂鸣器之前需要我们对三星的GPIO简介的相关章节有一定的了解,主要是timer 定时器。 二、玩转定时器的几个要领 2.1 查看开发板上蜂鸣器的连接的原理图 蜂鸣器对应的原理图 核心板的对应的原理图 2.2 选中GPD0CON配置寄存器的xpwmTOUT1功能 GPD0.GPD0CON = ((~(0xf 0))& GPD0CON)| (0x2 4);选为pwm输出功能 2.3 配置预分频和分频寄存器的
[单片机]
轻松学<font color='red'>ARM</font>系列之玩转蜂鸣器
ARM Linux 更新启动画面
启动画面(Splash Screen)是指在Linux启动时候显示的图片,通常默认情况下Linux只是输出一些传统的小企鹅图标和启动Console命令行,但嵌入式设备都需要定制自己开机画面,这里就以 Toradex ARM计算机模块 及其发布 Linux 为例对ARM Linux更新启动画面做说明。 1). 配置 开发主机:Ubuntu 14.04 X86_64 目标板:Toradex ARM 计算机模块及自带的Embedded Linux 2). 准备 下载Toradex Embedded Linux 源码包 请按 这里 说明如何下载及编译Kernel内核 安装相关软件包 --------------------
[单片机]
利用ADS1.2和JLINK V8搭建ARM7开发平台
硬件资源:一块以ARM7(LPC2119)为核心的电路板,Jlink v8仿真器,LONGWEIPS-305DM直流稳压电源,笔记本电脑(安装win7旗舰版) 软件资源:ADS1.2 Jlink v8驱动Setup_JLinkARM_V408i 最近需要用到LPC2119这款芯片,可手头没有这款芯片的仿真器,上网一查周立功公司的仿真器AK100某宝上最便宜也要1.8K,这个....囊中羞涩啊。LZ我忽然想到以前用ADS1.2搞S3C2440开发时用的是Jlink v8仿真器,这个仿真器能不能用到LPC2119这款芯片呢?于是乎赶忙问度娘,查资料得知有Jlink v8支持LPC2119芯片,欣喜万分,立马开始尝试。 由于
[单片机]
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved