Qt交叉编译工具建立 中篇
创始人
2024-08-01 14:40:50
0

继续上面的内容继续讲 Qt交叉编译工具建立 上篇 ,主要介绍了Qt/Embedded 的交叉编译,建立本机Qtopia 虚拟平台这两个方面介绍的!

一、Qt/Embedded的交叉编译
 
   要将我们写好的程序发布到开发板上,我们需要对Qt/Embedded 重新编译,与前面在宿主机上编译类似,步骤如下:

1. Build Qt/Embedded

  1. tar –xzvf qt-embedded-2.3.10-free.tar.gz  
  2. mv  qt-2.3.10  
  3. qt-2.3.10-target  
  4. export TMAKEDIR=$PWD/tmake-1.13  
  5. export QT2DIR=$PWD/qt-2.3.2  
  6. export QTEDIR=$PWD/qt-2.3.10-target  
  7. cd $QTEDIR  
  8. export TMAKEPATH=$TMAKEDIR/lib/qws/linux-arm-g++  
  9. export QTDIR=$QTEDIR  
  10. export PATH=$QTDIR/bin:$PATH  
  11. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  12. make  clean  
  13. ./configure -xplatform linux-arm-g++ -no-xft -no-qvfb -depths 4,8,16,32  
  14. make 

这步完成后,我们会在/$QTEDIR/lib/目录下面看到libqte.so libqte.so.2 libqte.so.2.3 libqte.so.2.3.10 这四个文件,我们可以使用file 命令来查看这个库文件是否是我们需要的在开发板上跑的库。

  1. file libqte.so.2.3.10  
  2. libqte.so.2.3.10: ELF 32-bit LSB shared object, ARM, version 1 (ARM), stripped 

有了这个库以后我们就可以把它拷贝到我们的开发板中相应的库目录下面,这里我们选择了开发板上的/usr/lib 目录,将/$QTEDIR/lib/下的libqte.so*复制到/usr/lib 目录下。

首先要建立宿主机和开发板的通讯,假设本机的ip 地址为192.168.0.56 并且/root/share 为共享文件夹。

  1. cp –arf /$QTEDIR/lib/libqte.so*  /root/share  
  2. 启动minicom  
  3. mount –t nfs –o nolock 192.168.0.56:/root/share /mnt/nfs将文件复制到开发板上  
  4. cp –arf /mnt/nfs/libqte.so* /usr/lib 

 2. 修改tmake 配置文件

  1. vi $ TMAKEDIR/lib/qws/linux-arm-g++/tmake.conf  
  2. 将其中“TMAKE_LINK= arm-linux-gcc”  
  3. “TMAKE_LINK_SHLIB= arm-linux-gcc”  
  4. 修改为:“TMAKE_LINK= arm-linux-g++”  
  5. “TMAKE_LINK_SHLIB= arm-linux-g++” 

 3.生成可执行文件
 
 这里我们采用了Qt/Embedded自带的一个demo,它在/$QTEDIR/examples/progressbar目录下,这个目录包括下面几个文件: main.cpp、Makefile.in 、progressbar.h 、

Makefile、progressbar.cpp、progressbar.pro,如果已经有了progressbar 的执行文件,可以使用make clean删除。

  1. progen –t app.t –o progressbar.pro  
  2. echo $TMAKEPATH 

查看返回的结果的结尾字符是否是“……/qws/linux-arm-g++”,如果不是的话需要在命令行中重新设置TMAKEPATH

export TMAKEPATH=/tmake 的安装路径(如$TMAKEDIR)/lib/qws/linux-arm-g++

此外还要使QTDIR指向Qt/Embedded 的安装路径,如:

export QTDIR=$QTEDIR 或者直接指定路径

  1. export QTDIR=……/qt-2.3.10-target 

完成了上面的环境变量的设置,并用echo 命令检查无误以后,就可以使用tmake 工具来生成我们需要的makefile 文件,在命令行中输入如下命令:

  1. tmake –o makefile progressbar.pro  
  2. make 

如果没出现错误的话就可以在当前目录下找到progressbar这个可执行文件,它就是在我们开发板上的相应目录中运行“./progressbar -qws”就可以运行程序了。
 
 注: (1)如果执行命令

  1. [/mnt/nfs]./progressbar -qws  
  2. ./progressbar: error while loading shared libraries: libstdc++.so.6: cannot open shared object file: No such file or direy 

我的解决办法是从编译器目录下查找,并拷贝到开发板/usr/lib/中

  
即拷贝/usr/local/arm/3.4.1/arm-linux/lib/libstdc++.so*  到开发板/usr/lib/中

