linux学习笔记-AREA.doc
文本预览下载声明
AREA
AREA 段名 属性,……
说明:AREA用于定义一个代码段、数据段或者特定属性的段。如
果段名以数字开头,那么该段名需用“|”字符括起来,如|7wolf|,
用C的编译器产生的代码一般也用“|”括起来。属性部分表示该代码
段/数据段的相关属性,多个属性可以用逗号“,”分隔。
常见属性如下:
?
DATA:定义数据段,默认为READWRITE。
?
CODE:定义代码段,默认为READONLY。
?
?
READONLY:表示本段为只读。
?
READWRITE:表示本段可读写。
?
ALIGN=表达式:对齐方式为2表达式次方,例如:表达式=3,则对
齐方式为8字节对齐。表达式的取值范围为0-31。
?
ARM汇编器所支持的伪指令
一个汇编语言程序至少要包含一个段,当程序太长时
,也可以将程序分为多个代码段和数据段。
使用示例:
AREA Init, CODE,READONLY
该伪指令定义一个代码段,段名为Init,属性为只读。
3-4-3 ARM汇编器所支持的伪指令
4. CODE16/CODE32
CODE16/CODE32
说明:CODE16伪操作指示编译器后面的代码为16位的Thumb指令
。CODE32伪操作指示编译器后面的代码为32位的ARM指令。
在使用ARM指令和Thumb指令混合编程的代码里,可用这两条
伪指令进行切换,但注意它们只通知编译器其后指令的类型,并
不能对处理器进行状态的切换(涉及ARM状态的切换需使用BX指令
。)
3-4-3 ARM汇编器所支持的伪指令
5. ENTRY
ENTRY
说明:ENTRY用于指定汇编程序的入口。在一个完整的汇编程序
中至少要有一个ENTRY,程序中也可以有多个,此时,程序的真正
入口点可在链接时指定,但在一个源文件里最多只能有一个ENTRY
或者没有ENTRY。
使用示例:
AREA Init, CODE, READONLY
ENTRY ;指定应用程序的入口点
……
3-4-3 ARM汇编器所支持的伪指令
6. END
END
说明:“END”告诉编译器已经到了源程序的结尾。
二:一直不理解这个GPBDAT『10:0』是什么意思。
原来GPB0共有10个GPBCON,所以10:0,代表10个当中的任意一个。例如GPB3就是对GPBDAT的第三位进行操作。
int a;
int *p;
p=a;//取a的地址。
令p=(int*)0x5600050 ,即a的地址也就是0其中对0了一个强制转化.(1)
*p=a;(2)
由(1)(2)得出。
*(int*0=a;
a变量变化。a地址不变,地址还是0所以a变化,就是0址上的数据发生变化。
#define a *0x12 a变量的变化就是地址0x12上面的数据变化。a的地址就是0x12。
对数据位的操作。
Bit 7 6
1
表示输出。以前老是以为弄反。如果gpb3设置为imput 则 二进制0 0 化为十进制为0 则36 就完成了对[7 6] 设置为00 的操作。
按位的操作。 清零 a=a(~(14))
a=(~(14))
置1 a|=(14),
1.Makefiles上面 变量的定义才有等号。 依赖于目标文件之间是冒号。
2.linux上 伪指令的.text代表代码段。
3.global为程序定义一个全局的变量。
4.src :=$(shell ls *.c)
结果为1.c 2.c
#define vf 0*p = vf
For(;i13 ;i++)
P[i] = mem_cfg[i]
Mem_cfg[]是一个数组。意思是把数组里面的数据放到地址0面去。
5.汇编和c语言的参数是用r0.r1,r2来传递的。这一点很重要,但是容易忘记与忽略.
假设汇编上r0 传来的是0地址。
Void(unsigned char *p) *p意思为*p指向0地址。
Val =*p;
*p = 0x1234; 即0地址的内容发生了变化。
假设传来的为0这个数。
Void(int p)
则p = 0;
另一个指针的用法。Int *p = (int *) 0 次地方加了一个强制转换。 指针变量p指向0地址, ×p的变化带边0地址内容的变化。 这里的*p是指向的数。留意下×p指向变量的用法。
Int *p = start start = 5;
void copy_code_to_sdram(unsigned char *src, u
显示全部