arm 裸板程序编译过程
2015-04-10 20:52
253 查看
看过编译原理的人都知道我们一句简单的arm-linux-gcc 到达做了哪些工作。他并不是简单的把我们的原文件编译成我们可执行的二进制文件,在这个过程中他其实至少做了两部工作。“编译”和链接“当然这其中包含了很多关于编译原理的至少,由于本人才疏学浅说以也只能够简单的把他说成编译和链接了。如果需要跟深入的理解请查找相关”编译原理的书籍吧“
这里我们先介绍一下常用的GCC命令.
1.arm-linux-gcc -v
查看gcc 版本号
2.arm-linux-nm
查看一个.o文件所需要的库。
3.arm-linux-ld
链接命令
3.arm-linux-gcc 编译命令
4 arm-linux-objdump
-h test 查看符号
-d 反汇编
5 arm-linux-as
ls.S -o ls.o 将汇编原文件编译成.o文件
6 arm-linux-objcopy
-I elf32-littlearm -O binary test test.bin 去掉二进制文件elf头。
现在我们来写一个arm裸板的LED闪灯程序 非常简单的。
源代码 led_test.c
void main()
{
int i=0;
volatile long *GPKCON0 = 0x7F008800;
volatile long *GPKDAT = 0x7F008808;
volatile long *GPKPUD = 0x7F00880C;
*GPKCON0 &= ~(0XFFFF <<16);
*GPKCON0 |= (0X1111 <<16);
while(1){
*GPKDAT &= ~(0XF <<4);
i=0xfffff;
while(i--)
;
*GPKDAT |= (0XF <<4);
i=0xfffff;
while(i--)
;
}
}
每隔大概3秒钟的时间LED闪烁一次。非常简单的一个程序。这里没有使用定时器啊 什么的知识简单的做循环来延时。注意 关于LED 的GPIO相关寄存器地址根据你自己的实际情况来。
编译过程
1 编译
arm-linux-gcc -c
-march=armv4 test.c -o test.o
2.链接
arm-linux-ld
-Ttext=50008000 test.o -o test //注意这个链接地址不要链接到你arm开发板不能提供的内存地址。
3 去掉elf头信息
arm-linux-objcopy
-I elf32-little -O binary test test.bin
这样 我们需要的LED裸板闪灯代码就生成了。
现在我们通过任何你能够使用的工具 把我们生成的 bin文件少些到ram的 0x50008000 这个地址。
然后让在bootloader中执行
bootm 0x50008000 看到你的灯闪木有。
注意 arm-linux-gcc 版本。由于arm-linux-gcc-4.x.x
不支持arm-linux-ld
-Ttext 这个参数还是其他的,具体没深入研究。会出错。
只能使用arm-linux-gcc 3.x.x的版本
这一点一定要注意。我今天就是因为这个原因郁闷了半天。如果有谁知道4.x.x版本的具体原因请告诉我并万分感谢
这里我们先介绍一下常用的GCC命令.
1.arm-linux-gcc -v
查看gcc 版本号
2.arm-linux-nm
查看一个.o文件所需要的库。
3.arm-linux-ld
链接命令
3.arm-linux-gcc 编译命令
4 arm-linux-objdump
-h test 查看符号
-d 反汇编
5 arm-linux-as
ls.S -o ls.o 将汇编原文件编译成.o文件
6 arm-linux-objcopy
-I elf32-littlearm -O binary test test.bin 去掉二进制文件elf头。
现在我们来写一个arm裸板的LED闪灯程序 非常简单的。
源代码 led_test.c
void main()
{
int i=0;
volatile long *GPKCON0 = 0x7F008800;
volatile long *GPKDAT = 0x7F008808;
volatile long *GPKPUD = 0x7F00880C;
*GPKCON0 &= ~(0XFFFF <<16);
*GPKCON0 |= (0X1111 <<16);
while(1){
*GPKDAT &= ~(0XF <<4);
i=0xfffff;
while(i--)
;
*GPKDAT |= (0XF <<4);
i=0xfffff;
while(i--)
;
}
}
每隔大概3秒钟的时间LED闪烁一次。非常简单的一个程序。这里没有使用定时器啊 什么的知识简单的做循环来延时。注意 关于LED 的GPIO相关寄存器地址根据你自己的实际情况来。
编译过程
1 编译
arm-linux-gcc -c
-march=armv4 test.c -o test.o
2.链接
arm-linux-ld
-Ttext=50008000 test.o -o test //注意这个链接地址不要链接到你arm开发板不能提供的内存地址。
3 去掉elf头信息
arm-linux-objcopy
-I elf32-little -O binary test test.bin
这样 我们需要的LED裸板闪灯代码就生成了。
现在我们通过任何你能够使用的工具 把我们生成的 bin文件少些到ram的 0x50008000 这个地址。
然后让在bootloader中执行
bootm 0x50008000 看到你的灯闪木有。
注意 arm-linux-gcc 版本。由于arm-linux-gcc-4.x.x
不支持arm-linux-ld
-Ttext 这个参数还是其他的,具体没深入研究。会出错。
只能使用arm-linux-gcc 3.x.x的版本
这一点一定要注意。我今天就是因为这个原因郁闷了半天。如果有谁知道4.x.x版本的具体原因请告诉我并万分感谢
相关文章推荐
- Linuxc编译和ARM程序编译过程详解
- ARM裸板程序的开发和编译(以点亮LED灯为例)
- qte for arm的编译过程
- 基于ARM 的嵌入式系统程序开发要点-(二)系统的初始化过程
- C程序编译过程
- gtk程序编译和链接过程
- C程序的编译过程
- 动态生成与编译(三)----写一个面向过程的程序
- c程序的编译过程
- (转)C程序的编译过程
- 【转】C++编译过程中"没有找到MFC80UD.DLL,因此这个程序未能启动.重新安装应用程序可能会修复此问题"? 的彻底解决
- GCC 编译c程序的方法及过程解析
- PC上配置编译MiniGUI v1.3.3和运行示例程序全过程
- 在VS2008中编译纯c/c++程序并由c#调用过程
- 在VS2008中编译纯c/c++程序并由c#调用过程
- 我的arm-gcc工具编译安装过程
- ARM编译程序参考
- C程序的编译过程
- C++编译过程中"没有找到MFC80UD.DLL,因此这个程序未能启动.重新安装应用程序可能会修复此问题"? 的彻底解决
- 结合"hello world"探讨gcc编译程序的过程