(2).[/mnt/nfs]./progressbar –qws

  1. /progressbar: error while loading shared libraries: libgcc_s.so.1: cannot open shared object file: No such fy 

方法同上

二、建立本机Qtopia 虚拟平台
 
软件:Redhat Linux9.0 for PC + minicom + Embeded Linux for 2410

  1. tmake-1.13.tar.gz qtopia-free-source-2.1.1.tar.bz2 qt-embedded-2.3.10-free.tar.gz qt-x11-2.3.2.tar.gz 

将本次实验所需的四个文件拷贝到/root/qtopia 目录下,我们以下的实验都是在这个目录下进行的。

宿主机上建立虚拟的Qtopia 环境需要以下几个步骤:

1. 解压缩安装文件:

  1. tar jxvf qtopia-free-source-2.1.1.tar.bz2  
  2.  mv qtopia-2.1.1  qtopia-2.1.1-target  
  3.  tar xzf tmake-1.13.tar.gz  
  4.  tar xzf qt-x11-2.3.2.tar.gz  
  5.  tar xzf qt-embedded-2.3.10-free.tar.gz  
  6.  mv qt-2.3.10  qt-2.3.10-target  
  7.  export QPEDIR=$PWD/qtopia-2.1.1-target  
  8.  export TMAKEDIR=$PWD/tmake-1.13  
  9. export QT2DIR=$PWD/qt-2.3.2  
  10.  export QTEDIR=$PWD/qt-2.3.10-target 

 2. Build Qt/X11: 

  1. cd $QT2DIR  
  2. export TMAKEPATH=$TMAKEDIR/lib/linux-g++  
  3. export QTDIR=$QT2DIR  
  4. export PATH=$QTDIR/bin:$PATH  
  5. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  6. ./configure -no-xft  
  7. make  
  8. mkdir $QTEDIR/bin  
  9. cp bin/uic $QTEDIR/bin/ 

3. Build Qvfb:

  1. export TMAKEPATH=$TMAKEDIR/lib/linux-g++  
  2. export QTDIR=$QT2DIR  
  3. export PATH=$QTDIR/bin:$PATH:$TMAKEDIR/bin  
  4. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  5. cd $QTEDIR/tools/qvfb  
  6. tmake -o Makefile qvfb.pro  
  7. make  
  8. mv qvfb $QTEDIR/bin/ 

4.Build libqte:

  1. cd $QTEDIR  
  2. export TMAKEPATH=$TMAKEDIR/lib/qws/linux-x86-g++  
  3. export QTDIR=$QTEDIR  
  4. export PATH=$QTDIR/bin:$PATH  
  5. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  6. cp -f $QPEDIR/src/qt/qconfig-qpe.h src/tools/  
  7. ./configure -system-jpeg -no-xft -qconfig qpe -qvfb -depths 4,8,16,32  
  8. make sub-src 

5.Build Qtopia:

  1. cd $QPEDIR  
  2. export QTDIR=$QTEDIR  
  3. export PATH=$QPEDIR/bin:$PATH  
  4. export  
  5. LD_LIBRARY_PATH=$QPEDIR/lib:$LD_LIBRARY_PATH  
  6. ./configure  
  7. make 

和前面编译Qt/Embedded 的基本步骤一样,还可以参考“./configure --help”,来进行选择。为了保证qvfb 能够正确显示qtopia 的结果,我们必须保证环境变量设置正确,我们可以通过“env”命令来检查下面的环境变量,也可以用下面的方法来检查。

  1.  echo $QPEDIR  
  2. /root/qtopia/qtopia-free-2.1.1/  
  3. echo $QTDIR  
  4. /root/qtopia/qt-2.3.10  
  5. echo $LD_LIBRARY_PATH  
  6. /root/qtopia/qtopia-free-2.1.1/lib:/root/qtopia/qt-2.3.10/lib  
  7. echo $PATH  
  8. /root/qtopia/qt-2.3.10/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local 
  9. /sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin 

出现上面的结果就可以正常的显示Virtual framebuffer,我们可以通过下面的命令在Virtual framebuffer 中实现Qtopia。

  1. cd $QPEDIR/bin  
  2. qvfb &  
  3. sleep 10  
  4. ./qpe.sh 

 小结:关于Qt交叉编译工具建立的内容介绍完了,想要深入了解的话,请继续关注 Qt交叉编译工具建立 下篇 ,***希望本文对你有所帮助!

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...