Ubuntu16.04下用luvcview对摄像头功能调试(二)

Ubuntu16.04下用luvcview对摄像头功能调试(二)

Ubuntu16.04下用luvcview对摄像头功能调试(一)中我们已经用vscode搭好了调试项目的环境,下面可以稍微深入了解一下程序的组织和功能接口实现。

找main函数

直觉告诉我main函数在和项目名字相同的luvcview.c中。
在这里插入图片描述
打个断点先,然后F5开始调试,由于这个项目基于事件驱动的,所以直觉又告诉我们等会儿肯定会进入一个等待事件发送的大循环。。另外,从main函数开始调试也可以看看其进行了哪些初始化(参数信息、版本信息、打开摄像头、帧率啥的)。。
点啊点啊点,终于找到了一个可疑的地方
在这里插入图片描述

看这注释的mainloop提示地多明显,上一个语句还创建了个名叫mythread的线程,其参数传了个eventThread,这多半是程序事件任务的线程了,当前的main线程应该是取得摄像头的一帧和显示帧率。
进入到evenThread中。

事件线程

在这里插入图片描述

577行,然后往下浏览,635行的东西很快引起了我们的注意,似乎是在根据curr_action选择执行,
打一个断点,先点击界面上的左边第一个功能:brightness up,然后点击程序执行(continue),果然执行光标走到了635行。
在这里插入图片描述
接下来进入了那个 v4l2UpControl函数,发现它调用了下面的这个函数
在这里插入图片描述
再次进入
在这里插入图片描述
接下来正常执行,打印出语句,亮度参数已调整。

在这里插入图片描述
然后点击执行按钮(continue)进行等待下一次事件。

测试其他功能

随后又测试了界面上左边几个功能,其执行调用函数过程类似。

接下来调试其余的几个暂时无效的功能(如自动白平衡,自动曝光,gamma校正等)
前面过程类似,随意点击一个gamma up按钮在这里插入图片描述
进到刚刚那个isv4l2Control函数,执行到ioctl函数的地方时,发现ioctl函数执行失败返回-1
在这里插入图片描述
ps:这里有可能左边的err显示的是< optimized out >,包括很多变量值都显示的这个。
解决: 在makefile中将编译命令中的 -O2 改为 -O0, 表示不进行编译优化

最后便打印出错误消息在这里插入图片描述
所有的问题都在于这个ioctl函数执行失败,可能并未注册控制数。。

程序eventThread组织方式

从luvcview.c(635行)开始,根据点击的按钮,传入不同的功能参数(如BRIGHTNESS_UP),将其作为参数传入 v4l2UpControl函数。 其实处理这些功能的函数也就两个,v4l2UpControl和v4l2DownControl函数,它们的参数相同。其中一个名为control的int类型参数,根据功能不同,定义不同的数值。 接着就是
 if (isv4l2Control(vd, control, &queryctrl) < 0)

下一篇将讨论功能的实现,看看代码数据组织和结构,以及寻求 ioctl 函数返回-1的原因。

发布了47 篇原创文章 · 获赞 108 · 访问量 8万+

猜你喜欢

转载自blog.csdn.net/Lagrantaylor/article/details/96994768