bootloader在Arduino中起着至关重要的位置,arduino-1.5.6-r2版本中的bootloader对看门狗(watchdog)的bug进行了修复;mega2560其实就是使用的AVR单片机系列Atmega2560芯片,作为arduino中的一员使用了arduino的开源库,及其开源的外围硬件;单独使用Atmega2560芯片并自己设计电路,又想使用arduino提供的强大的开源库,及其比较方便的开发环境Arduino
 IDE时,会产生很多问题。下面我就来阐述一下自己设计的电路使用Atmega2560芯片,外部8MHz晶振,使用JTAG ICE MKII ICSP烧写程序,注意事项:
1.在保证电源正常供电的情况先,让电路工作,开始下载程序时,注意熔丝位的设置,CKDIV8熔丝位编程会让系统时钟工作在8分频的情况;
2.BOOTRST熔丝位编程会影响系统复位后从boot区重新启动;
3.由于arduino环境默认没有mega2560 8MHz的平台,所以在arduino-1.5.6-r2-windows\Arduino\hardware\arduino\boards.txt中进行新平台的添加,这样在arduino Ide中就会有新的平台加入;例如:
mega2560_8M.name=Arduino Mega2560_8M
mega2560_8M.upload.protocol=wiring
mega2560_8M.upload.maximum_size=258048
mega2560_8M.upload.speed=115200
mega2560_8M.bootloader.low_fuses=0xFF
mega2560_8M.bootloader.high_fuses=0xD8
mega2560_8M.bootloader.extended_fuses=0xFD
mega2560_8M.bootloader.path=atmeg2560_8M
mega2560_8M.bootloader.file=stk500boot_v2_mega2560.hex
mega2560_8M.bootloader.unlock_bits=0x3F
mega2560_8M.bootloader.lock_bits=0x0F
mega2560_8M.build.mcu=atmega2560
mega2560_8M.build.f_cpu=8000000L
mega2560_8M.build.core=arduino
mega2560_8M.build.variant=mega
Mega2560_8M是我新命名的平台,在bootloader中新建Mega2560_8M文件夹,同时把同级目录stk500v2下的所有文件考入Mega2560_8M,我是在ubuntu下进行编译的,当然要使用avr-gcc编译器,make
 clean删除已有的可执行程序,在Makefile中找到maga2560:处,更改F_CPU=16000000为F_CPU=8000000,然后执行make mega2560生成新的可执行程序stk500boot_v2_mega2560.hex;
注意:这其中主要是修改了F_CPU为8M;其他没有修改,可以尝试在windows下编译
4.这样在Arduno IDE中,tool->board中就有了新的平台Mega2560_8M,编译程序是需要指定这个版本类型;
5.程序写好后,需要下载程序到芯片中;步骤如下:
(1)芯片引出的ISP管脚连接JTAG ICE MKII
(2)擦除Flash
(3)下载 Mega2560_8M文件中的bootloader程序stk500boot_v2_mega2560.hex到芯片中
(4)下载程序到芯片中,在此之前不要擦除芯片程序,否则会把bootloader擦掉;
(5)编程BOOTRST熔丝位,让系统复位从boot区执行
这样下来看门狗就可使用了。注意一定要保留bootloader才可以修复一些bug;
--------------------- 
来源:CSDN
原文:https://blog.csdn.net/wzdvs2005/article/details/41349413

