Ubuntu實現樹莓派交叉編譯

2021-08-27 23:54:12 字數 4760 閱讀 1567

一、交叉編譯

在乙個平台上生成另乙個平台上的可執行**。為什麼要大費周折的進行交叉編譯呢?一句話:不得已而為之。有時是因為目的平台上不允許或不能夠安裝所需要的編譯器,而又需要這個編譯器的某些特徵;有時是因為目的平台上的資源貧乏,無法執行所需要的編譯器;有時又是因為目的平台還沒有建立,連作業系統都沒有,根本談不上執行什麼編譯器。

要進行交叉編譯,我們需要在主機平台上安裝對應的交叉編譯工具鏈(cross compilation tool chain),然後用這個交叉編譯工具鏈編譯源**,最終生成可在目標平台上執行的**。

常見的交叉編譯例子如下:

1、在windows pc上,利用ads(arm 開發環境),使用armcc編譯器,則可編譯出針對arm cpu的可執行**。

2、在linux pc上,利用arm-linux-gcc編譯器,可編譯出針對linux arm平台的可執行**。

3、在windows pc上,利用cygwin環境,執行arm-elf-gcc編譯器,可編譯出針對arm cpu的可執行**。

二、名詞解釋

linux下的大多數軟體包都使用autoconf/automake工具自動生成makefile,只要使用「./configure」,「make」,「make install」就可以把程式安裝到linux系統中去了。編譯第三方源**時,可以看下工程中的readme和install檔案,一般情況下都會寫編譯步驟。

1、./configure 常用引數  [--build] | [--host] | [--target] | [--prefix] | [--help]

>> ./configure: 用來生成對應的 makefile;

>> --build: 執行**編譯的主機,正常的話就是你的主機系統。若無指定使用host的值;

