在Linux平台上使用Cmake进行交叉编译替代嵌入式平台所使用的Makefile

时间:2021-08-05 18:45:00

在Linux平台上使用Cmake进行交叉编译替代嵌入式平台所使用的Makefile

阿曾

2010.3.9

 嵌入式平台编写了一个大项目,一直使用的是Makefile,现在要改为Cmake,之前没有碰过Cmake,开始现学现用。

参考资料:

在 linux 下使用 CMake 构建应用程序》--在IBM developerWorks上的一篇文章


Cmake实践》-- 非常好的教程


http://blog.csdn.net/netnote/article/details/4051620  总结的很好


一 Cmake 语法基础

在工程目录hello文件夹下面有三个文件夹,分别是build,doc,src,文件分别有CMakeLists.txt,COPYRIGHT,R,E

,README,runhello.sh.

在doc下面有hello.txt.在src下面有main.c,CMakeLists.txt

在工程目录下的CMakeLists.txt内容

在src目录下的CMakeLists.txt内容

在工程目录下的build下面执行

cmake ..

将在build目录下生成各种Cmake的中间产物。

然后执行

make

make install

将各种安装文件按照CMAKE_INSTALL_PREFIX的目录安装。

这样将在/tmp/camke/hello2目录下生成几个目录

/tmp/camke/hello2/bin,下面有hello,runhello.sh

/tmp/camke/hello2/share/doc,下面有COPYRIGHT,README,hello.txt


二 以 jm11.0kta1.2为例编写cmake需要的CMakeLists.txt

 jm11.0kta1.2 download website:  http://iphome.hhi.de/suehring/tml/download/KTA/

 jm11.0kta1.2.zip解压后的文件夹名为JMKTA。
JMKTA的目录结构如下
.
├── bin
│   ├── decoder.cfg
│   ├── encoder_baseline.cfg
│   ├── encoder.cfg
│   ├── encoder_extended.cfg
│   ── xxxxxxxxxxxxxxxxxxxxxxx
│   ├── q_matrix_def.cfg
│   ├── q_offset.cfg
│   ├── sg0conf.cfg
│   ├── sg2conf.cfg
│   └── sg6conf.cfg
├── Changes_detail.txt
├── CHANGES.TXT
├── copyright.txt
├── disclaimer.txt
├── doc
│   ├── coding_style.doc
│   ├── doxygen.txt
│   ├── foot.html
│   ├── h26l.css
│   ├── ldecod.dox
│   └── lencod.dox
├── Doxyfile
├── FREXT_changes.txt
├── KTA_CHANGES.TXT
├── lcommon
│   ├── inc
│   └── src
├── ldecod
│   ├── inc
│   │   ├── adaptive_filter.h
│   │   ├── adaptive_quantization.h
│   │   ├── xxxxxxxxxxxxxxxxxxxxxxx
│   │   ├── output.h
│   │   ├── parsetcommon.h
│   │   ├── parset.h
│   │   ├── rtp.h
│   │   ├── sei.h
│   │   ├── spatial_domain_coding.h
│   │   ├── transform8x8.h
│   │   └── vlc.h
│   ├── Makefile
│   ├── obj
│   └── src
│       ├── adaptive_filter.c
│       ├── adaptive_quantization.c
│       ├── annexb.c
│       ├── xxxxxxxxxxxxxxxxxxxxxxx
│       ├── parsetcommon.c
│       ├── rtp.c
│       ├── sei.c
│       ├── spatial_domain_coding.c
│       ├── transform8x8.c
│       └── vlc.c
├── ldecod.dsp
├── ldecod.dsw
├── ldecod.kdevelop
├── ldecod.kdevelop.filelist
├── ldecod.vcproj
├── lencod
│   ├── inc
│   │   ├── adaptive_filter.h
│   │   ├── adaptive_quantization.h
│   │   ├── annexb.h
│   │   ├── xxxxxxxxxxxxxxxxxxxxxxx
│   │   ├── refbuf.h
│   │   ├── rtp.h
│   │   ├── sei.h
│   │   ├── simplified_fast_me.h
│   │   ├── spatial_domain_coding.h
│   │   ├── transform8x8.h
│   │   └── vlc.h
│   ├── Makefile
│   ├── obj
│   └── src
│       ├── adaptive_filter.c
│       ├── adaptive_quantization.c
│       ├── annexb.c
│       ├── biariencode.c
│       ├── block.c
│       ├── xxxxxxxxxxxxxxxxxxxxxxx
│       ├── simplified_fast_me.c
│       ├── slice.c
│       ├── spatial_domain_coding.c
│       ├── transform8x8.c
│       ├── vlc.c
│       └── weighted_prediction.c
├── lencod.dsp
├── lencod.dsw
├── lencod.kdevelop
├── lencod.kdevelop.filelist
├── lencod.vcproj
├── Readme.txt
├── rtpdump
│   ├── ReadMe.txt
│   ├── rtpdump.cpp
│   ├── rtpdump.dsp
│   ├── rtpdump.vcproj
│   ├── StdAfx.cpp
│   └── StdAfx.h
├── tml.dsw
├── tml.sln
└── unixprep.sh

