0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

移植speexdsp到OpenHarmony标准系统②

电子发烧友开源社区 来源:未知 2022-11-30 09:10 次阅读

由于想要分享的内容较多,为避免读者姥爷们失去看下去的耐心,分享将以连载的方式进行。

第一期请点击查看《移植speexdspOpenHarmony标准系统①》,本期为移植speexdsp到OpenHarmony标准系统的第②期,主要内容如下:

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

linux上生成speexdsp的so动态链接库和.a静态链接库

  • make和make install后会生成speexdsp的.so动态链接库和.a静态链接库

make
make install

(左右移动查看全部内容)

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

其中build/lib目录下:

├── libspeexdsp.a               /*静态库*/
├── libspeexdsp.la               /*记录同名动态库和静态库相关信息的la文本文件*/
├── libspeexdsp.so -> libspeexdsp.so.1.5.2 
├── libspeexdsp.so.1 -> libspeexdsp.so.1.5.2  /*符号链接*/
├── libspeexdsp.so.1.5.2            /*动态库*/
└── pkgconfig                 /*pkgconfig 的 *.pc文件*/
  └── speexdsp.pc

(左右移动查看全部内容)

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

  • o: 编译的目标文件

  • a: 静态库,其实就是把若干o文件打了个包

  • so: 动态链接库(共享库) 动态库文件必须以lib开头,以.so结尾

  • lo: 使用libtool编译出的目标文件,其实就是在o文件中添加了一些信息

  • la: 使用libtool编译出的库文件,其实是个文本文件,记录同名动态库和静态库的相关信息

知识拓展:

  • 函数库分为静态库*a和动态库*.so两种:
    ①静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库。
    ②动态库在程序编译时并不会被连接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需要动态库存在。

  • 符号链接(symbolic link)是 Linux 系统中的一种文件,它指向系统中的另一个文件或目录。符号链接类似于 Windows 系统中的快捷方式。

  • 在linux中,*.la是记录同名动态库和静态库相关信息的文本文件。

三、分析speexdsp在标准Linux系统的编译过程文件

