iar编写arm程序出错

iar编写arm程序出错,第1张

你得说具体点,在哪步提示的没有系统卷。

一般不是因为没有ntfs格式,在安装时只要有硬盘可以在安装过程中格式化为ntfs格式。

你说的问题可能是找不到硬盘了。可以把硬盘的电源接口以及与主板接口牢固一下试试。

我的开发板 是这样的

1烧写裸机程序

一个nand flash 一个 norflash

先用jlink下载Uboot到norflash

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

然后从nandflash启动

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

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

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

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

33实现你的C程序

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

crt0S:

text

global _start

_start:

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

mov r1, #0x0

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

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

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

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

halt_loop:

b halt_loop

MAKEFILE :

key_ledbin : crt0S key_ledc

arm-linux-gcc -g -c -o crt0o crt0S

arm-linux-gcc -g -c -o key_ledo key_ledc

arm-linux-ld -Ttext 0x0000000 -g crt0o key_ledo -o key_led_elf

arm-linux-objcopy -O binary -S key_led_elf key_ledbin

arm-linux-objdump -D -m arm key_led_elf > key_leddis

clean:

rm -f key_leddis key_ledbin 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启动

不改MAKEFILE文件,当然不能编译了,Linux的驱动就是这么搞的啊,没办法的,反正是批处理的,也就多花点时间嘛,你可以把一些不需要的驱动,选择不编译,这样就能加快速度了。给你个办法,在Windows虚拟机中安装交叉编译环境,你可以在Windows下编辑你的程序,Linux只起到编译的作用,这样,两个工作可以同时进行,有空你还可以上上网,这样你就不觉得时间长了。

一。从一数到十

COUNT EQU 0x30003100 ;定义变量COUNT的基地址 AREA Example1,CODE,READONLY;声明代码段Example1为只读 ENTRY ;标识程序入口

CODE32 ;声明32位ARM指令 START LDR R1,=COUNT ;将0X30003100赋给R1 MOV R0,#0 ;执行R0=0

STR R0,[R1] ;存储R0寄存器的数据到R1指向的存储单元 LOOP LDR R1,=COUNT ;将0X30003100赋给R1

LDR R0,[R1] ;将R1中的数值作为地址,取出此地址中的数据保存到R0中 ADD R0,R0,#1 ;执行R0=R0+1

CMP R0,#10 ;将R0与10进行比较

MOVHS R0,#0 ;若R0大于等于10,则R0=0

STR R0,[R1] ;存储R0寄存器的数据到R1指向的地址单元 B LOOP ;跳转到LOOP

END ;汇编文件结束

二,9的8次幂

X EQU 9 ;初始化X为9 n EQU 8 ;初始化N为8

AREA Example3,CODE,READONLY ;生明代码段Example3为只读 ENTRY ;标识程序入口路

CODE32 ;声明32位ARM指令

START LDR SP,=0x30003F00 ;把0x30003F00 赋给SP(R13) LDR R0,=X ;把9赋给R0 LDR R1,=n ;把8赋给R1

BL POW ;跳转到POW,并把下一条指令地址存入到R14中 HALT B HALT ;等待跳转

POW STMFD SP!,{R1-R12,LR} ;将R1-R12入栈,满递减堆栈 MOVS R2,R1 ;将R1赋给R2,并影响标志位 MOVEQ R0,#1 ;若Z=1,则R0=1

BEQ POW_END ;若Z=1,跳转到POW_END MOV R1,R0 ;将R0中值赋给R1 SUB R2,R2,#1 ;将R2-1的只赋给R2 POW_L1 BL DO_MUL ;跳转到DO-MUL,并把下一条指令地址存入R14中 SUBS R2,R2,#1 ;将R2-1的值赋给R2,并影响标志位 BNE POW_L1 ;若Z=0,跳转到POW_L1

POW_END LDMFD SP!,{R1-R12,PC} ;数据出栈,存入到R1-R12,PC中 DO_MUL MUL R0,R1,R0 ;把R1R0的值赋给R0 MOV PC,LR ;LR中的值赋给PC END ;汇编结束

三:从一一直加到一百

程序清单(一) C 语言实验参考程序

#define uint8 unsigned char ;定义一个无符号字符常量uint8 #define uint32 unsigned int ;定义一个无符号整型常量unint32

#define N 100 ;定义一个常量N=100(宏定义,100用N代替) uint32 sum; ;定义sum为无符号整型常量(声明一个unsigned int型的变量sum) void Main(void) ;主函数

{uint32 i; ;定义无符号整型常量i(声明一个unsigned int型的变量i) sum=0; ;sum初始值为0

for(i=0;i<=N;i++) ;i在N内自增加1(i从0开始,i<=N时循环成立) {sum+=i;} ;把sum+i赋给sum while(1); ;为真循环 }

