关于宏v4l2
struct v4l2_subdev *sd结构体
struct v4l2_subdev {
#if defined(CONFIG_MEDIA_CONTROLLER)
struct media_entity entity;
#endif
struct list_head list;
struct module *owner;
bool owner_v4l2_dev;
u32 flags;
struct v4l2_device *v4l2_dev;
const struct v4l2_subdev_ops *ops;
const struct v4l2_subdev_internal_ops *internal_ops;
struct v4l2_ctrl_handler *ctrl_handler;
char name[V4L2_SUBDEV_NAME_SIZE];
u32 grp_id;
void *dev_priv;
void *host_priv;
struct video_device *devnode;
struct device *dev;
struct fwnode_handle *fwnode;
struct list_head async_list;
struct v4l2_async_subdev *asd;
struct v4l2_async_notifier *notifier;
struct v4l2_async_notifier *subdev_notifier;
struct v4l2_subdev_platform_data *pdata;
};
sd->ops
(图片来源网络,侵删)
if(sd->ops == NULL){
DEBUG_CORE("sd->ops NULL");
break;
}
然后看看 v4l2_subdev_ops 的定义
static const struct v4l2_subdev_ops ov5645_subdev_ops = {
.core = &ov5645_core_ops,
.video = &ov5645_video_ops,
.pad = &ov5645_subdev_pad_ops,
};
if(sd->ops->core == NULL){
DEBUG_CORE("sd->ops->core NULL");
break;
}
最后判断ioctl是否为空
if(sd->ops->core->ioctl == NULL){
DEBUG_CORE("sd->ops->core NULL");
break;
}
sd->ops->core->ioctl(sd, ctrl->id, &ctrl->val);
小结
最后把 v4l2_subdev_call(sd, core, ioctl, ctrl->id,ctrl->val);
转换为了 sd->ops->core->ioctl(sd, ctrl->id, &ctrl->val);
转换这个主要是为了空指针检查。解决问题了以后,还是用原来的宏就行了。
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
