前言
有时候需要进行源码断点调试(断点调试是寻找问题的利器,同时也有利于加快理解ffmpeg源码),本文介绍如何用Xcode开发环境进行ffmpeg的源码断点调试,这里介绍了如何开启源码断点调试,开启源码断点调试的前提是编译ffmpeg库的时候开启--enable-debug选项。
源码调试前的准备
- 环境
系统:Mac OS X 10.15.4 (19E266)
Xcode:11.4 (11E146)
ffmpeg:4.2 - 编译mac下的ffmpeg源码
git clone https://github.com/FFmpeg/FFmpeg.git
cd FFmpeg
git checkout -b 4.2 remotes/origin/release/4.2
./configure --enable-debug --enable-gpl --enable-libx264 \
--enable-nonfree --enable-libmp3lame --disable-optimizations
make && make install
这里引入了x264 libmp3lame外部库,make工具默认会在/usr/local/include查找外部库的头文件,在/usr/local/lib查找对应的外部库文件;如果这些外部库没有安装,则通过brew工具安装,命令如下:
brew install x264
brew install lame
备注:
--disable-optimizations必须要加上,不然断点调试会出现"stack_not_16_byte_aligned_error"崩溃(10.15.4的系统和11.4的xcode编译的ffmpeg库才会有这个问题,其它情况不需要加这个选项)。
--enable-libx264 后边命令写不下时的 "\" 要加上
默认ffmpeg会被安装到源码根目录下。
-
准备调试工程
1、新建一个工程
工程语言为:C语言
备注:等待数分钟待xcode创建完所有的索引
调试ffmpeg自带源码ffmpeg.c/ffplay.c/ffprobe.c
1、在前面工程中新建target
2、配置target
3、配置运行参数
备注:这里为ffplay 命令行程序运行需要的参数。如果上面选择的是ffmpeg程序,这里参数可以根据实际需求更改
4、调试
如果更改了更改了这三个文件中的代码或者ffmpeg中的源码,则重新执行指令
make
将更改生效,然后再进行对应的断点调试
调试ffmpeg下的examples例子源码
Mac环境下编译ffmpeg下examples中的例子
方式一
// -o 代表生成中间编译代码,并且生成可执行程序
cd ffmpeg源码/examples
clang encode_video.c -o ./test/encode_video -I/usr/local/include -L/usr/local/lib/ -lavformat -lavcodec -lavutil -lavfilter -lswscale
./test/encode_video ./test/test.mp4 libx264
备注:此方式编译的程序无法进行断点调试,原因还不清楚
方式二
cd ffmpeg源码/
make examples
如果要清除重新编译则先使用命令 make examplesclean;具体参考examples目录下的readme文档;默认这些例子程序将生成在examples目录下
对examples下的程序程序设置断点调试步骤和前面基于ffmpeg/ffprobe/ffplay一样。只不过在前面步骤4中选择的程序为example这些例子程序,打断点时选择examples目录下的对应例子代码即可