arm-linux交叉编译ACE

2019-07-13 04:45发布

 ACE应用于主站数据采集核心的开发已告一段落了。现在打算涉足嵌入式linux应用程序的设计。俗话说“工欲善其事,必先利其器”,ACE支持arm系列的嵌入式系统,当然首先折腾他了,后期还打算整整apache的运行时库apr。嵌入式系统的仿真平台采用skyeye,在这样一个平台里我已经实现了nfs mount 宿主机目录。测试交叉编译后的程序十分方便。      网上搜到一篇《机电之家 嵌入式Linux系统攻略--ACE程序移植过程详细解析》交叉编译工具是Moxa tool chain for DA66x,写的满详细,主要参照它就完成了arm-linux的交叉编译。详细过程如下: 1.解压ace源代码到/root 2.设置环境变量ACE_ROOT如:export ACE_ROOT=”/root/ACE_wrappers” 3.将$ACE_ROOT/ace/config-linux.h复制成$ACE_ROOT/ace/config.h 4.$ACE_ROOT/include/makeinclude/platform_linux.GNU复制成 $ACE_ROOT/include/makeinclude/platform_macros.GNU并修改platform_macros.GNU文件,添加编译器名称: CC = arm-linux-gcc CXX =arm-linux-g++ CXX_FOR_VERSION_TEST ?= $(CXX) 删除: ifeq ($(insure),1) CC = insure CXX = insure else CC ?= gcc CXX ?= g++ endif   5.修改$ACE_ROOT/include/makeinclude/platform_g++_common.GNU文件,注释第134行:LDFLAGS += -Wl,-E (ACE6.0) 6.gperf目录下的测试程序无法编译,因为这些测试程序要用$(ACE_ROOT)/apps/gperf/src/目录下的相关源代码生成的gperf程序去完成下一步动作,而这个程序是利用交叉编译器生成的,不能在PC上运行。因此在GNUmakefile里面的all:后面,我们要删除cppinset adainset cinset iinset iinset2 m3inset pinset preinset taoinset tinset这些目标对象。 7.进入$ACE_ROOT,直接输入make 8. 将$ACE_ROOT/lib/arm下的libACE.so.6.0.0建立链接libACE.so,将链接文件拷贝到LD_LIBRARY_PATH指定的目录中        交叉编译ACE顺利完成后,下面我们写个简单的测试程序以验证交叉编译后的ACE是否能正常使用,测试可以分2步,第一步测试能否正常编译通过这个测试程序,第二步测试基于ACE的程序能否在skyeye仿真系统里正常运行。下面开始第一步测试:  #include "time.h"
#include "ace/Log_Msg.h"
#include "spawn.h"
typedef struct {
    float a;
    float b;
  } substruct;
 struct mystruct{
    int i;
  int jj;
    substruct r;
  } ; void foo (void)
{
  ACE_TRACE (ACE_TEXT ("foo"));
  ACE_DEBUG ((LM_INFO, ACE_TEXT ("%IHowdy Pardner ")));
}
int ACE_TMAIN(int argc,int argv[])
{
   struct mystruct ddd;
   ddd.jj =111;
   struct timespec _TimeSpec;
   posix_spawnattr_t _Posix;
   _TimeSpec.tv_sec = 111;
   _Posix.__flags =1111;
  ACE_TRACE(ACE_TEXT ("main"));
  foo(); 
  ACE_DEBUG ((LM_INFO, ACE_TEXT ("%IGoodnight ")));
}          将上面的代码拷贝保存为ace_test.cpp,然后使用阿arm-linux-g++交叉编译。ACE的头文件使用-I标明,库文件路径使用-L标明,ace_test需要的动态库使用-l标明:[root@localhost nfsroot]# arm-linux-g++ -o ace_test -I/usr/local/include -L/usr/local/lib -lACE ace_test.cpp如果编译提示“ld: skipping incompatible /usr/local/lib/libACE.so when searching for -lACE”说明ACE编译工具指定错误,编译出来的库不是arm-linux能识别的。无出错信息则表示第一步测试通过。          第二步测试中,在skyeye里挂载宿主机的nfsroot目录,并链接其中的lib目录:
mount -o nolock 192.168.1.1:/nfsroot /home
ln -s /home/lib /lib 这样就可以在skyeye里执行刚刚宿主机里编译的ace_test了。如果提示缺失动态库请在/usr/local/arm/3.4.1/arm-linux/lib拷贝到宿主机的nfsroot/lib下。我一直加了: libm.so.6            libACE.so            librt-2.3.2.so
libdl.so             libdl.so.2           libm-2.3.2.so
librt.so.1           libm.so              libpthread-0.10.so
libgcc_s.so.1        libstdc++.so.6.0.1   libstdc++.so
ld-linux.so.2        libACE.so.6.0.0      libdl-2.3.2.so
libc.so.6            libgcc_s.so          libpthread.so.0
libstdc++.so.6       libACE.so.6.0.0.bak  libc-2.3.2.so
librt.so             ld-2.3.2.so
最后出现了运行结果: arm-linux交叉编译ACE - yu_hongchang - 中原大鱼的博客  第二步测试完毕,ACE在嵌入式linux里成功运行了!       再看看lib目录大小总计近30M了,乖乖赶快减肥。当然使用arm-linux-strip。瘦身后总大小在4M左右,放在ramdisk里还会使用gzip压缩一次,大小就变成了2M多了。可以满足实际要求了!

纪录下另外一种编译ACE的方法,只编译ACE动态库转自:http://hi.baidu.com/%BD%DB%D7%D3%CF%E3%B3%A6/blog/item/423cd3c3a9d983ba8226acb9.html 1. 创建环境变量 
export ACE_ROOT=/root/ACE_wrappers 
2. 生成makefile文件 
#cd /root/ACE_wrappers/ace 
#../MPC/mpc.pl -type make -include ../bin/MakeProjectCreator/config ace.mpc 
完了之后会生成Makefile.ACE 
3. config.h文件 
#ln -s config-linux.h config.h 
如果要使用epoll,需要在config.h中增加宏定义 
#define ACE_HAS_EVENT_POLL 
或者修改mpc文件重新生成makefile文件也可以。 
4.编译 
#make -f Makefile.ACE 
----------------------------如果是交叉编译ACE------------------------------- 编译的过程和前一篇linux下编译ACE相同, 不过要对ace.mpc文件稍加修改 
//**********************
verbatim(make,local){
CXX=arm-linux-g++
AR=arm-linux-ar
}
//**********************
添加星号线之间的部分就可以。。也可以不修改mpc文件,直接 
make -f Makefile.ACE CXX=arm-linux-g++