>> --host: 編譯出來的二進位制程式所執行的主機, 交叉編譯工具鏈的字首。因為絕大多數是如果本機編譯就本機執行,所以這個值就等於build。但是交叉編譯的時候build和host需要設定不同值,用host指定執行主機,即host != build的時候編譯才是交叉編譯。若無指定將會執行`config.guess'來檢測;

>> --prefix: 安裝目錄,比如 --prefix=/usr 意思是將該軟體安裝在 /usr 下面,執行檔案就會安裝在 /usr/bin (而不是預設的 /usr/local/bin),資源檔案就會安裝在 /usr/share(而不是預設的/usr/local/share);

>> --help: 檢視引數;

>> --target: 這個引數比較特殊,表示需要處理的目標平台名稱,主要在程式語言工具如編譯器和彙編器上下文中起作用,若無指定使用host的值。一般用來編譯工具,比如給arm開發板編譯乙個可以處理mips程式的gcc,那麼--target=mips;

>>>> 舉例說明:編譯gcc

>> ./configure --build=i386-linux --host=arm-linux --target=mipsel-linux --prefix=$(pwd)/_install

用i386-linux的編譯器進行gcc的編譯,編譯出的gcc執行在arm-linux, 編譯結果存放到$(pwd)/_install路徑下,編譯出的gcc用來編譯能夠在mipsel-linux下執行的**。

2、makefile包含了一些基本的預先定義的操作:

>>make: 根據makefile編譯源**,連線,生成目標檔案,可執行檔案;

>>make clean: 清除上次的make命令所產生的object檔案(字尾為「.o」的檔案)及可執行檔案;

>>make distclean: 類似make clean,但同時也將configure生成的檔案全部刪除掉,包括makefile;

>>make test / make check: 檢查make,確保make沒有出錯,一般在make install之前執行;

>>make install: 將編譯成功的可執行檔案安裝到指定目錄中,一般為/usr/local/bin目錄;

>>make dist: 產生發布軟體包檔案(即distribution package)。這個命令將會將可執行檔案及相關檔案打包成乙個tar.gz壓縮的檔案用來作為發布軟體的軟體包。它會在當前目錄下生成乙個名字類似「package-version.tar.gz」的檔案。package和version,是我們在configure.in中定義的am_init_automake(package, version);

>>make distcheck: 生成發布軟體包並對其進行測試檢查,以確定發布包的正確性。這個操作將自動把壓縮包檔案解開,然後執行configure命令,並且執行make,來確認編譯不出現錯誤,最後提示你軟體包已經準備好,可以發布了;

三、交叉編譯源**

1、環境

ubuntu

2、樹莓派交叉編譯工具安裝

step2. 將原始碼放到各使用者都能share的資料夾下,如/usr/tools

step3. 將交叉編譯工具的路徑加到環境變數中,為了以後啟動不用再設定,我加到了/etc/bash.bashrc中

1 $gedit /etc/bash.bashrc

2 #在檔案的末尾加上: export path=$path:/usr/tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian-x64/bin

3 $source /etc/bash.bashrc

step4. 檢測是否安裝成功

way1: 

$arm #雙tab
顯示以下內容

#能顯示正確資訊

$arm-linux-gnueabihf-g++ -v

#能顯示正確資訊

注意:交叉編譯時,如果出現arm-linux-gnueabihf-***找不到,確定arm-linux-gnueabihf-*** -v 是否能輸出正確資訊;

如果-v顯示「no such file or diectory」, 可能是32位/64位相容問題,解決辦法:

13.10之前版本

//安裝32位相容庫

1 apt-get install ia32-libs

13.10之後版本

1 $ dpkg --add-architecture i386

2 $ apt-get update

3 $ sudo apt-get install lib32z1-dev

4 $ sudo apt-get install libgtk2.0-0:i386 libpangox-1.0-0:i386 libpangoxft-1.0-0:i386 libidn11:i386 libasound2:i386 libasound2-plugins:i386 gstreamer0.10-pulseaudio:i386 gstreamer0.10-plugins-base:i386 gstreamer0.10-plugins-good:i386 gstreamer0.10-ffmpeg:i386

5 $ sudo apt-get install ia32-libs

三、編譯源**

1、在寫編譯指令碼時,一定要確保編譯器寫的是交叉編譯的編譯器。比如比較常用的makefile,

1 demo: $(obj)

2 $(cxx) -o $@ $^ $(ldflags)

其中的cxx必須是arm-linux-gnueabihf-g++才能編譯出正確的在樹莓派上的可執行檔案。

2、編譯第三方庫

如果你想設定全域性的cc和cxx變數,在每次開啟乙個新的terminal時,輸入以下命令:

1 $export cc=arm-linux-gnueabihf-gcc  

2 $export cxx=arm-linux-gnueabihf-g++

其他的全域性變數同上。

以下列幾個常用的第三方庫交叉編譯步驟

1>> sqlite3  sqlite-autoconf-3081002.tar.gz

step1:  make clean

step2:  ./configure --host=arm-linux-gnueabihf --prefix=/usr/local/tools/sqlite3

step3:  make

step4:  make install

2>>curl   curl-7.43.0.tar.gz

step1:  make clean

step2:  ./configure --host=arm-linux-gnueabihf --prefix=/usr/local/tools/curl

step3:  make

step4:  make install

3>> openssl:  openssl-1.0.1p.tar.gz

step1: ./config no-asm shared --prefix=/usr/local/tools/openssl

step2:  a、修改makefile cc=arm-linux-gnueabihf-gcc

b、找到有-m64的地方,將-m64刪除。  

step3: make

step4: make install

Ubuntu實現樹莓派交叉編譯

一 交叉編譯 在乙個平台上生成另乙個平台上的可執行 為什麼要大費周折的進行交叉編譯呢?一句話 不得已而為之。有時是因為目的平台上不允許或不能夠安裝所需要的編譯器,而又需要這個編譯器的某些特徵 有時是因為目的平台上的資源貧乏,無法執行所需要的編譯器 有時又是因為目的平台還沒有建立,連作業系統都沒有,根...

Ubuntu實現樹莓派交叉編譯

一 交叉編譯 在乙個平台上生成另乙個平台上的可執行 為什麼要大費周折的進行交叉編譯呢?一句話 不得已而為之。有時是因為目的平台上不允許或不能夠安裝所需要的編譯器,而又需要這個編譯器的某些特徵 有時是因為目的平台上的資源貧乏,無法執行所需要的編譯器 有時又是因為目的平台還沒有建立,連作業系統都沒有,根...

在ubuntu交叉編譯 樹莓派

交叉編譯是在乙個平台上生成另乙個平台上的可執行 比如 1.我們再windows上面編寫c51 並編譯成可執行 如xx.hex,是在c51上面執行,不是在windows上面執行 2.我們在ubuntu上面編寫樹莓派的 並編譯成可執行 如a.out,是在樹莓派上面執行,不是在ubuntu linux上面...