怎么给ARM11烧写裸机程序,需要先下载U-BOOT吗?还是什么都不需要,直接用J-Linker就可以下载?

怎么给ARM11烧写裸机程序,需要先下载U-BOOT吗?还是什么都不需要,直接用J-Linker就可以下载?,第1张

我的开发板 是这样的

1.烧写裸机程序

一个nand flash 一个 norflash

先用jlink下载Uboot到norflash

然后启动 用uboot更新uboot到 nandflash的方式 下载裸机程序

然后从nandflash启动

2.ADS用法 可以去网上查查 好多

3.(不使用ADS)建立裸机程序:必须自己实现几个东西

3.1初始化硬件(汇编):比如关闭看门狗啊 初始化栈指针(如果你要跑C的话) 之类

3.2MAKEFILE 中要制定连接地址 去_elf头

3.3实现你的C程序

比如简单的控制LED的裸机程序

crt0.S:

.text

.global _start

_start:

ldr r0, =0x53000000 @ WATCHDOG寄存器地址

mov r1, #0x0

str r1, [r0] @ 写入0,禁止WATCHDOG,否则CPU会不断重启

ldr sp, =1024*4 @ 设置堆栈,注意:不能大于4k, 因为现在可用的内存只有4K

@ nand flash中的代码在复位后会移到内部ram中,此ram只有4K

bl main@ 调用C程序中的main函数

halt_loop:

b halt_loop

MAKEFILE :

key_led.bin : crt0.S key_led.c

arm-linux-gcc -g -c -o crt0.o crt0.S

arm-linux-gcc -g -c -o key_led.o key_led.c

arm-linux-ld -Ttext 0x0000000 -g crt0.o key_led.o -o key_led_elf

arm-linux-objcopy -O binary -S key_led_elf key_led.bin

arm-linux-objdump -D -m arm key_led_elf >key_led.dis

clean:

rm -f key_led.dis key_led.bin key_led_elf *.o

C代码:

#define GPBCON (*(volatile unsigned long *)0x56000010)#define GPBDAT (*(volatile unsigned long *)0x56000014)

int main()

{

GPBCON = 0x00000400 // 设置GPB5为输出口, 位[11:10]=0b01

GPBDAT = 0x00000000 // GPB5输出0,LED1点亮

return 0}

执行make 生成.bin文件

然后下载到nandflash

从nand启动

uboot是个单线程裸机程序,进入死循环的话可以尝试用Ctrl+C退出

LZ说进入死等待,那么相必是uboot已经成功启动(串口有打印信息), 这样的话uboot启动后也就无非做以下几件事情:

1. tftp传内核

2. nfs传内核

3. 从nand读取内核

4. 从SD读取内核(这个一般还没有)

这样如果死在某个环节就要去检查相应的驱动或者硬件是否有问题了。

如果连串口信息也没有,程序死在某个hang的地方(b .),可能是内存没稳定或者是u-boot.bin拷到内存中的地址错了。

嵌入式系统上电,首先运行的的是uboot程序,uboot开始运行,首先就要对系统硬件进行相关的初始化,比如时钟,比如mmu,比如调试串口,在这个初始化过程中,基本不会出现程序跑飞,需要看门狗照顾的情况,所以,一般的做法就是关闭看门狗,避免喂狗的麻烦,等一切就绪后,正常运行时,再打开看门狗。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11264914.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存