由于各种原因我的fl2440无启动代码,无任何程序,这时要通过jlink来烧录相关boot程序。

准备工作:

1、Jlink使用jlink commander工具

2、初始化sdram的程序boot.bin

3、运行SDRAM的程序或者bootloader 这里使用u-boot_sdram.bin(至少包含nand擦写烧录和程序加载)

4、正常的u-boot程序u-boot.bin(这里使用的是u-boot-2013.10的版本,这个版本之后的相关配置使用了linux一样配置方法,功能差不多)

Bootloader(u-boot)设计启动原理步骤:

1、由于fl2440-I 只提供了nand flash启动,因此cpu启动是本身会把nand flash前4K代码copy到内部sram,并从sram 的0x00000000地址开始执行。

2、通过内部sram的前4K代码完成对nand flash里u-boot程序的读取,并设置pc跳转到正常的u-boot运行。(在编写正常u-boot时要确保前4k代码能正常,即使用位置无关的代码,函数调用bl等)

3、在u-boot里对相关内核参数设置或者维护操作处理。

BootLoader启动原理知道后,就应该知道内部4k sram必须要有启动代码。现在板子是白片,所以要用jlink给内部sram烧录程序。

步骤如下:

1.连接后打开j-link commander,第一次键入connect命令之后一直按enter键确定到正常模式

2.使用loadbin命令下载boot.bin到0x0开始处

3.设置pc到0x00处使用命令setpc  0,使用g命令开始运行程序

4.因为我的boot.bin里初始化了sdram为后期烧录u-boot_sdram.bin使用。在这里我点亮了一个灯方便调试。使用halt命令将cpu停掉。并使用loadbin命令将u-boot_sdram.bin烧录到0x32000000处。最后跳转到0x32000000处运行u-boot进行下一步操作。

这个u-boot_sdram.bin实现了nand flash的烧写和串口的通讯并且定位到0x32000000

5.进入u-boot程序截图如下:

6.在u-boot下使用loady 31000000命令超级终端的ymodem协议把程序加载到sdram这里我加载到0x31000000,注意不要覆盖你sdram里面的u-boot

7.使用命令nand erase 0 10000 擦除nand,和命令nand write 31000000 0 10000烧录自己的u-boot到nand里,reset命令即可进入新的u-boot的。此后nand里面就有相关的u-boot程序了。

8.新的u-boot如下:

其中boot.bin的程序如下使用汇编处理 u-boot_sdram.bin以附件给出https://files.cnblogs.com/files/stardream/boot_u-boot_sdram_bin.7z。

只针对fl2440

 @start.s

 .equ WTCON,     0x53000000  

 .equ BWSCON,    0x48000000  

 .equ CLKDIVN,   0x4c000014    

 .equ MPLLCON,   0x4c000004  

 .equ GPBCON,    0x56000010

 .equ GPBDAT,    0x56000014

 .text  

 .global _start  

 _start:  

     bl close_watch_dog  

     bl set_clock  

     bl init_sdram  

     ldr sp, =0x32000000  

     ldr lr, =loop_halt          @设置返回地址  

 loop_halt:  

     b loop_halt  

 close_watch_dog:  

     ldr r0, =WTCON  

     mov r1, #  

     str r1, [r0]  

     mov pc, lr  

 set_clock:  

     ldr r0, =CLKDIVN  

     mov r1, #0x05   // FCLK:HCLK:PCLK=::, HDIVN=,PDIVN=  

     str r1, [r0]  

     mrc p15, , r1, c1, c0,         /* 读出控制寄存器*/   

     orr r1, r1, #0xc0000000          /* 设置为“asynchronous bus mode?*/  

     mcr p15, , r1, c1, c0,         /* 写入控制寄存器*/  

     ldr r0, =MPLLCON  

     ldr r1, =((0x5c<<)|(0x01<<)|(0x01))  //MPLL_400MHZ    

     str r1, [r0]  

     /* 启动ICACHE */  

     mrc p15, , r0, c1, c0,    @ read control reg  

     orr r0, r0, #(<<)  

     mcr p15, , r0, c1, c0,    @ write it back  

     mov pc, lr  

 init_sdram:  

     /*gpiob */

 ldr r0, =GPBCON  

     mov r1, #0x00

 bic r1,r1, #((<<) | (<<))

 orr r1,r1, #((<<) | (<<))

     str r1, [r0]

 ldr r0, =GPBDAT  

     mov r1, #0x00

 bic r1,r1, #(<<)

     str r1, [r0]  

     /* 如果程序在sdram里,那么就不初始化了 */  

     adr r0, _start  

     ldr r1, =0x30000000   

     cmp r0, r1  

     beq 2f  

     mov r0,#BWSCON  

     adrl r1,mem_cfg_val  

                             @STr [r1],[r0],#  

     mov r4, #  

 :    

     ldr r3, [r1], #  

     str r3, [r0], #  

     add r4, #  

     cmp r4, #  

     bne 1b  

 :    

 ldr r0, =GPBDAT  

     mov r1, #0x00

 bic r1,r1, #(<<)

     str r1, [r0]  

     b .   @stop here

     mov pc, lr  

 .align   

 mem_cfg_val:  

     @ 存储控制器13个寄存器的设置值  

     .long   0x22011110      @ BWSCON  

     .long   0x00000700      @ BANKCON0  

     .long   0x00000700      @ BANKCON1  

     .long   0x00000700      @ BANKCON2  

     .long   0x00000700      @ BANKCON3    

     .long   0x00000700      @ BANKCON4  

     .long   0x00000700      @ BANKCON5  

     .long   0x00018005      @ BANKCON6  

     .long   0x00018005      @ BANKCON7  

     .long   0x008C07A3      @ rEFrESH  

     .long   0x000000B1      @ BANKSIZE  

     .long   0x00000030      @ MrSrB6  

     .long   0x00000030      @ MrSrB7 

