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

那个ADS怎么用的?建立裸机程序步骤是什么?麻烦大侠们赐教啊!!!我是菜鸟... 那个ADS怎么用的?建立裸机程序步骤是什么?麻烦大侠们赐教啊!!!我是菜鸟 展开
 我来答
百度网友62d6b0d88
推荐于2016-10-01 · TA获得超过206个赞
知道小有建树答主
回答量:246
采纳率:100%
帮助的人:113万
展开全部
我的开发板 是这样的
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启动
zhoulinshijie
2013-03-08 · 超过40用户采纳过TA的回答
知道小有建树答主
回答量:210
采纳率:0%
帮助的人:98.2万
展开全部
可以使用jlink直接的下载调试的
追问
我有JLINK,怎么调试的呢?我用ADS写程序时,发现没有ARM11呢?怎么办呢?
追答
看看你的开发板的手册,应该有怎么连接的。连接好了就点击debug。具体的可以看看国嵌的培训视频或者其他的视频教程。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式