关于Arduino MEGA2560 看门狗对bootloader的依赖的更多相关文章

  1. Arduino 看门狗使用

    1.需要调用 #include <avr/wdt.h> 2.设置看门狗复位时间 wdt_enable(WDTO_2S); 代码时间定义的底层查看 #define WDTO_15MS 0 / ...

  2. Arduino - 看门狗定时器(WDT:Watch Dog Timer)

    看门狗定时器(WDT:Watch Dog Timer)实际上是一个计数器. 一般给看门狗一个大数,程序开始运行后看门狗开始倒计数. 如果程序运行正常,过一段时间CPU应该发出指令让看门狗复位,令其重新 ...

  3. 嵌入式 uboot以及kernel添加看门狗临时记录(个人记录未整理乱)

    Uboot_Kernerl_Add_Watch_Dog: U-Boot 2010.06 (Nov 01 2013 - 15:28:44) DRAM:  128 MiBCheck spi flash c ...

  4. RM-Linux驱动--Watch Dog Timer(看门狗)驱动分析

    from:http://blog.csdn.net/geekcome/article/details/6595265 硬件平台:FL2440 内核版本:2.6.28 主机平台:Ubuntu 11,04 ...

  5. S3C3440看门狗驱动程序

    S3C3440看门狗驱动程序 http://www.cnblogs.com/lfsblack/archive/2012/09/13/2684079.html 看门狗是当CPU进入错误状态后,无法恢复的 ...

  6. 基于S3C2440的嵌入式Linux驱动——看门狗(watchdog)驱动解读

    本文将介绍看门狗驱动的实现. 目标平台:TQ2440 CPU:s3c2440 内核版本:2.6.30 1. 看门狗概述 看门狗其实就是一个定时器,当该定时器溢出前必须对看门狗进行"喂狗“,如 ...

  7. [看门狗]基于Linux的嵌入式系统全程喂狗策略

    转自:http://blog.csdn.net/erickhuang1989/article/details/8721548 在嵌入式系统中,为了使系统在异常情况下能自动恢复,一般都会引入看门狗电路. ...

  8. [WDT]内部看门狗和外部看门狗

    1. 芯片内部看门狗 内部看门狗通常为芯片内部某个特殊定时器,用户可以通过手动初始化.设置timeout.使能.失能该看门狗,然后在线程中定时去喂狗,从而达到检测应用程序跑飞.跑死的情况. 在Linu ...

  9. u-boot分析(五)----I/D cache失效|关闭MMU和cache|关闭看门狗

    u-boot分析(五) 上篇博文我们按照210的启动流程,对u-boot启动中的设置异常向量表,设置SVC模式进行了分析,今天我们继续按照u-boot的启动流程对以下内容进行分析. 今天我们会用到的文 ...

随机推荐

  1. 手机wifi的mac地址是什么??

    简单来说,每个能够接入网络的设备,无论是平板.手机.电脑.电视都有一个专门的序号,这个序号就被称为MAC,正常来说可以看做是这款设备的唯一标识,手机里的MAC其实是特指Wi-Fi无线网卡的MAC地址. ...

  2. npm和npx

    npx 指令会先在项目的node_modules里面找资源包 npm info 包名称  [查看资源包的信息]

  3. 「JLOI2011」飞行路线

    前言 看到好多大佬都在跑分层图最短路,\(\text{DP}\) 解法的我瑟瑟发抖... 题目描述 给定一张 \(N\) 个点(点编号从 \(0\) 到 \(N-1\)),\(M\) 条边的无向带权图 ...

  4. Py西游攻关之基础数据类型(六)-文件操作

    Py西游攻关之基础数据类型 - Yuan先生 https://www.cnblogs.com/yuanchenqi/articles/5782764.html 九 文件操作 9.1 对文件操作流程 打 ...

  5. MySql的数据导入到Sql Server数据库中

    步骤一:安装MySql驱动 驱动下载链接:https://dev.mysql.com/downloads/connector/odbc/ 下载完成后安装, 一路Next即可 步骤二:创建DSN DSN ...

  6. RF之目录结构、执行参数、用例标签 -6

    自动化项目的目录结构:        建议的目录结构... 以robot --pythonpath .  tc命令执行tc用例下面所有的用例 builtin库里面的Run Keywords方法实现初始 ...

  7. CTU Open Contest 2019 AB题

    小菜鸡飘过 A: Beer Barrels 题意:给出四个整数:A,B,K,C,:A,B,C都是大于0的个位数,问在所有仅有A或者B组成的K位数中,数字C的个数是多少 思路: 1.先考虑特殊情况: ( ...

  8. pytorch 调整tensor的维度位置

    target.permute([0, 3, 1, 2]) 一定要使用permute以及中括号 一些在我这里没起到作用的网上的例子: 1. https://blog.csdn.net/zouxiaolv ...

  9. d3基本图形

                                             柱状图                                   散点图.气泡图               ...

  10. 最短路径问题:Dijkstra算法

    定义 所谓最短路径问题是指:如果从图中某一顶点(源点)到达另一顶点(终点)的路径可能不止一条,如何找到一条路径使得沿此路径上各边的权值总和(称为路径长度)达到最小. 下面我们介绍两种比较常用的求最短路 ...