一个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启动
使用的软件根据你使用的 *** 作系统运旅腔不同而不同。大体上来说,流程都差不多,
1) 首先 ARM 上面 boot strap mode 需要设定好,一般来说,都要设定成 boot from internal ROM,如果你的 ARM 没有这个选项,那麽下面的都不用看了。
2) 找到跟旁衫你使用的 *** 作系统相关的 boot loader。
3) ARM 开机以串口连结上 PC。
4) 选择下载 boot loader
5) 看你的 internal boot ROM 的选项,有些会下载完毕後,直接跳到 boot loader 重新开机。
6) 接下来就是 boot loader 开机。跟着指令,下载你的 *** 作系统烧录到镇顷 Flash 里面。
7) ARM 关机,然後把boot strap mode设定回 Flash 开机。
当然,有很多 ARM 的 boot strap mode 的设定不同,有些是 boot from USB,boot from SD 等等,不一而足,但是跟你要从串口烧机无关,就不多说了。
如果是裸机的程序,那么可以用jtag转接板连接到电脑上,用ads来调试和仿真。如果是boot loader一般也是jtag转接板连到电脑渗兄,通过H-JTAG烧写nor flash或者nand flash,把boot loader烧进去。由于 *** 作系统和根文件系统比较大,一般都基于boot loader,通过网口或者usb等高纳桐速传输口烧写至nand flash。找份教程对照着学一洞喊坦下,方向性搞懂了,这些都很简单了。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)