Jlink下载u-boot的更多相关文章

  1. Kinetis Design Studio 下使用J-Link下载程序

    1.安装J-Link驱动. 在KDS安装目录下已自带J-Link驱动,进入以下目录(以我的为例): C:\Freescale\KDS_1.1.1\segger\USBDriver 将看到CDC.x64 ...

  2. 图解Stm32使用jlink下载程序时jtag接口(SW和JTAG模式)的简化方法

    转自: http://www.it165.net/embed/html/201308/2332.html 用过stm32的人都知道stm32有两种常用下载程序的方法,用串口和jlink.串口下载方法和 ...

  3. 痞子衡嵌入式:MCUXpresso IDE下使用J-Link下载算法在Flash调试注意事项(i.MXRT500为例)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下使用J-Link下载算法在Flash调试注意事项. 痞子衡前段时间写过一篇小文<为i.MXRT设计更 ...

  4. JLINK下载出现问题

    JLINK 下载报错: RAM CHECK FAILED 说法一: 有一种说法是版本的问题 http://tieba.baidu.com/p/1902940329?red_tag=d180765763 ...

  5. 龙邱STM32单片机用J-LINK下载无法被识别的解决方法

    问题如下: 按照正常步骤使用keil5给龙邱的stm32下载程序,SWD下载方式提示no cortex-m sw device found,JTAG方式提示no cortex-m device fou ...

  6. Jlink下载问题

    在使用Jlink SWD模式进行下载的时候遇到了无法下载的问题. SWD模式下,共有4跟线,VCC.GND.SWCLK.SWDIO JTAG标准接口如下图所示: 一般情况下,目标板卡的 debug V ...

  7. java代码自动下载Spring Boot用户手册

    本示例演示Spring Boot 1.5.9.RELEASE版本的用户手册下载 pom.xml <?xml version="1.0" encoding="UTF- ...

  8. 【转】【JLINK下载失败,STLINK下载失败万能解决方案】JLINK和STLINK都无法下载时的解决办法,此时芯片并没有报废

    很多时候都会认为这个板子无法下载了,其实不是的,有解决办法. 原因如下: 由于客户设置的晶振频率和PLL配置错误时,就会出现这种问题,下载一次程序锁住一次板子,搞的人痛不欲生. 还有错误的外设配置,S ...

  9. MDK5使用Jlink下载显示 no cortex m sw divice 解决办法

    问题: (1)下面界面中找不到设备 (2)下载程序的时候提示" no cortex m sw divice " 然后是"target dll has been cance ...

随机推荐

  1. 点按钮ajax get方法修改0或1状态封装成函数

    最终效果 列表页面表格里点击按钮修改状态 按钮样式要引入bootstrap才可以用 本文件用的是laravel框架环境 larave路由里 Route::get('category/changesta ...

  2. keil5 mdk调用外部编辑器notepad++、sublime3、VSCode总结

    1.打开keil主界面,点击菜单栏Tools菜单,选择如下图所示的选项. 2.点击如下图所示的菜单上红笔标注的地方,给这个工具命名,如notepad++.sublime3.vscode等,如下图, 并 ...

  3. HyperLedger Fabric 1.4 区块链应用场景(3.1)

    比特币是区块链应用最早的场景,随着比特币安全稳定运行多年以后,数字货币的场景应用遍地开花,各种山寨币泛滥,通过ICO(Initial Coin Offering 首次币发行)就能融到大量资金,上市后的 ...

  4. hdu 1394 Minimum Inversion Number(线段树)

    参考:http://blog.sina.com.cn/s/blog_691ce2b70101ldmm.html https://blog.csdn.net/wiking__acm/article/de ...

  5. ubuntu配置机器学习环境(一) ubuntu安装

    第一部分:Ubuntu14.04安装 Step :安装Ubuntu Step 1.1:准备安装U盘 首先到官网下载Ubuntu的镜像,我使用的是Ubuntu 14.04.3的ISO. 然后使用Ultr ...

  6. Android面试收集录 2D绘图与动画技术

    1.如何在Android应用程序的窗口上绘制图形? 继承View 实现View中的onDraw()方法 2.如何绘制圆,空心椭圆? canvas.drawArc或canvas.drawCircle方法 ...

  7. React16版本的新特性

    React16版本更新的新特性 2018年05月03日 21:27:56 阅读数:188 1.render方法的返回值类型:New render return types 之前的方式: class A ...

  8. linux-clone-ip处理办法

    vim /etc/udev/rules.d/70-persistent-net.rules 步骤1:#将eth0相关的文件给删除 步骤2:#vi /etc/sysconfig/network-scri ...

  9. 快速平方根算法的javascript实现

    前几天看见了一个来自雷神之槌的平方根源码,原理多方有介绍,不赘述. 源码是c语言写的,我思考后发现这样的算法在javascript中也是可以完成的. function InvSqrt(x){ var ...

  10. 汇编指令MOVSX与MOVZX

    MOVSX 操作数A ,操作数B MOVZX 操作数A ,操作数B 相同点:操作数B 空间必须小于 操作数A 1.格式与MOV基本相同 2.能完成小存储单元向大存储单元的数据传送 比如 movsx e ...