精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

移植speexdsp到OpenHarmony標準系統(tǒng)②

電子發(fā)燒友開源社區(qū) ? 來源:未知 ? 2022-11-30 09:10 ? 次閱讀

由于想要分享的內容較多,為避免讀者姥爺們失去看下去的耐心,分享將以連載的方式進行。

第一期請點擊查看《移植speexdspOpenHarmony標準系統(tǒng)①》,本期為移植speexdsp到OpenHarmony標準系統(tǒng)的第②期,主要內容如下:

846e2556-704b-11ed-8abf-dac502259ad0.png

linux上生成speexdsp的so動態(tài)鏈接庫和.a靜態(tài)鏈接庫

  • make和make install后會生成speexdsp的.so動態(tài)鏈接庫和.a靜態(tài)鏈接庫

make
make install

(左右移動查看全部內容)

84842a5e-704b-11ed-8abf-dac502259ad0.png

其中build/lib目錄下:

├── libspeexdsp.a               /*靜態(tài)庫*/
├── libspeexdsp.la               /*記錄同名動態(tài)庫和靜態(tài)庫相關信息的la文本文件*/
├── libspeexdsp.so -> libspeexdsp.so.1.5.2 
├── libspeexdsp.so.1 -> libspeexdsp.so.1.5.2  /*符號鏈接*/
├── libspeexdsp.so.1.5.2            /*動態(tài)庫*/
└── pkgconfig                 /*pkgconfig 的 *.pc文件*/
  └── speexdsp.pc

(左右移動查看全部內容)

linux下的so、o、lo、a、la文件:

  • o: 編譯的目標文件

  • a: 靜態(tài)庫,其實就是把若干o文件打了個包

  • so: 動態(tài)鏈接庫(共享庫) 動態(tài)庫文件必須以lib開頭,以.so結尾

  • lo: 使用libtool編譯出的目標文件,其實就是在o文件中添加了一些信息

  • la: 使用libtool編譯出的庫文件,其實是個文本文件,記錄同名動態(tài)庫和靜態(tài)庫的相關信息

知識拓展:

  • 函數庫分為靜態(tài)庫*a和動態(tài)庫*.so兩種:
    ①靜態(tài)庫在程序編譯時會被連接到目標代碼中,程序運行時將不再需要該靜態(tài)庫。
    ②動態(tài)庫在程序編譯時并不會被連接到目標代碼中,而是在程序運行是才被載入,因此在程序運行時還需要動態(tài)庫存在。

  • 符號鏈接(symbolic link)是 Linux 系統(tǒng)中的一種文件,它指向系統(tǒng)中的另一個文件或目錄。符號鏈接類似于 Windows 系統(tǒng)中的快捷方式。

  • 在linux中,*.la是記錄同名動態(tài)庫和靜態(tài)庫相關信息的文本文件。

三、分析speexdsp在標準Linux系統(tǒng)的編譯過程文件

分析speexdsp在標準Linux系統(tǒng)的編譯過程文件,找到生成so庫和測試用的可執(zhí)行文件所需的.c源代碼,頭文件路徑,cflags編譯器標志,所依賴的庫。

對比編譯前后的speexdsp原生庫結構

  • tree工具能以樹形的方式顯示指定目錄的層級結構。非綠色字體是編譯后生成的文件。

