DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2890|回复: 0
打印 上一主题 下一主题

用ATmega8单片机设计串行编程器

[复制链接]
跳转到指定楼层
楼主
发表于 2012-1-27 14:10:57 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
                    通常进行单片机实验和开发,编程器是必不可少的。仿真、调试完的程序要借助编程器写入单片机的存储器中,随着单片机技术的发展出现了MTP(可多次编程)存储器技术和ISP(在系统可编程)技术,这样就可以省去昂贵的仿真器,只要通过计算机接口和一条串行下载线就可直接在目标芯片上编程。ATmega8就是一种具有MTP与ISP功能的单片机,他也是AVR单片机中价格性能比最高的单片机,因此研究他的串行编程特性对利用他的上述功能来开发应用单片机有很高的实用价值。
1 ATmega8的体系结构与主要性能特点
ATmega8是ATMEL公司在2002年推出的一款新型的AVR高档单片机,他的芯片内部集成了较大容量的存储器和丰富强大的硬件接口电路,具备AVR高档单片机MEGE系列的全部性能和特点。但由于采用了小引脚封装(为DIP28和TQFP/MLF32),所以价格仅和低档单片机相当,再加上AVR单片机的系统内在可编程特性,使得无需购买昂贵的仿真器,只需要一条具有编程器功能的串行下载线就可以进行单片机嵌入式系统的设计和开发。
ATmega8是一款采用低功耗CMOS工艺生产的基于AVR RISC(精简指令集)结构的8 b单片机。AVR单片机的核心是将32个工作寄存器和丰富的指令集连接在一起,所有的工作寄存器都与ALU(算术逻辑单元)直接相连,实现了在一个时钟周期内执行的一条指令同时访问(读写)2个独立寄存器的操作。这种结构提高了代码效率,使得大部分指令的执行时间仅为一个时钟周期。因此,ATmega8可以达到将近1 MIPS/MHz的性能,运行速度比普通的单片机高出10倍。
ATmega8的主要性能特点如下:
(1)高性能、低功耗的8bAVR微控制器,先进的RISC精简指令集结构,130条功能强大的指令,大多数为单周期指令,32个8b的通用工作寄存器,工作在16MHz时具有16MIPS的性能。
(2)片内集成了较大容量的非易失性程序和数据存储器
8 kB的Flash程序存储器,可擦写次数大于10 000次;512B的E2ZRROM,擦写次数至少100 000次;支持可在线编程(ISP)和可应用自编程(IAP);可编程的程序加密位。
(3)丰富强大的外部接口性能
3个PWM通道,可实现任意16b以内的、相位和频率可调的PWM脉宽调制输出;6通道A/D转换;一个12C的串行接口,一个可编程的USART接口;一个支持主/从、收/发的SPI同步串行接口;2个带预分频的8b定时/计数器,1个带预分频的16b定时/计数器;带片内RC振荡器的可编程看门狗定时器。
(4)特殊的微控制器性能
可控制的上电复位延时电路和可编程的欠电压检测电路;内部和外部共18个中断源;5种休眠模式(空闲,ADC噪声抑制,省电,掉电,待命)。
2 串行编程器的设计
从上面的描述我们就对ATmega8有了一个总体的认识,ATmega8的在线可编程功能为单片机的设计和开发提供了极大的方便,工程人员可以编译完程序后直接通过编程器将程序写入Flash存储器(而无需昂贵的仿真器)。并且可以自己来设计编程器,下面就以ATmega8作为处理芯片来设计一个串行编程器,也通过这个应用的例子来介绍一下ATmega8的具体应用。
(1)硬件电路,串行编程器的电路原理图如图1所示。


从PC机的串行口通过RS232引出3条线:RXD,TXD,GND用于PC机与ATmega8的通信。最右端的5条线分别与要写入程序的芯片相连。
(2)串行编程器的工作原理
ATmega8的同步串行接口SPI允许在几个AVR单片机之间,以与SPI接口协议兼容的方式进行高速的同步数据传输。因此可以把串行编程器的处理芯片设计为主机,目标芯片就作为从机,这样就可以实现2个单片机的数据传输,从而实现程序的烧写过程。数据由主机发送从机接收。向主机的SPI数据寄存器SPDR装入待发送数据的写操作,自动启动SPI时钟发生器,于是该数据便在时钟脉冲的控制下开始逐位左移或右移。若设定最高位MSB先传送,主机的MSB将自MOSI(PB3)引脚输出,经从机的MOSI引脚进入其8b移位寄存器中,占据最低位LSB的位置。同时,从机的MSB由MISO(PB4)引脚移出,通过主机的MISO引脚进人到主机移位寄存器中,作为他的LSB位。这样8个时钟脉冲后,主机SPI移位寄存器中的内容就完全送给了从机。图2为主从机通信流程图。