分析speexdsp在标准Linux系统的编译过程文件,找到生成so库和测试用的可执行文件所需的.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}#这个是在构建环境上运行的一个脚本,它用来猜测构建机的配置环境,因为这个脚本是在构建机上运行,所以它可以动态执行uname等命令来获得构建机的环境,所以我们一般不要指定这个变量,从而让脚本自动获得。
├── config.h#Config.h是自动生成的头文件,是根据配置文件Config.h.in生成的。config.h主要用于代码移植,产生可移植代码。
├── config.h.in#autoheader后形成config.h.in
├── config.log#该文件在执行configure文件时动态生成,包含了一些行号信息,表示一个文件在哪一行执行,以及执行的什么命令,因此可以知道测试是在哪个位置中完成。
├── color {#0F0} {config.status}#这是脚本文件,运行该脚本可以生成一个当前相同的配置,从而避免再次执行configure这个比较庞大的代码。也就是config.log生成的是文本文件,而config.status生成的则是命令脚本文件。
├── color {#0F0} {config.sub}#这个是将host target build变量正则化的一个脚本,它的sub就是substitute的缩写。因为用户提供的build可能并不符合脚本正规的四元组或者三元组的结构,所以这个脚本将它转换为标准的格式,从而可以进行格式化处理。
├── color {#0F0} {configure}#这个是我们需要监测环境的主要入口文件,使用该文件可以生成Makefile文件,它会替换Makefile中需要替换的变量。
├── color {#0F0} {configure.ac}#该文件为autoconfigure文件使用的一个文件,该文件用来生成configure文件,这个文件一般是开发者维护,我们安装该软件的时候只需要执行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公司联合开发的微信号架构(MSA)
├── color {#0F0} {README.Trimedia}#Trimedia 是由Philips公司1996年推出的新一代媒体处理器(Media Processor)芯片
├── color {#0F0} {README.win32}#Win32是指Microsoft Windows操作系统32位环境
├── 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文件抽象程序更高的编译规则文件。 在里面可以指定生成目录,编译用的源码,编译的时候依赖哪些库,要安装到什么目录。

原生库根目录下的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 。再逐步查看各个文件夹源码可知只有libspeexdsp 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:这个表示该头文件只是参加可执行文件的编译,而不用安装到安装目录下
。如果需要安装到系统中,可以用 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可执行文件需要的.c源文件有testdenoise.c testec.c hotestjitter.c testresample.c testresample2.c

分析原生库下Makefile文件

Makefile里有什么?Makefile里主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释。

  • 显式规则。显式规则说明了如何生成一个或多个目标文件。这是由Makefile的书写者明显指出要生成的文件、文件的依赖文件和生成的命令。

  • 隐晦规则。由于我们的make有自动推导的功能,所以隐晦的规则可以让我们比较简略地书写 Makefile,这是由make所支持的。

  • 变量的定义。在Makefile中我们要定义一系列的变量,变量一般都是字符串,这个有点像你C语言中的宏,当Makefile被执行时,其中的变量都会被扩展到相应的引用位置上。

  • 文件指示。其包括了三个部分,一个是在一个Makefile中引用另一个Makefile,就像C语言中的include一样;另一个是指根据某些情况指定Makefile中的有效部分,就像C语言中的预编译#if一样;还有就是定义一个多行的命令。有关这一部分的内容,我会在后续的部分中讲述。

  • 注释。Makefile中只有行注释,和UNIX的Shell脚本一样,其注释是用 # 字符,这个就像C/C++中的 // 一样。如果你要在你的Makefile中使用 # 字符,可以用反斜杠进行转义,如: # 。

笔者在speexdsp根目录下的makefile(最基本的Makefile)文件中搜索关键字CFLAGS找到CFLAGS = -g -O2 -fvisibility=hidden这条语句

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

分析“make”过程log

以下是执行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动态链接库需要的.c源文件为preprocess.c jitter.c mdf.c fftwrap.c filterbank.c resample.c buffer.c scal.c、smallft.c。

  • 编译出speexdsp动态链接库需要的.h源文件目录为libspeexdsp

  • 编译出测试用的testdenoise testecho testjitter testresample testresample2可执行文件需要的.c源文件有testdenoise.c testec.c hotestjitter.c testresample.c testresample2.c

  • 编译出测试用的testdenoise testecho testjitter testresample testresample2可执行文件需要的.h源文件目录为根目录下include

  • 编译时需要添加的cflags编译器标志为-o -g -O2 -fvisibility=hidden

下期分享内容:将三方库加入到OpenHarmony的编译体系

更多热点文章阅读

  • 基于OpenHarmony的智慧牧场方案:室内管理系统篇
  • 移植speexdsp到OpenHarmony标准系统①
  • OpenHarmony 3.2 Beta多媒体系列:音视频播放gstreamer
  • 基于OpenHarmony的智慧牧场方案:生物运动轨迹跟踪篇
  • 基于OpenHarmony的智能门禁系统,让出行更便捷

提示:本文电子烧友社区发布,转载请注明以上来源。如需社区合作及入群交流,请添加微信EEFans0806,或者发邮箱liuyong@huaqiu.com。


原文标题:移植speexdsp到OpenHarmony标准系统②

文章出处:【微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 电子发烧友
    +关注

    关注

    33

    文章

    548

    浏览量

    32854
  • 开源社区
    +关注

    关注

    0

    文章

    93

    浏览量

    396

原文标题:移植speexdsp到OpenHarmony标准系统②

文章出处:【微信号:HarmonyOS_Community,微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    基于ArkTS语言的OpenHarmony APP应用开发:HelloOpenharmony

    1、程序简介该程序是基于OpenHarmony标准系统编写的UI应用类:HelloOpenHarmony。本案例是基于API9接口开发。本案例已在OpenHarmony凌蒙派-RK35
    的头像 发表于 09-15 08:09 261次阅读
    基于ArkTS语言的<b class='flag-5'>OpenHarmony</b> APP应用开发:Hello<b class='flag-5'>Openharmony</b>

    瑞芯微RK3566鸿蒙开发板OpenHarmony标准系统应用兼容性测试指导

    本文OpenHarmony标准系统应用兼容性测试指导,适用鸿蒙系统软件开发测试的新手入门学习课程,设备为触觉智能的瑞芯微RK3566开发板,型号Purple Pi OH。是Laval官方社区主荐的一款鸿蒙开发主板。
    的头像 发表于 09-10 11:56 265次阅读
    瑞芯微RK3566鸿蒙开发板<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>应用兼容性测试指导

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeMap

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的安全关联容器:SafeMap。OpenHarmony提供了一个线程安全的map实现。SafeMap在STLmap基础上封装互斥锁
    的头像 发表于 08-30 12:42 254次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeMap

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeQueue

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的线程安全队列:SafeQueue。线程安全队列,是在dequeue的基础上封装std::lock_guard,以此实现线程的相关
    的头像 发表于 08-30 12:41 212次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeQueue

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeStack

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的线程安全队列:SafeQueue。线程安全队列,是在dequeue的基础上封装std::lock_guard,以此实现线程的相关
    的头像 发表于 08-30 12:41 250次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeStack

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeBlockQueue

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的读写锁:SafeBlockQueue。线程安全阻塞队列SafeBlockQueue类,提供阻塞和非阻塞版的入队入队和出队接口,并提
    的头像 发表于 08-30 12:41 228次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>的C++公共基础类库案例:SafeBlockQueue

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeStack

    /a28_utils_safestack 2、基础知识 C++公共基础类库为标准系统提供了一些常用的C++开发工具类,包括: 文件、路径、字符串相关操作的能力增强接口 读写锁、信号量、定时器、线程增强及线程池等接口
    发表于 08-21 14:51

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeQueue

    /a27_utils_safequeue 2、基础知识 C++公共基础类库为标准系统提供了一些常用的C++开发工具类,包括: 文件、路径、字符串相关操作的能力增强接口 读写锁、信号量、定时器、线程增强及线程池等
    发表于 08-21 10:56

    请求推荐无需NPU的OpenHarmony标准系统ARM开发板

    请教一下大佬们,目前的需求是在国产ARM开发板上跑OpenHarmony标准系统,无需NPU/GPU,其它配置(CPU、RAM等)可以尽量高点,价位在2k以内,球球推荐!感谢大佬们!
    发表于 08-16 16:25

    OpenHarmony标准系统C++公共基础类库案例:HelloWorld

    1、程序简介该程序是基于凌蒙派OpenHarmony-v3.2.1标准系统C++公共基础类库的简单案例:HelloWorld。主要讲解C++公共基础类库案例如何搭建和编译。2、程序解析2.1、创建
    的头像 发表于 08-13 08:23 390次阅读
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准系统</b>C++公共基础类库案例:HelloWorld

    基于OpenHarmony标准系统的C++公共基础类库案例:ThreadPoll

    1、程序简介 该程序是基于OpenHarmony标准系统的C++公共基础类库的线程池处理:ThreadPoll。 本案例完成如下工作: 创建1个线程池,设置该线程池内部有1024个线程空间。 启动5
    发表于 08-12 11:42

    鸿蒙OpenHarmony【基于Hi3516DV300开发板(时钟应用开发)】

    如何快速搭建基于OpenHarmony标准系统(Hi3516DV300开发板)的应用开发环境,并基于一个时钟APP示例逐步展示应用的创建、开发、调试和安装等流程。
    的头像 发表于 05-08 15:27 1081次阅读
    鸿蒙<b class='flag-5'>OpenHarmony</b>【基于Hi3516DV300开发板(时钟应用开发)】

    鸿蒙OpenHarmony南向:【Hi3516标准系统入门(命令行方式)】

    除小型系统外,Hi3516DV300开发板还支持标准系统。此章节简要介绍如何使用命令行在Hi3516DV300开发板上进行标准系统的开发。
    的头像 发表于 05-08 09:26 766次阅读
    鸿蒙<b class='flag-5'>OpenHarmony</b>南向:【Hi3516<b class='flag-5'>标准系统</b>入门(命令行方式)】

    OpenHarmony开发实例:【 待办事项TodoList】

    TodoList应用是基于OpenHarmony SDK开发的安装在润和HiSpark Taurus AI Camera(Hi3516d)开发板标准系统上的应用;应用主要功能是以列表的形式,展示需要完成的日程;通过本demo可以学习
    的头像 发表于 04-22 22:00 642次阅读
    <b class='flag-5'>OpenHarmony</b>开发实例:【 待办事项TodoList】

    【鸿蒙】标准系统移植指南

    标准系统移植指南 本文描述了移植一块开发板的通用步骤,和具体芯片相关的详细移植过程无法在此一一列举。后续社区还会陆续发布开发板移植的实例供开
    的头像 发表于 02-27 14:36 774次阅读
    【鸿蒙】<b class='flag-5'>标准系统</b><b class='flag-5'>移植</b>指南