当前位置:  技术问答>linux和unix

请教编译问题。

    来源: 互联网  发布时间:2015-11-10

    本文导语:  我的Makefile: CC = arm-linux-gcc  AR = arm-linux-ar LD = arm-linux-ld KERNELDIR = /XXXX/XXX/XXX/linux-2.4.X include $(KERNELDIR)/.config CFLAGS = -mbig-endian -D__KERNEL__ -DMODULE -I$(KERNELDIR)/include -O -Wall #ifdef CONFIG_SMP #CFLAGS += -D__SMP__ -DS...

我的Makefile:

CC = arm-linux-gcc 
AR = arm-linux-ar
LD = arm-linux-ld

KERNELDIR = /XXXX/XXX/XXX/linux-2.4.X

include $(KERNELDIR)/.config

CFLAGS = -mbig-endian -D__KERNEL__ -DMODULE -I$(KERNELDIR)/include -O -Wall

#ifdef CONFIG_SMP
#CFLAGS += -D__SMP__ -DSMP
#endif

all:AAA.o

AAA.o:BBB.o CCC.o DDD.o EEE.o 
$(LD) -r $^ -o $@

clean:
rm -rf *.o
touch *.c *.h

为什么连接时报错:
arm-linux-ld: BBB.o: compiled for a big endian system and target is little endian
File in wrong format: failed to merge target specific data of file BBB.o

如何把target变为big endian 。

|
说的是你的文件格式的问题
ig-Endian 和 Little-Endian 字节排序
字节排序  含义
Big-Endian  一个Word中的高位的Byte放在内存中这个Word区域的低地址处。
Little-Endian  一个Word中的低位的Byte放在内存中这个Word区域的低地址处。

必须注意的是:一个Word的长度是16位,一个Byte的长度是8位。如果一个数超过一个Word的长度,必须先按Word分成若干部分,然后每一部分(即每个Word内部)按Big-Endian或者Little-Endian的不同操作来处理字节。
一个例子:
如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为
                big-endian     little-endian
0x0000     0x12              0xcd
0x0001     0x34              0xab
0x0002     0xab              0x34
0x0003     0xcd              0x12
(注意:0xab换算成2进制是10101011,是个8位的数。)

-----------
疑问:为什么要以一个Word为基础单位来分割而不是一个DoubleWord或者Byte?究竟就是这么定义的还是跟具体的CPU有关,跟具体的模式(比如说16位模式、32位模式、64位模式的LE和BE定义会不同)有关?我实在是不清楚,望知道的大侠不吝指点,也希望有这方面资料(文章、代码)的朋友贴一些上来。
 posted on 2005-02-22 23:59 乾坤一笑

|
同意alaiyeshi(七宝树八宝饭)


因为你编译选项指定是BigEndian (CFLAGS = -mbig-endian), 而一般的库是LittleEndian的, 所以链接(arm-linux-ld)的时候会报不匹配. 

解决方法: 
1, 要么编译时候指定LittleEndian;
2, 要么链接的时候通过不同的搜索路径选择现成的BigEndian 的库,或者重新编译成BigEndian 的库;

|
难道是
$(LD) -r $(CFLAGS) $^ -o $@

|
AAA.o:BBB.o CCC.o DDD.o EEE.o 
$(LD) -r $^ -o $@

你把上面的$(LD)那行加上-mbig-endian 试一下,不太确定。

|
所谓word是指机器的字长,未必就一定是16位,现在通常都是32位了。

    
 
 

您可能感兴趣的文章:

  • 请教:JSP编译器编译成字节码,跟别的编译器编译出来的有什么不同呢?
  • 请教Linux下pgadmin3-1.0.2的编译和安装!!高分请教!
  • 用Jdk编译时出现提示要加 -deprecation 再编译,请教??
  • gcc 编译的问题,请教各位
  • 请教一个GCC编译选项
  • 万能的CSDN啊,100分请教高手一个编译内核传参的问题!
  • 请教:有没有把java编译好的.java和.class文件编译成各个平台下的可执行文件??.exe?着急着急
  • 请教:嵌入式Linux交叉编译工具----版本选择的问题
  • 请教:编译的时候为什么说不认识WindowAdapter?
  • 请教关于用c编译出来的.a文件和用c++编译出来的.a文件的互用问题
  • 新手请教linux下的c语言编译!
  • 请教一个gcc静态编译的问题。
  • 请教:如何在一个节点上利用另一个节点上的编译器呢?
  • 关于QT编译的问题,请教前辈
  • 请教交叉编译
  • 在AIX 5.3 上编译程序的问题,请教各位大虾
  • 请教如何在solaris 8上安装c编译器
  • 请教如何能把 gcc编译的所有信息存放到一个文件里
  • 请教,刚下载了一个U_boot 1.2.0源码,能直接编译?
  • 请教各位大虾,怎么自己编译一个精简的Linux出来用?
  • 请教本地硬盘安装问题请教本地硬盘安装问题
  • 请教,请教,这个问题是为什么????
  • ■请教■请教redhat最基本的问题!
  • 请教一个 shell 问题,我用下面这个 shell 语句总是失败,请教
  • 高分请教,各位大侠,请教一个问题,理论高手请进??谢谢
  • 请教象我这样的硬盘应如何安装Linux,我昨天试装了,但有问题。(老问题了,也看了前面的帖子,但还是来请教,请多指教)
  • 请教一个函数入口处的汇编问题(压栈问题)
  • 请教!出现这个提示是什么原因..是模块版本问题,还是其他问题..http://220.114.102.28/xitong/ProductShow.asp?ArticleID=82
  • 请教两个小问题:一个cgywin下使用vi的问题,另一个socket的问题
  • 请教一个opengl的问题
  • 请教两个redhat9问题
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 各位大虾,请教装了REDHAT9操作系统后,启动时无法引导到LINUX,请教该如何解决啊
  • 请教,请教,,,一定要看!!一定要看!!
  • 请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • :请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • 请教这种循环的执行过程
  • 请教如何在指定目录下查找包含指定文字的文件
  • 请教局域网中如何通过ip地址得到主机名
  • 请教,如何用虚拟订机安装liux
  • 【请教】LINUX 下SNMP的MIB开发
  • 请教两个shell
  • 请教高手:如何用gnome/gtk编写托盘程序
  • 菜鸟请教Linux
  • 请教semop()函数的用法、含义
  • 请教个,关于C编译器参数CFLAGS的问题(真诚请教,分不够了全部送出)
  • 请问如何在Redhat7.1下安装Ftp服务,如何开启Ftp帐号????请教!!!急急急急急急
  • Think in java 问题。(请教)
  • 请教下我的eth0为什么设置后重启会失败?
  • 数据库 iis7站长之家
  • 请教高手AIX中怎么删除行尾的字符^M
  • 请教java中如何实现vb中chr() ,asc() 类似的功能?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3