bin文件夹里面有可执行程序的配置参数。
doc里面是文档,而且居然给的是word版。
主要用到的是lencod和ldecod文件夹,分别是编码端和解码端代码。
假如JMKTA文件夹在个人目录下。进入JMKTA文件夹

cd ~/JMKTA
vim CMakeLists.txt

PROJECT(kta)
CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
ADD_SUBDIRECTORY(lencod)


cd lencod

vim CMakeLists.txt

ADD_SUBDIRECTORY(src)


cd src

vim CMakeLists.txt

AUX_SOURCE_DIRECTORY(. DIR_SRCS)
INCLUDE_DIRECTORIES(${kta_SOURCE_DIR}/lencod/inc)
ADD_EXECUTABLE(lencod ${DIR_SRCS})
SET(EXECUTABLE_OUTPUT_PATH ${kta_SOURCE_DIR}/bin)
MESSAGE(STATUS "KTA BINARY DIR is ",${kta_SOURCE_DIR}/bin)
TARGET_LINK_LIBRARIES(lencod m)


推荐采用外部构建的方法,在KTA文件夹里面新建一个build文件夹构建工程。当然,这个文件夹放任何地方都可以。
cd ~/JMKTA
mkdir build
cmake ..
make

然后可执行程序lencod在~/JMKTA/bin里面。

现在我们来分析一下几个CMAKE的基本语句。

  • PROJECT(kta)定义工程名,后面的变量kta_SOURCE_DIR就是指这个工程路径。
  • CMAKE_MINIMUM_REQUIRED(VERSION 2.6) 要求都最低版本号
  • ADD_SUBDIRECTORY(lencod) 增加存放源文件都子目录
  • AUX_SOURCE_DIRECTORY(. DIR_SRCS)  将当前目录中的源文件名称赋值给变量 DIR_SRCS
  • INCLUDE_DIRECTORIES(${kta_SOURCE_DIR}/lencod/inc) 添加头文件存放路径,不然就会出现头文件找不到都错误。
  • ADD_EXECUTABLE(lencod ${DIR_SRCS}) 定义可执行文件名为lencod,相关源文件类表是变量DIR_SRCS的值。这时候当前目录中有多少文件都不怕了,CMAKE会自动编译并处理好依赖关系。
  • SET(EXECUTABLE_OUTPUT_PATH ${kta_SOURCE_DIR}/bin) 认为设置目标二进制可执行程序存放地址为工程源代码存放路径下,根据个人情况而定。我这里和KTA的Makefile保持了一致。
  • MESSAGE(STATUS "KTA BINARY DIR is ",${kta_SOURCE_DIR}/bin) 打印出目标二进制可执行程序都存放路径。
  • TARGET_LINK_LIBRARIES(lencod m)为可执行程序链接共享库,也就是替代了Makefile里面都-lm这条命令。它添加的是算术运算共享库。