全志F1C600 sqlite3嵌入式移植安裝全過程

https://blog.csdn.net/nanfeibuyi/article/details/88034543
https://blog.csdn.net/H542723151/article/details/100568182
https://www.cnblogs.com/wangkangluo1/archive/2012/05/27/2520465.html
https://www.ibm.com/developerworks/cn/linux/l-makefile/
全志F1C600板子移植

step0:生成Makefile

有很多開源庫軟件包中是沒有Makefile的,需要使用者自己生成,自動生成Makefile的步驟如下:

0.1、生成autoscan.log,configure.scan(configure.in)
autoscan是用來掃描源代碼目錄生成configure.scan文件的。autoscan可以用目錄名做爲參數,但如果你不使用參數的話,那麼autoscan將認爲使用的是當前目錄。autoscan將掃描你所指定目錄中的源文件,並創建configure.scan文件。configure.scan包含了系統配置的基本選項,裏面都是一些宏定義。我們需要將它改名爲configure.in

0.2、 執行aclocal命令,生成aclocal.m4 autom4te.cache兩個文件
aclocal是一個perl腳本程序。aclocal根據configure.in文件的內容,自動生成aclocal.m4文件。aclocal的定義是:“aclocal - create aclocal.m4 by scanning configure.ac”。

0.3、 執行autoconf命令,生成重要的configure文件
使用autoconf,根據configure.in和aclocal.m4來產生configure文件。configure是一個腳本,它能設置源程序來適應各種不同的操作系統平臺,並且根據不同的系統來產生合適的Makefile,從而可以使你的源代碼能在不同的操作系統平臺上被編譯出來。

configure.in文件的內容是一些宏,這些宏經過autoconf處理後會變成檢查系統特性、環境變量、軟件必須的參數的shell腳本。configure.in文件中的宏的順序並沒有規定,但是你必須在所有宏的最前面和最後面分別加上AC_INIT宏和AC_OUTPUT宏。

在configure.ini中:
  #號表示註釋,這個宏後面的內容將被忽略。
  AC_INIT(FILE) 這個宏用來檢查源代碼所在的路徑。
  AM_INIT_AUTOMAKE(PACKAGE, VERSION) 這個宏是必須的,它描述了我們將要生成的軟件包的名字及其版本號:PACKAGE是軟件包的名字,VERSION是版本號。當你使用make dist命令時,它會給你生成一個類似helloworld-1.0.tar.gz的軟件發行包,其中就有對應的軟件包的名字和版本號。
  AC_PROG_CC  這個宏將檢查系統所用的C編譯器。
  AC_OUTPUT(FILE)  這個宏是我們要輸出的Makefile的名字。
  我們在使用automake時,實際上還需要用到其他的一些宏,但我們可以用aclocal來幫我們自動產生。執行aclocal後我們會得到aclocal.m4文件。
  產生了configure.in和aclocal.m4兩個宏文件後,我們就可以使用autoconf來產生configure文件了。
  
0.4、 根據Makefile.am文件生成Makefile.in文件
執行命令automake --add-missing,生成重要的Makefile.in文件,這裏如果沒有生成Makefile.in文件,請檢查Makefile.am文件是否編寫正確
Makefile.am是用來生成Makefile.in的,需要你手工書寫。Makefile.am中定義了一些內容:
  AUTOMAKE_OPTIONS  這個是automake的選項。在執行automake時,它會檢查目錄下是否存在標準GNU軟件包中應具備的各種文件,例如AUTHORS、ChangeLog、NEWS等文件。我們將其設置成foreign時,automake會改用一般軟件包的標準來檢查。
  bin_PROGRAMS  這個是指定我們所要產生的可執行文件的文件名。如果你要產生多個可執行文件,那麼在各個名字間用空格隔開。
  helloworld_SOURCES  這個是指定產生“helloworld”時所需要的源代碼。如果它用到了多個源文件,那麼請使用空格符號將它們隔開。比如需要helloworld.h,helloworld.c那麼請寫成helloworld_SOURCES= helloworld.h helloworld.c。
  如果你在bin_PROGRAMS定義了多個可執行文件,則對應每個可執行文件都要定義相對的filename_SOURCES。
  
0.5、 運行autoconf命令生成configure文件。

06、執行./configure,生成Makefile文件
在這裏插入圖片描述
在這裏插入圖片描述

step1:配置

./configure -h查看有哪些配置項
如何查平臺的target
查芯片平臺的工具鏈的版本信息時,會帶出來一個“Target”就是。
在這裏插入圖片描述
所以全志芯片的target就是
./configure --prefix=$(pwd)/installdir --target=arm-openwrt-linux-muslgnueabi --host=arm-openwrt-linux
–host是編譯工具鏈的前綴。

./configure --host=arm-openwrt-linux --prefix=$(pwd)/installdir也可以在全志板子上跑。
主要是編譯工具鏈搞對,這個target是可以不寫的。

step2:編譯

make
可以打開makefile看下工具鏈等關鍵信息是否配置成功

step3:安裝

make install
在這裏插入圖片描述

step4:查看安裝結果

在這裏插入圖片描述

step5:檢查文件信息,是否是指定平臺的架構。

在這裏插入圖片描述

step6 測試:

將bin文件夾中的文件拷貝到開發板的/bin中,並將lib中的文件拷貝到開發板的/lib中。
在這裏插入圖片描述
上圖說明可執行程序是可以用的,libray應該也可以。

step7 庫的使用

非嵌入式(交叉編譯)下編譯:
gcc -g test.c -o test -lsqlite3

上面的代碼是sqlite官方的測試代碼,雖然很簡單但是也很強大,一般應用都夠了,再瞭解一下sqlite的語法就可以實現強大的功能了,編譯方法如下,在這裏假設你已經安裝好了arm-linux-gcc,我採用的是arm-linux-gcc-4.3.2,編譯方法如下:

arm-linux-gcc -o test test.c -sqlite3 -L/work/sqlite/sqlite_arm/lib -I/work/sqlite/sqlite_arm/include

-L/work/sqlite/sqlite_arm/lib :指定庫的位置。
-I/work/sqlite/sqlite_arm/include:指定頭文件的位置。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章