程序清单(二) 简单的启动代码

IMPORT |Image$$RO$$Limit | ;R0输出段存储区域界线 IMPORT |Image$$RW$$Base | ;RW输出段运行时起始地址 IMPORT |Image$$ZI$$Base | ;ZI输出段运行时起始地址 IMPORT |Image$$ZI$$Limit | ;ZI输出段存储区域界线 IMPORT Main ;主函数

AREA Start,CODE,READONLY ;声明代码段start,为只读 ENTRY ;程序入口

CODE32 ;声明32位ARM指令 Reset LDR SP,=0x40003f00 ;将0x40003f00赋给SP

LDR R0,=|Image$$RO$$Limit| ;将R0输出段存储区域界线赋给R0 LDR R1,=|Image$$RW$$Base | ;将RW输出段运行时起始地址赋给R1 LDR R3,=|Image$$ZI$$Base | ;将ZI输出段运行时起始地址赋给R3 CMP R0,R1 ;比较R0和R1,相等Z=1,反之Z=0 BEQ LOOP1 ;若Z=1,则跳到LOOP1

LOOP0 CMP R1,R3 ;比较R1和R3,若R1<r3,c=0

LDRCC R2,[R0],#4 ;若C=0,读取R0地址单元内容并且存入R2,且R0=R0+4 STRCC R2,[R1],#4 ;若C=0,读取R2中的数据存入R1,且R1=R1+4 BCC LOOP0 ;若C=0,跳转到LOOP0

LOOP1 LDR R1,=|Image$$ZI$$Limit| ;将ZI输出段存储区域赋给R1 MOV R2,#0 ;把0赋给R2

LOOP2 CMP R3,R1 ;比较R1和R3,若R1<r3,c=0 strcc="" r2,[r3],#4="" ;若c="0,将R2中数据保存到内存单元R3中,且R3=R3+4" bcc="" loop2="" b="" main="" ;跳转到主程序="" end="" ;汇编结束=""

四、程序清单(一) C 语言调用汇编的参考程序

#define uint8 unsigned char ;定义一个无符号字符常量uint8 #define uint32 unsigned int ;定义一个无符号整型常量uint32

extern uint32 Add(uint32 x,uint32 y); //声明子程序Add为一个无符号整型常量,它为2个无符号整型常量x,y的和

uint32 sum; ;定义sum为无符号整型常量 void Main(void) ;无返回主程序

{sum=Add(555,168); ;sum等于555+168 while(1); ;为真循环 }

程序清单(二) 汇编加法函数程序

EXPORT Add ;声明子程序Add方便调用 AREA Start,CODE,READONLY ;声明代码段start,为只读 ENTRY ;程序入口

CODE32 ;声明32位ARM指令

Add ADD R0,R0,R1 ;将R0+R1值赋给R0 MOV PC,LR ;将LR值赋给PC

硬件平台:FS2410开发平台:MDK35程序源码:GPFCON EQU 0x56000050 ;Port F control

GPFDAT EQU 0x56000054 ;Port F data

GPFUP EQU 0x56000058 ;Pull-up control F

AREA myarea, CODE

ENTRY LDR r0, =0x5500

LDR r1, = GPFCON

STR r0,[r1] LDR r0, = 0x0

LDR r1, =GPFUP

STR r0,[r1]

start_while

LDR r0, = 0x0

LDR r1, =GPFDAT

STR r0,[r1] LDR r0, =0xffffloop1

SUBS r0,r0, #1

BNE loop1 LDR r0, = 0xF0

LDR r1, =GPFDAT

STR r0,[r1] LDR r0, =0xffff

loop2

SUBS r0,r0, #1

BNE loop2 B start_whilestop

B stop

END

这个很简单啊,

你打开你的开发板的原理图,对照扩展口,选择几个GPIO口,用对应的接口线引出来。再对照数据手册,找到相应的控制寄存器、上拉使能寄存器、数据寄存器,分别设置下,就可以驱动你的led啦。

比如说你接出来两根线,GPF0和GPF1,那就去数据手册找GPFCON、GPFUP、GPFDAT这三个寄存器,GPFCON中写入0x5(0101),即设置为输出。然后上啦禁止(GPFUP=0xff),再往GPFDAT中写0x2(GPF0为低电平,GPF1为高电平),就可以点亮你的led啦。

以上就是关于iar编写arm程序出错全部的内容,包括:iar编写arm程序出错、怎么给ARM11烧写裸机程序,需要先下载U-BOOT吗还是什么都不需要,直接用J-Linker就可以下载、怎么在linux下编译驱动程序我我按照别人写的LED启动程序,用交叉编译器arm-linux-gcc编译,总提示找不到等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/zz/9764828.html

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

发表评论

登录后才能评论

评论列表(0条)

保存