当前位置:首页 > 单片机 > 单片机
[导读] 并行编程,最早的编程方法,功能最强大,但需要连接较多的引脚,通常需要12V~24V的高压,以示区别,下面称为高压并行编程。ISP(InSystemProgrammability)在系统编程,简称为串行下载IAP(InApplICationP

并行编程,最早的编程方法,功能最强大,但需要连接较多的引脚,通常需要12V~24V的高压,以示区别,下面称为高压并行编程。
ISP(InSystemProgrammability)在系统编程,简称为串行下载
IAP(InApplICationPrograming)在应用编程,BootLoader也是类似的意思


1ISP虽然利用了SPI接口(例外:M64/M128为UASRT0接口,Tiny13等没有SPI接口)的引脚,但只在复位时起作用,而且下载完成后合格的下载器会自动断开端口的连接,对正常工作时没有影响的(在产品应用中,下载器一定是不会一直粘在上面的)。
2虽然高压并行下载能修复任何熔丝位,但对于贴片封装来说是很不现实的,所以ISP接口是最常用的下载方式了
3虽然IAP是一种新的升级方法,但IAP程序本身也是要先用高压并行下载或ISP来烧进芯片里面才行
4Tiny13等少管脚AVR芯片因为管脚实在太少了,有ISP,但没有[高压并行编程]而特制了[高压串行编程]

所以,产品上一般都留有ISP接口插座,或更省位置的----留6个焊盘就行了


ISP的工作前提
1芯片没有物理损坏
2芯片的SPIEN熔丝位=0使能ISP功能
3芯片的RSTDISBL熔丝位=1RESET引脚有效(假如芯片有这个熔丝位)
4线路正常---------接错线?短路?
5下载器正常-------特别要考虑连线的接触不良问题
6电源


运行时钟ISP时钟(必须低于运行时钟的1/4)
4096Hz<1024Hz//很变态的用法,外接32.768KHz晶体+CKDIV8,不过AVRISP还是提供了603Hz这个速度了
//另一简易解决办法是下载时在32.768KHz晶体并联一个1MHz晶体,双龙的下载线就配有一个8MHz的石英晶体
32768Hz<8192Hz
128KHz<32KHz//内部RC128KHz
1.0MHz<250KHz//默认值(包括8MHz+CKDIV8),所以AVRISP的ISP速度多为230KHz
8.0MHz<2000KHz
16.0MHz<4000KHz
运行时钟不等于震荡器的频率,因为部分AVR芯片有系统时钟预分频器,可以对震荡器进行1~256分频
CKDIV8熔丝位决定CLKPS位的初始值。
若CKDIV8未编程,CLKPS位复位为“0000”;若CKDIV8已编程,CLKPS位复位为“0011”,给出启动时分频因子为8

AVRISP可提供的ISP时钟921.6KHz,230.4KHz,57.6KHz,28.8KHz,4.0KHz,603Hz
STK500可提供的ISP时钟1.845MHz,460.8KHz,115.2KHz,57.6KHz,4.0KHz,1206Hz

时钟设定ISP方案
内部RC选择合适的ISP速度
外部RC接上合适的电阻和电容,选择合适的ISP速度。------补救:外部时钟源接到XTAL1
外部RC根本就没有什么意义,频率精度/稳定度不高,成本也没有降低,所以新的AVR芯片已经没有这个选项了。
各位网友要注意的是错误设定后补救方法
外部晶体接上合适的晶体,选择合适的ISP速度。------补救:外部时钟源接到XTAL1
外部时钟接上合适的时钟源,选择合适的ISP速度。------补救:外部时钟源接到XTAL1
外部时钟源可以是外部(4MHz)有源晶体输出,其他MCU的XTAL2脚,各种方波振荡电路(NE555)输出等


大部分AVR芯片的ISP端口是SCK,MOSI,MISO,RESET
而M64/M128的ISP端口是SCK,PDI,PDO,RESET
而且M64/M128出厂默认兼容M103----熔丝位M103C=0,很多新特性不能使用,程序也可能不能正常运行
----因为C编译器通常默认自动把SP指向SRAM的末端,M103=0x0FFFH,M64/M128=0x10FFH,必然出错!


AVR的所有熔丝位均是:
1未编程,多为不起作用的意思。
0编程,多为起作用的意思。
基于可编程工艺的都是这样:
PROM/EEPROM/FLASH都是出厂时和擦除后变为全1(0xFF)的,要编程才能变成0。
反过来就是了,跟CE/OE/INT都是[低电平有效]一样,都是很常见。


在ISP模式下永远不能访问(修改)SPIEN位,这是AVR芯片的硬件保护
有独立RESET脚的M16/M32/M64/M128等,在ISP模式下根本就就不会令ISP无效,无论如何修改熔丝位,都能恢复正常。
M8/M48/M88/M168/Tiny系列有RSTDISBL熔丝位可以令导致RESET失效而令ISP无法工作外,其他情况都能恢复正常。

一般来说,只要满足ISP的工作前提,再把XTAL1接到一个4MHz有源晶体的输出,基本是万试万灵的。

不要忘记,并行高压编程的时钟信号也是从XTAL1导入方波信号的。
如果有源晶振的方法不行(除了ISPEN=0,RSTDISBL=0情况外),恐怕高压编程也未必能奏效。


JTAG的影响(M16,M32,M128等):
JTAG能访问SPIEN和JTAGEN,要是不小心同时改成SPIEN=1,JTAGEN=1,将会导致MCU锁死,需要高压并行编程才能恢复。


DebugWIRE的影响:(M48,M88,M168,T2313等,数据手册里面的资料不是很详细)
由于DebugWIRE使用RESET脚来通讯,所以跟ISP有所冲突
可以通过ISP或并行高压编程来使能DebugWIRE功能[即DWEN=0],使能DebugWIRE功能后,ISP功能失效。
可以通过DebugWIRE来关闭DebugWIRE功能[即DWEN=1],关闭DebugWIRE功能后,如果RSTDISBL=1,SPIEN=0,ISP功能有效。
比较特殊的是DebugWIRE调试中,断点的使用会降低Flash数据记忆时间DebugWIRE调试用的器件不能发给最终客户。
JTAGMKII同时具备JTAG/DeubgWIRE/ISP三种功能,可以轻松实现DebugWIRE/ISP的切换。
(软件需要升级到1.09版以后即对应AVRstudio4.12以后版本)
最新版本JTAGMK2使用说明中文pdf(20051125)
设计使用debugWIRE的系统时,必须进行下面的检查:
?dW/(RESET)的上拉电阻不得小于10kΩ。debugWIRE并不需要上拉电阻
?将RESET引脚与VCC直接连接将无法工作
?使用debugWIRE时必须断开与RESET引脚连接的电容
?必须断开所有的外部复位源


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

近日,一则关于 AI 算力领域的消息引发行业震动!据科技网站 The Information 援引四位知情人士爆料,中国科技巨头阿里巴巴与百度已正式将自研芯片应用于 AI 大模型训练,打破了此前对英伟达芯片的单一依赖。

关键字: AI 算力 阿里 百度 芯片 AI模型

上海2025年9月5日 /美通社/ -- 由上海市经济和信息化委员会、上海市发展和改革委员会、上海市商务委员会、上海市教育委员会、上海市科学技术委员会指导,东浩兰生(集团)有限公司主办,东浩兰生会展集团上海工业商务展览有...

关键字: 电子 BSP 芯片 自动驾驶

9月1日消息,继小鹏、零跑后,现在小米汽车也宣布了8月的交付量。

关键字: 小米汽车 芯片

当地时间 8 月 22 日,美国芯片制造商英特尔公司宣布与美国联邦政府达成协议,后者将向英特尔普通股投资 89 亿美元,以每股 20.47 美元的价格收购 4.333 亿股英特尔普通股,相当于该公司 9.9% 的股份。

关键字: 英特尔 半导体 芯片

在当今数字化时代,人工智能(AI)和高性能计算(HPC)的迅猛发展对 GPU 芯片的性能提出了极高要求。随着 GPU 计算密度和功耗的不断攀升,散热问题成为了制约其性能发挥的关键因素。传统的风冷方案已难以满足日益增长的散...

关键字: 人工智能 高性能计算 芯片

8月20日消息,博主数码闲聊站暗示,9月底大概率只有小米16系列会亮相,其它骁龙8 Elite 2旗舰、天玑9500旗舰新品都将排到10月份,新机大乱斗会在国庆假期之后开始。

关键字: 小米雷军 芯片

8月21日消息,据媒体报道,英伟达宣布将自研基于3nm工艺的HBM内存Base Die,预计于2027年下半年进入小规模试产阶段,此举旨在弥补其在HBM领域的技术与生态短板。

关键字: 英伟达 黄仁勋 芯片 显卡

继寻求收购英特尔10%的股份之后,近日又有消息称,特朗普政府正在考虑通过《芯片法案》资金置换股权的方式,强行收购美光、三星、台积电三大芯片巨头的股份。若此举落地,美国政府将从“政策扶持者”蜕变为“直接股东”,彻底重塑全球...

关键字: 芯片 半导体

在这篇文章中,小编将为大家带来单片机的相关报道。如果你对本文即将要讲解的内容存在一定兴趣,不妨继续往下阅读哦。

关键字: 单片机 AVR PIC

在集成电路设计流程中,网表作为连接逻辑设计与物理实现的关键桥梁,其分模块面积统计对于芯片性能优化、成本控制和资源分配具有重要意义。本文将详细介绍如何利用 Python 实现网表分模块统计面积的功能,从网表数据解析到面积计...

关键字: 网表 芯片 分模块
关闭