(3)具体的工作过程
把图2的ATmega8设为主机,PB3(MOSI),PB4(MISO),PB6(SCK),PBl管脚用于控制对目标芯片的写入。PBl引脚控制单片机的Reset,只有当Reset被拉为低时单片机才进入串行编程模式。从机的所有I/O引脚都处于输入状态且上拉电阻被禁止。PB6(SCK)引脚用于提供串行编程的时钟,他在上电期间必须为低电平,这样才能保证主机芯片和从机芯片的时钟同步,因此上电期间给Reset一个正脉冲(至少2个XTALl时钟周期)以保证SCK的低电平,这可以通过软件来实现。PB3(MOSI)引脚用于将程序送人从机中。数据在SCK的上升沿被输入,从机的Reset被拉低后,总是将他的MOSI设为上拉禁止的输入状态,用于从主机接收数据。当从从机中读取数据时,数据在SCK的下降沿输出。设计硬件时要保证从机的Reset,SCK,MOSI,MISO这4根线能被编程器自由地置高置低,否则不可能进行在片编程。具体的命令字格格式可参照ATmega8manual中所给出的串行编程命令表。

(4)软件设计
编程器的软件分为两部分,即上层程序和下层程序。上层程序在PC机上运行,用VB编写,来完成HEX文件的发送。下层程序用C语言编写,可通过下载线下载到ATmega8(主机)中;完成接收HEX文件和写人、读及擦除功能。
写芯片 下层程序将HEX文件传送给ATmega8。HEX文件的文件结构是由汇编程序的指令并用ASCII码表示的文本文件,他由若干数据帧组成,每帧的结构顺序为;数据长度、高位地址、低位地址、数据属性、数据及校验和。因为ASCII码是一个4位的二进制数,每2个ASCII码合起来才能用1B表示,所以要先把HEX文件转换后,再发送。发送过程中对数据的校验和是由每一帧的校验和与该帧的最后两位相比较完成的。下层程序完成接收HEX文件和写目标芯片,其过程为先接收HEX文件存储于数据缓冲区,根据地址将数据写入目标芯片的存储器中,数据存放以高位地址、低位地址和数据为顺序存放,所以在读取时要严格按顺序读取。写程序的流程图如图3所示。


读芯片 读芯片的过程是通过编程器将目标芯片中的数据送PC机,PC机收到数据后保存在一个文件里。下层用C编写控制主机从从机读取数据,上层用VB实现,调用MSCOMM和COMMDIAI。即可完成对数据的接收及存储。读芯片的流程图如图4所示。
在数据的传送过程中,要绝对保证数据不丢失。通常采用2种方法:一种是延时,即写人数据后等待一段时间再写入下一个数据;另一种是采用数据校验技术,就是在写人数据后再读数据然后判断是否正确写人。但是这两种方法都存在缺陷,第1种时间太长并且不能保证写入数据的完全正确,第2种方法当要写入的数据和程序存储器的原始数据相同时就判断失效。可以把这两种方法有机地结合起来,从而保证数据不丢失。具体的过程如下:
当向Flash的某一地址写入数据时,当一个数据写入完毕,允许写下一个数据时,读取这一地址的数据,如果读到的数据不是0xFF(程序被擦除后,存储单元里的数据都为0xFF),就再继续接着向存储器里写数据,如果读到的数据是0xFF,就再重新写数据再校验。但是当要向存储器里写的数据正好是0xFF时,用这种方法就出错,这时可以通过程序控制在检验到读出数据为0xFF时,再连续实行2次这样的操作,如果读出数据还是0xFF,就采取延时的方法处理后,再接着进行对Flash的操作。
擦除芯片 对芯片擦除就是对芯片重新固化。可以通过控制编程引脚高低电平来实现,但是加控制信号时间太短的话,无法擦除干净,如果过长就容易烧坏芯片。其实擦除的结果是所有地址里的数据都为0xFF,这样也就是说可以通过向存储器里写0xFF操作来实现擦除,本设计采取这种方法就避免了因为选择控制信号时间不合适而导致的一些问题。
3 结 语
本文介绍了ATmega8这款AVR高档单片机,并论述了他的串行下载特性和串行编程器的工作原理;同时提出了新的串行编程数据校验方法和程序擦除方法。MTP(可多次编程)和ISP(在系统编程)技术给单片机应用系统开发提供了很大的方便和灵活性,利用这两种技术可以直接在电路板上反复进行下载调试,甚至可以实现远程在线升级,因此对单片机编程特性的研究有很高的实用价值。

            
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2025-1-22 23:49 , 耗时 0.089448 秒, 21 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

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