├── color {#0F0} {acinclude.m4}
├── color {#0F0} {AUTHORS} #speexdsp項目作者信息
├── color {#0F0} {autogen.sh} #autogen.sh腳本配置文件
├── aclocal.m4 #運行aclocal后生成的aclocal.m4文件和一個緩沖文件夾autom4te.cache
├── autom4te.cache
│ ├── output.0
│ ├── output.1
│ ├── output.2
│ ├── requests
│ ├── traces.0
│ ├── traces.1
│ └── traces.2
├── build
│ ├── include
│ │ └── speex
│ │ ├── speexdsp_config_types.h
│ │ ├── speexdsp_types.h
│ │ ├── speex_echo.h
│ │ ├── speex_jitter.h
│ │ ├── speex_preprocess.h
│ │ └── speex_resampler.h
│ ├── lib
│ │ ├── libspeexdsp.a
│ │ ├── libspeexdsp.la
│ │ ├── libspeexdsp.so -> libspeexdsp.so.1.5.2
│ │ ├── libspeexdsp.so.1 -> libspeexdsp.so.1.5.2
│ │ ├── libspeexdsp.so.1.5.2
│ │ └── pkgconfig
│ │ └── speexdsp.pc
│ └── share
│ └── doc
│ └── speexdsp
│ └── manual.pdf
├── color {#0F0} {ChangeLog}#spexxds原生庫更新日志(和本次移植無關信息)
├── color {#0F0} {compile}
├── color {#0F0} {config.guess}#這個是在構建環(huán)境上運行的一個腳本,它用來猜測構建機的配置環(huán)境,因為這個腳本是在構建機上運行,所以它可以動態(tài)執(zhí)行uname等命令來獲得構建機的環(huán)境,所以我們一般不要指定這個變量,從而讓腳本自動獲得。
├── config.h#Config.h是自動生成的頭文件,是根據配置文件Config.h.in生成的。config.h主要用于代碼移植,產生可移植代碼。
├── config.h.in#autoheader后形成config.h.in
├── config.log#該文件在執(zhí)行configure文件時動態(tài)生成,包含了一些行號信息,表示一個文件在哪一行執(zhí)行,以及執(zhí)行的什么命令,因此可以知道測試是在哪個位置中完成。
├── color {#0F0} {config.status}#這是腳本文件,運行該腳本可以生成一個當前相同的配置,從而避免再次執(zhí)行configure這個比較龐大的代碼。也就是config.log生成的是文本文件,而config.status生成的則是命令腳本文件。
├── color {#0F0} {config.sub}#這個是將host target build變量正則化的一個腳本,它的sub就是substitute的縮寫。因為用戶提供的build可能并不符合腳本正規(guī)的四元組或者三元組的結構,所以這個腳本將它轉換為標準的格式,從而可以進行格式化處理。
├── color {#0F0} {configure}#這個是我們需要監(jiān)測環(huán)境的主要入口文件,使用該文件可以生成Makefile文件,它會替換Makefile中需要替換的變量。
├── color {#0F0} {configure.ac}#該文件為autoconfigure文件使用的一個文件,該文件用來生成configure文件,這個文件一般是開發(fā)者維護,我們安裝該軟件的時候只需要執(zhí)行configure就可以,這個configure.ac我們一般不用理會
├── color {#0F0} {COPYING}
├── color {#0F0} {depcomp}#automake --add-missing命令生成install-sh, missing, depcomp文件
├── color {#0F0} {doc}
│ ├── color {#0F0} {celp_decoder.eps}
│ ├── color {#0F0} {celp_decoder.odg}
│ ├── color {#0F0} {components.eps}
│ ├── color {#0F0} {components.odg}
│ ├── color {#0F0} {echo_path.eps}
│ ├── color {#0F0} {echo_path.odg}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ ├── color {#0F0} {manual.lyx}
│ ├── color {#0F0} {manual.pdf}
│ ├── color {#0F0} {programming.html}
│ ├── color {#0F0} {ref_shaping.eps}
│ ├── color {#0F0} {sampledec.c}
│ ├── color {#0F0} {sampleenc.c}
│ ├── color {#0F0} {speex_abs.eps}
│ ├── color {#0F0} {speex_abs.odg}
│ ├── color {#0F0} {speex_analysis.eps}
│ └── color {#0F0} {speex_analysis.odg}
├── color {#0F0} {Doxyfile}
├── color {#0F0} {html}
│ ├── color {#0F0} {speex.png}
│ ├── color {#0F0} {speex.webprj}
│ └── color {#0F0} {speex.xcf}
├── color {#0F0} {include}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ └── color {#0F0} {speex}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ ├── color {#0F0} {speex_buffer.h}
│ ├── speexdsp_config_types.h
│ ├── color {#0F0} {speexdsp_config_types.h.in}
│ ├── color {#0F0} {speexdsp_types.h}
│ ├── color {#0F0} {speex_echo.h}
│ ├── color {#0F0} {speex_jitter.h}
│ ├── color {#0F0} {speex_preprocess.h}
│ └── color {#0F0} {speex_resampler.h}
├── color {#0F0} {INSTALL}
├── color {#0F0} {install-sh}#automake --add-missing命令生成install-sh, missing, depcomp文件
├── color {#0F0} {libspeexdsp}
│ ├── color {#0F0} {arch.h}
│ ├── color {#0F0} {bfin.h}
│ ├── color {#0F0} {buffer.c}
│ ├── buffer.lo
│ ├── buffer.o
│ ├── color {#0F0} {echo_diagnostic.m}
│ ├── color {#0F0} {fftwrap.c}
│ ├── color {#0F0} {fftwrap.h}
│ ├── fftwrap.lo
│ ├── fftwrap.o
│ ├── color {#0F0} {filterbank.c}
│ ├── color {#0F0} {filterbank.h}
│ ├── filterbank.lo
│ ├── filterbank.o
│ ├── color {#0F0} {fixed_arm4.h}
│ ├── color {#0F0} {fixed_arm5e.h}
│ ├── color {#0F0} {fixed_bfin.h}
│ ├── color {#0F0} {fixed_debug.h}
│ ├── color {#0F0} {fixed_generic.h}
│ ├── color {#0F0} {jitter.c}
│ ├── jitter.lo
│ ├── jitter.o
│ ├── color {#0F0} {kiss_fft.c}
│ ├── color {#0F0} {_kiss_fft_guts.h}
│ ├── color {#0F0} {kiss_fft.h}
│ ├── color {#0F0} {kiss_fftr.c}
│ ├── color {#0F0} {kiss_fftr.h}
│ ├── libspeexdsp.la
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ ├── color {#0F0} {math_approx.h}
│ ├── color {#0F0} {mdf.c}
│ ├── mdf.lo
│ ├── mdf.o
│ ├── color {#0F0} {misc_bfin.h}
│ ├── color {#0F0} {os_support.h}
│ ├── color {#0F0} {preprocess.c}
│ ├── preprocess.lo
│ ├── preprocess.o
│ ├── color {#0F0} {pseudofloat.h}
│ ├── color {#0F0} {resample.c}
│ ├── resample.lo
│ ├── color {#0F0} {resample_neon.h}
│ ├── resample.o
│ ├── color {#0F0} {resample_sse.h}
│ ├── color {#0F0} {scal.c}
│ ├── scal.lo
│ ├── scal.o
│ ├── color {#0F0} {smallft.c}
│ ├── color {#0F0} {smallft.h}
│ ├── smallft.lo
│ ├── smallft.o
│ ├── color {#0F0} {testdenoise}
│ ├── color {#0F0} {testdenoise.c} #測試噪音抑制的文件
│ ├── testdenoise.o
│ ├── color {#0F0} {testecho}
│ ├── color {#0F0} {testecho.c} #測試聲學回音消除的文件
│ ├── testecho.o
│ ├── color {#0F0} {testjitter} # 測試抖動的文件
│ ├── color {#0F0} {testjitter.c}
│ ├── testjitter.o
│ ├── color {#0F0} {testresample}
│ ├── color {#0F0} {testresample2}
│ ├── color {#0F0} {testresample2.c}#測試重采樣的文件
│ ├── testresample2.o
│ ├── color {#0F0} {testresample.c}#測試重采樣的文件
│ ├── testresample.o
│ └── color {#0F0} {vorbis_psy.h}
├── color {#0F0} {libtool}
├── ltmain.sh
├── m4
│ ├── libtool.m4
│ ├── lt~obsolete.m4
│ ├── ltoptions.m4
│ ├── ltsugar.m4
│ └── ltversion.m4
├── color {#0F0} {macosx}
│ ├── color {#0F0} {English.lproj}
│ │ └── color {#0F0} {InfoPlist.strings}
│ ├── color {#0F0} {Info.plist}
│ ├── color {#0F0} {Speex_Prefix.pch}
│ ├── color {#0F0} {Speex_UB.xcodeproj}
│ │ └── color {#0F0} {project.pbxproj}
│ └── color {#0F0} {Speex.xcodeproj}
│ └── color {#0F0} {project.pbxproj}
├── Makefile
├── color {#0F0} {Makefile.am}
├── Makefile.in
├── color {#0F0} {missing}#automake --add-missing命令生成install-sh, missing, depcomp文件
├── color {#0F0} {NEWS}
├── color {#0F0} {README}
├── color {#0F0} {README.blackfin}#匯聚式處理器Blackfin是由ADIIntel公司聯合開發(fā)的微信號架構(MSA)
├── color {#0F0} {README.Trimedia}#Trimedia 是由Philips公司1996年推出的新一代媒體處理器(Media Processor)芯片
├── color {#0F0} {README.win32}#Win32是指Microsoft Windows操作系統(tǒng)32位環(huán)境
├── color {#0F0} {regression-fixes}
│ └── color {#0F0} {1-resampler_unsigned_fix.patch}
├── color {#0F0} {regressions}
├── color {#0F0} {SpeexDSP.kdevelop}
├── speexdsp.pc
├── color {#0F0} {speexdsp.pc.in}
├── SpeexDSP.spec
├── color {#0F0} {SpeexDSP.spec.in}
├── stamp-h1
├── color {#0F0} {symbian}
│ ├── color {#0F0} {bld.inf}
│ ├── color {#0F0} {config.h}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ └── color {#0F0} {speex.mmp}
├── color {#0F0} {ti}#TI公司DSP芯片
│ ├── color {#0F0} {config.h}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ ├── color {#0F0} {os_support_custom.h}
│ ├── color {#0F0} {speex_C54_test}
│ │ ├── Makefile
│ │ ├── color {#0F0} {Makefile.am}
│ │ ├── Makefile.in
│ │ ├── color {#0F0} {speex_C54_test.cmd}
│ │ └── color {#0F0} {speex_C54_test.pjt}
│ ├── color {#0F0} {speex_C55_test}
│ │ ├── Makefile
│ │ ├── color {#0F0} {Makefile.am}
│ │ ├── Makefile.in
│ │ ├── color {#0F0} {speex_C55_test.cmd}
│ │ └── color {#0F0} {speex_C55_test.pjt}
│ └── color {#0F0} {speex_C64_test}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ ├── color {#0F0} {speex_C64_test.cmd}
│ └── color {#0F0} {speex_C64_test.pjt}
├── color {#0F0} {tmv}
│ ├── color {#0F0} {config.h}
│ ├── color {#0F0} {fftwrap_tm.h}
│ ├── color {#0F0} {filterbank_tm.h}
│ ├── color {#0F0} {fixed_tm.h}
│ ├── color {#0F0} {_kiss_fft_guts_tm.h}
│ ├── color {#0F0} {kiss_fftr_tm.h}
│ ├── color {#0F0} {kiss_fft_tm.h}
│ ├── color {#0F0} {mdf_tm.h}
│ ├── color {#0F0} {misc_tm.h}
│ ├── color {#0F0} {preprocess_tm.h}
│ ├── color {#0F0} {profile_tm.h}
│ └── color {#0F0} {speex_config_types.h}
├── color {#0F0} {TODO}
└── color {#0F0} {win32}
├── color {#0F0} {config.h}
├── color {#0F0} {libspeexdsp}
│ ├── color {#0F0} {libspeexdsp.dsp}
│ ├── color {#0F0} {libspeexdsp.dsw}
│ ├── color {#0F0} {libspeexdsp_dynamic.dsp}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ └── Makefile.in
├── color {#0F0} {libspeexdsp.def}
├── Makefile
├── color {#0F0} {Makefile.am}
├── Makefile.in
├── color {#0F0} {speex.iss}
├── color {#0F0} {VS2003}
│ ├── color {#0F0} {libspeexdsp}
│ │ ├── color {#0F0} {libspeexdsp.vcproj}
│ │ ├── Makefile
│ │ ├── color {#0F0} {Makefile.am}
│ │ └── Makefile.in
│ ├── color {#0F0} {libspeexdsp.sln}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ └── color {#0F0} {tests}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ ├── color {#0F0} {testdenoise.vcproj}
│ ├── color {#0F0} {testecho.vcproj}
│ └── color {#0F0} {testresample.vcproj}
├── color {#0F0} {VS2005}
│ ├── color {#0F0} {libspeexdsp}
│ │ ├── color {#0F0} {libspeexdsp.vcproj}
│ │ ├── Makefile
│ │ ├── color {#0F0} {Makefile.am}
│ │ └── Makefile.in
│ ├── color {#0F0} {libspeexdsp.sln}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ └── color {#0F0} {tests}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ ├── Makefile.in
│ ├── color {#0F0} {testdenoise.vcproj}
│ ├── color {#0F0} {testecho.vcproj}
│ └── color {#0F0} {testresample.vcproj}
└── color {#0F0} {VS2008}
├── color {#0F0} {libspeexdsp}
│ ├── color {#0F0} {libspeexdsp.vcproj}
│ ├── Makefile
│ ├── color {#0F0} {Makefile.am}
│ └── Makefile.in
├── color {#0F0} {libspeexdsp.sln}
├── Makefile
├── color {#0F0} {Makefile.am}
├── Makefile.in
└── color {#0F0} {tests}
├── Makefile
├── color {#0F0} {Makefile.am}
├── Makefile.in
├── color {#0F0} {testdenoise.vcproj}
├── color {#0F0} {testecho.vcproj}
└── color {#0F0} {testresample.vcproj}

(左右移動查看全部內容)

分析原生庫下make.am文件

make.am是一種比Makefile文件抽象程序更高的編譯規(guī)則文件。 在里面可以指定生成目錄,編譯用的源碼,編譯的時候依賴哪些庫,要安裝到什么目錄。

原生庫根目錄下的make.am如下

## Process this file with automake to produce Makefile.in. -*-Makefile-*-


# To disable automatic dependency tracking if using other tools than
# gcc and gmake, add the option 'no-dependencies'
AUTOMAKE_OPTIONS = 1.8
ACLOCAL_AMFLAGS = -I m4


pkgconfigdir = $(libdir)/pkgconfig
pkgconfig_DATA = speexdsp.pc


EXTRA_DIST = SpeexDSP.spec SpeexDSP.spec.in SpeexDSP.kdevelop speexdsp.pc.in README.blackfin


#Fools KDevelop into including all files
SUBDIRS = libspeexdsp include doc win32 symbian ti  


DIST_SUBDIRS = libspeexdsp include doc win32 symbian ti


rpm: dist
 rpmbuild -ta ${PACKAGE}-${VERSION}.tar.gz

(左右移動查看全部內容)

父目錄需要包含子目錄,在父目錄下的Makefile.am中需要添加: SUBDIRS = 子目錄。可知speexdsp子目錄為libspeexdsp include doc win32 symbian ti 。再逐步查看各個文件夾源碼可知只有l(wèi)ibspeexdsp include文件夾與本次移植有關。所以接下來查看libspeexdsp目錄下的make.am文件:

子目錄libspeexdsp下的make.am

# Disable automatic dependency tracking if using other tools than gcc and gmake
#AUTOMAKE_OPTIONS = no-dependencies


EXTRA_DIST=echo_diagnostic.m


AM_CPPFLAGS = -I$(top_srcdir)/include -I$(top_builddir)/include/speex -I$(top_builddir) @FFT_CFLAGS@
/*top_srcdir工程最頂層目錄*/
/*top_builddir定義生成目標文件的最上層目錄*/


lib_LTLIBRARIES = libspeexdsp.la


# Sources for compilation in the library
if BUILD_KISS_FFT
 FFTSRC=kiss_fft.c _kiss_fft_guts.h kiss_fft.h kiss_fftr.c kiss_fftr.h 
else
if BUILD_SMALLFT
 FFTSRC=smallft.c
else
 FFTSRC=
endif
endif


libspeexdsp_la_SOURCES = preprocess.c jitter.c mdf.c fftwrap.c filterbank.c resample.c buffer.c 
scal.c $(FFTSRC)/*編譯libspeexdsp.so需要preprocess.c jitter.c mdf.c fftwrap.c filterbank.c resample.c 
buffer.c scal.c、smallft.c源文件(特別需要注意$(FFTSRC)的存在,因為FFTSRC=smallft.c)*/


/*noinst_HEADERS:這個表示該頭文件只是參加可執(zhí)行文件的編譯,而不用安裝到安裝目錄下
。如果需要安裝到系統(tǒng)中,可以用 include_HEADERS來代替。*/
noinst_HEADERS =  arch.h  bfin.h 
  fixed_arm4.h 
  fixed_arm5e.h  fixed_bfin.h  fixed_debug.h  
  math_approx.h   misc_bfin.h  
  fftwrap.h 
 filterbank.h fixed_generic.h os_support.h 
 pseudofloat.h smallft.h vorbis_psy.h resample_sse.h resample_neon.h


libspeexdsp_la_LDFLAGS = -no-undefined -version-info/*LDFLAGS:編譯時的選項*/ @SPEEXDSP_LT_CURRENT@:@SPEEXDSP_LT_REVISION@:@SPEEXDSP_LT_AGE@
libspeexdsp_la_LIBADD = $(LIBM)


if BUILD_EXAMPLES /*編譯測試文件*/ 
noinst_PROGRAMS = testdenoise testecho testjitter testresample testresample2
testdenoise_SOURCES = testdenoise.c
testdenoise_LDADD = libspeexdsp.la@FFT_LIBS@ /*鏈接需要libspeexdsp.la庫文件*/
testecho_SOURCES = testecho.c /*需要的
testecho_LDADD = libspeexdsp.la @FFT_LIBS@ /*鏈接需要libspeexdsp.la庫文件*/
testjitter_SOURCES = testjitter.c
testjitter_LDADD = libspeexdsp.la @FFT_LIBS@ /*鏈接需要libspeexdsp.la庫文件*/
testresample_SOURCES = testresample.c
testresample_LDADD = libspeexdsp.la @FFT_LIBS@ @LIBM@ /*鏈接需要libspeexdsp.la庫文件*/
testresample2_SOURCES = testresample2.c
testresample2_LDADD = libspeexdsp.la @FFT_LIBS@ @LIBM@ /*鏈接需要libspeexdsp.la庫文件*/
endif

(左右移動查看全部內容)

通過分析libspeexdsp下的make.am可以知道:

  • 編譯出so庫需要的.c源文件有preprocess.c jitter.c mdf.c fftwrap.c filterbank.c resample.c
    buffer.c scal.c、smallft.c

  • 編譯出so庫需要的.h源文件有arch.h bfin.h fixed_arm4.h fixed_arm5e.h fixed_bfin.h fixed_debug.h math_approx.h misc_bfin.h fftwrap.h filterbank.h fixed_generic.h os_support.h pseudofloat.h smallft.h vorbis_psy.h resample_sse.h resample_neon.h

  • 編譯出測試用的testdenoise testecho testjitter testresample testresample2可執(zhí)行文件需要的.c源文件有testdenoise.c testec.c hotestjitter.c testresample.c testresample2.c

分析原生庫下Makefile文件

Makefile里有什么?Makefile里主要包含了五個東西:顯式規(guī)則、隱晦規(guī)則、變量定義、文件指示和注釋。

  • 顯式規(guī)則。顯式規(guī)則說明了如何生成一個或多個目標文件。這是由Makefile的書寫者明顯指出要生成的文件、文件的依賴文件和生成的命令。

  • 隱晦規(guī)則。由于我們的make有自動推導的功能,所以隱晦的規(guī)則可以讓我們比較簡略地書寫 Makefile,這是由make所支持的。

  • 變量的定義。在Makefile中我們要定義一系列的變量,變量一般都是字符串,這個有點像你C語言中的宏,當Makefile被執(zhí)行時,其中的變量都會被擴展到相應的引用位置上。

  • 文件指示。其包括了三個部分,一個是在一個Makefile中引用另一個Makefile,就像C語言中的include一樣;另一個是指根據某些情況指定Makefile中的有效部分,就像C語言中的預編譯#if一樣;還有就是定義一個多行的命令。有關這一部分的內容,我會在后續(xù)的部分中講述。

  • 注釋。Makefile中只有行注釋,和UNIX的Shell腳本一樣,其注釋是用 # 字符,這個就像C/C++中的 // 一樣。如果你要在你的Makefile中使用 # 字符,可以用反斜杠進行轉義,如: # 。

筆者在speexdsp根目錄下的makefile(最基本的Makefile)文件中搜索關鍵字CFLAGS找到CFLAGS = -g -O2 -fvisibility=hidden這條語句

84957796-704b-11ed-8abf-dac502259ad0.png

分析“make”過程log

以下是執(zhí)行make命令后在終端顯示的部分log,通過分析也可以知道編譯so庫需要的.c文件均位于libspeexdsp目錄。

jiajiahao@ubuntu:~/Desktop/speexdsp-SpeexDSP-1.2.1$ make
make all-recursive
make[1]: 進入目錄“/home/jiajiahao/Desktop/speexdsp-SpeexDSP-1.2.1
Making all in libspeexdsp
make[2]: 進入目錄“/home/jiajiahao/Desktop/speexdsp-SpeexDSP-1.2.1/libspeexdsp”
 CC    preprocess.lo
 CC    jitter.lo
 CC    mdf.lo
 CC    fftwrap.lo
 CC    filterbank.lo
 CC    resample.lo
 CC    buffer.lo
 CC    scal.lo
 CC    smallft.lo
 CCLD   libspeexdsp.la
make[2]: 離開目錄“/home/jiajiahao/Desktop/speexdsp-SpeexDSP-1.2.1/libspeexdsp”

(左右移動查看全部內容)

分析build安裝目錄下生成的.pc文件

下圖為build/lib/pkgconfig目錄的speexdsp.pc文件

84a4a9c8-704b-11ed-8abf-dac502259ad0.png

.pc文件的所有參數

  • Name: 該模塊的名字,比如你的pc名字是xxxx.pc,那么名字最好也是xxxx。

  • Description: 模塊的簡單描述。上文pkg-config –list-all命令出來的結果,每個名字后面就是description。

  • URL: 用戶可以通過該URL獲得更多信息,或者下載信息。也是輔助的,可要可不要。

  • Version: 版本號。

  • Requires: 該模塊有木有依賴于其他模塊。一般沒有。

  • Requires.private: 該模塊有木有依賴于其他模塊,并且還不需要第三方知道的。一般也沒有。

  • Conflicts: 有沒有和別的模塊沖突。常用于版本沖突。比如,Conflicts: bar < 1.2.3,表示和bar模塊的1.2.3以下的版本有沖突。

  • Cflags: 這個就很重要了。pkg-config的參數–cflags就指向這里。主要用于寫本模塊的頭文件的路徑。

  • Libs: 也很重要,pkg-config的參數–libs就指向這里。主要用于寫本模塊的庫/依賴庫的路徑。

  • Libs.private: 本模塊依賴的庫,但不需要第三方知道。

在文件中的第14行中清楚的指出speexdsp依賴-lm這個庫。

分析運行configure命令后生成的config.log

84c24244-704b-11ed-8abf-dac502259ad0.png

從中也可以分析出speexdsp依賴的庫-lm 和編譯器需要添加的C_FLAGS標記-g -O2 -fvisibility=hidden

configure:9932: checking for cos in -lm
configure:9957: gcc -o conftest -g -O2 -fvisibility=hidden  conftest.c -lm  >&5

(左右移動查看全部內容)

結論

  • speexdsp依賴的庫為-lm

  • 編譯出speexdsp動態(tài)鏈接庫需要的.c源文件為preprocess.c jitter.c mdf.c fftwrap.c filterbank.c resample.c buffer.c scal.c、smallft.c。

  • 編譯出speexdsp動態(tài)鏈接庫需要的.h源文件目錄為libspeexdsp

  • 編譯出測試用的testdenoise testecho testjitter testresample testresample2可執(zhí)行文件需要的.c源文件有testdenoise.c testec.c hotestjitter.c testresample.c testresample2.c

  • 編譯出測試用的testdenoise testecho testjitter testresample testresample2可執(zhí)行文件需要的.h源文件目錄為根目錄下include

  • 編譯時需要添加的cflags編譯器標志為-o -g -O2 -fvisibility=hidden

下期分享內容:將三方庫加入到OpenHarmony的編譯體系

更多熱點文章閱讀

  • 基于OpenHarmony的智慧牧場方案:室內管理系統(tǒng)篇
  • 移植speexdsp到OpenHarmony標準系統(tǒng)①
  • OpenHarmony 3.2 Beta多媒體系列:音視頻播放gstreamer
  • 基于OpenHarmony的智慧牧場方案:生物運動軌跡跟蹤篇
  • 基于OpenHarmony的智能門禁系統(tǒng),讓出行更便捷

提示:本文電子發(fā)燒友社區(qū)發(fā)布,轉載請注明以上來源。如需社區(qū)合作及入群交流,請?zhí)砑游⑿臙EFans0806,或者發(fā)郵箱liuyong@huaqiu.com。


原文標題:移植speexdsp到OpenHarmony標準系統(tǒng)②

文章出處:【微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關注!文章轉載請注明出處。


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯系本站處理。 舉報投訴

原文標題:移植speexdsp到OpenHarmony標準系統(tǒng)②

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    基于ArkTS語言的OpenHarmony APP應用開發(fā):HelloOpenharmony

    1、程序簡介該程序是基于OpenHarmony標準系統(tǒng)編寫的UI應用類:HelloOpenHarmony。本案例是基于API9接口開發(fā)。本案例已在OpenHarmony凌蒙派-RK35
    的頭像 發(fā)表于 09-15 08:09 ?308次閱讀
    基于ArkTS語言的<b class='flag-5'>OpenHarmony</b> APP應用開發(fā):Hello<b class='flag-5'>Openharmony</b>

    瑞芯微RK3566鴻蒙開發(fā)板OpenHarmony標準系統(tǒng)應用兼容性測試指導

    本文OpenHarmony標準系統(tǒng)應用兼容性測試指導,適用鴻蒙系統(tǒng)軟件開發(fā)測試的新手入門學習課程,設備為觸覺智能的瑞芯微RK3566開發(fā)板,型號Purple Pi OH。是Laval官方社區(qū)主薦的一款鴻蒙開發(fā)主板。
    的頭像 發(fā)表于 09-10 11:56 ?321次閱讀
    瑞芯微RK3566鴻蒙開發(fā)板<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標準系統(tǒng)</b>應用兼容性測試指導

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:SafeMap

    1、程序簡介該程序是基于OpenHarmony的C++公共基礎類庫的安全關聯容器:SafeMap。OpenHarmony提供了一個線程安全的map實現。SafeMap在STLmap基礎上封裝互斥鎖
    的頭像 發(fā)表于 08-30 12:42 ?289次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標準系統(tǒng)</b>的C++公共基礎類庫案例:SafeMap

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:SafeQueue

    1、程序簡介該程序是基于OpenHarmony的C++公共基礎類庫的線程安全隊列:SafeQueue。線程安全隊列,是在dequeue的基礎上封裝std::lock_guard,以此實現線程的相關
    的頭像 發(fā)表于 08-30 12:41 ?239次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標準系統(tǒng)</b>的C++公共基礎類庫案例:SafeQueue

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:SafeStack

    1、程序簡介該程序是基于OpenHarmony的C++公共基礎類庫的線程安全隊列:SafeQueue。線程安全隊列,是在dequeue的基礎上封裝std::lock_guard,以此實現線程的相關
    的頭像 發(fā)表于 08-30 12:41 ?285次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標準系統(tǒng)</b>的C++公共基礎類庫案例:SafeStack

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:SafeBlockQueue

    1、程序簡介該程序是基于OpenHarmony的C++公共基礎類庫的讀寫鎖:SafeBlockQueue。線程安全阻塞隊列SafeBlockQueue類,提供阻塞和非阻塞版的入隊入隊和出隊接口,并提
    的頭像 發(fā)表于 08-30 12:41 ?266次閱讀
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>標準系統(tǒng)</b>的C++公共基礎類庫案例:SafeBlockQueue

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:SafeStack

    /a28_utils_safestack 2、基礎知識 C++公共基礎類庫為標準系統(tǒng)提供了一些常用的C++開發(fā)工具類,包括: 文件、路徑、字符串相關操作的能力增強接口 讀寫鎖、信號量、定時器、線程增強及線程池等接口
    發(fā)表于 08-21 14:51

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:SafeQueue

    /a27_utils_safequeue 2、基礎知識 C++公共基礎類庫為標準系統(tǒng)提供了一些常用的C++開發(fā)工具類,包括: 文件、路徑、字符串相關操作的能力增強接口 讀寫鎖、信號量、定時器、線程增強及線程池等
    發(fā)表于 08-21 10:56

    請求推薦無需NPU的OpenHarmony標準系統(tǒng)ARM開發(fā)板

    請教一下大佬們,目前的需求是在國產ARM開發(fā)板上跑OpenHarmony標準系統(tǒng),無需NPU/GPU,其它配置(CPU、RAM等)可以盡量高點,價位在2k以內,球球推薦!感謝大佬們!
    發(fā)表于 08-16 16:25

    OpenHarmony標準系統(tǒng)C++公共基礎類庫案例:HelloWorld

    1、程序簡介該程序是基于凌蒙派OpenHarmony-v3.2.1標準系統(tǒng)C++公共基礎類庫的簡單案例:HelloWorld。主要講解C++公共基礎類庫案例如何搭建和編譯。2、程序解析2.1、創(chuàng)建
    的頭像 發(fā)表于 08-13 08:23 ?467次閱讀
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>標準系統(tǒng)</b>C++公共基礎類庫案例:HelloWorld

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:ThreadPoll

    1、程序簡介 該程序是基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫的線程池處理:ThreadPoll。 本案例完成如下工作: 創(chuàng)建1個線程池,設置該線程池內部有1024個線程空間。 啟動5
    發(fā)表于 08-12 11:42

    鴻蒙OpenHarmony【基于Hi3516DV300開發(fā)板(時鐘應用開發(fā))】

    如何快速搭建基于OpenHarmony標準系統(tǒng)(Hi3516DV300開發(fā)板)的應用開發(fā)環(huán)境,并基于一個時鐘APP示例逐步展示應用的創(chuàng)建、開發(fā)、調試和安裝等流程。
    的頭像 發(fā)表于 05-08 15:27 ?1118次閱讀
    鴻蒙<b class='flag-5'>OpenHarmony</b>【基于Hi3516DV300開發(fā)板(時鐘應用開發(fā))】

    鴻蒙OpenHarmony南向:【Hi3516標準系統(tǒng)入門(命令行方式)】

    除小型系統(tǒng)外,Hi3516DV300開發(fā)板還支持標準系統(tǒng)。此章節(jié)簡要介紹如何使用命令行在Hi3516DV300開發(fā)板上進行標準系統(tǒng)的開發(fā)。
    的頭像 發(fā)表于 05-08 09:26 ?818次閱讀
    鴻蒙<b class='flag-5'>OpenHarmony</b>南向:【Hi3516<b class='flag-5'>標準系統(tǒng)</b>入門(命令行方式)】

    OpenHarmony開發(fā)實例:【 待辦事項TodoList】

    TodoList應用是基于OpenHarmony SDK開發(fā)的安裝在潤和HiSpark Taurus AI Camera(Hi3516d)開發(fā)板標準系統(tǒng)上的應用;應用主要功能是以列表的形式,展示需要完成的日程;通過本demo可以學習
    的頭像 發(fā)表于 04-22 22:00 ?674次閱讀
    <b class='flag-5'>OpenHarmony</b>開發(fā)實例:【 待辦事項TodoList】

    【鴻蒙】標準系統(tǒng)移植指南

    標準系統(tǒng)移植指南 本文描述了移植一塊開發(fā)板的通用步驟,和具體芯片相關的詳細移植過程無法在此一一列舉。后續(xù)社區(qū)還會陸續(xù)發(fā)布開發(fā)板移植的實例供開
    的頭像 發(fā)表于 02-27 14:36 ?837次閱讀
    【鴻蒙】<b class='flag-5'>標準系統(tǒng)</b><b class='flag-5'>移植</b>指南