提交 9765a32c 编写于 作者: H Hans Verkuil 提交者: Mauro Carvalho Chehab

[media] vivid: set device_caps in video_device

This simplifies the querycap function.
Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: NLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@osg.samsung.com>
上级 3e43cb33
...@@ -200,27 +200,12 @@ static int vidioc_querycap(struct file *file, void *priv, ...@@ -200,27 +200,12 @@ static int vidioc_querycap(struct file *file, void *priv,
struct v4l2_capability *cap) struct v4l2_capability *cap)
{ {
struct vivid_dev *dev = video_drvdata(file); struct vivid_dev *dev = video_drvdata(file);
struct video_device *vdev = video_devdata(file);
strcpy(cap->driver, "vivid"); strcpy(cap->driver, "vivid");
strcpy(cap->card, "vivid"); strcpy(cap->card, "vivid");
snprintf(cap->bus_info, sizeof(cap->bus_info), snprintf(cap->bus_info, sizeof(cap->bus_info),
"platform:%s", dev->v4l2_dev.name); "platform:%s", dev->v4l2_dev.name);
if (vdev->vfl_type == VFL_TYPE_GRABBER && vdev->vfl_dir == VFL_DIR_RX)
cap->device_caps = dev->vid_cap_caps;
if (vdev->vfl_type == VFL_TYPE_GRABBER && vdev->vfl_dir == VFL_DIR_TX)
cap->device_caps = dev->vid_out_caps;
else if (vdev->vfl_type == VFL_TYPE_VBI && vdev->vfl_dir == VFL_DIR_RX)
cap->device_caps = dev->vbi_cap_caps;
else if (vdev->vfl_type == VFL_TYPE_VBI && vdev->vfl_dir == VFL_DIR_TX)
cap->device_caps = dev->vbi_out_caps;
else if (vdev->vfl_type == VFL_TYPE_SDR)
cap->device_caps = dev->sdr_cap_caps;
else if (vdev->vfl_type == VFL_TYPE_RADIO && vdev->vfl_dir == VFL_DIR_RX)
cap->device_caps = dev->radio_rx_caps;
else if (vdev->vfl_type == VFL_TYPE_RADIO && vdev->vfl_dir == VFL_DIR_TX)
cap->device_caps = dev->radio_tx_caps;
cap->capabilities = dev->vid_cap_caps | dev->vid_out_caps | cap->capabilities = dev->vid_cap_caps | dev->vid_out_caps |
dev->vbi_cap_caps | dev->vbi_out_caps | dev->vbi_cap_caps | dev->vbi_out_caps |
dev->radio_rx_caps | dev->radio_tx_caps | dev->radio_rx_caps | dev->radio_tx_caps |
...@@ -1135,6 +1120,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst) ...@@ -1135,6 +1120,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst)
strlcpy(vfd->name, "vivid-vid-cap", sizeof(vfd->name)); strlcpy(vfd->name, "vivid-vid-cap", sizeof(vfd->name));
vfd->fops = &vivid_fops; vfd->fops = &vivid_fops;
vfd->ioctl_ops = &vivid_ioctl_ops; vfd->ioctl_ops = &vivid_ioctl_ops;
vfd->device_caps = dev->vid_cap_caps;
vfd->release = video_device_release_empty; vfd->release = video_device_release_empty;
vfd->v4l2_dev = &dev->v4l2_dev; vfd->v4l2_dev = &dev->v4l2_dev;
vfd->queue = &dev->vb_vid_cap_q; vfd->queue = &dev->vb_vid_cap_q;
...@@ -1160,6 +1146,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst) ...@@ -1160,6 +1146,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst)
vfd->vfl_dir = VFL_DIR_TX; vfd->vfl_dir = VFL_DIR_TX;
vfd->fops = &vivid_fops; vfd->fops = &vivid_fops;
vfd->ioctl_ops = &vivid_ioctl_ops; vfd->ioctl_ops = &vivid_ioctl_ops;
vfd->device_caps = dev->vid_out_caps;
vfd->release = video_device_release_empty; vfd->release = video_device_release_empty;
vfd->v4l2_dev = &dev->v4l2_dev; vfd->v4l2_dev = &dev->v4l2_dev;
vfd->queue = &dev->vb_vid_out_q; vfd->queue = &dev->vb_vid_out_q;
...@@ -1184,6 +1171,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst) ...@@ -1184,6 +1171,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst)
strlcpy(vfd->name, "vivid-vbi-cap", sizeof(vfd->name)); strlcpy(vfd->name, "vivid-vbi-cap", sizeof(vfd->name));
vfd->fops = &vivid_fops; vfd->fops = &vivid_fops;
vfd->ioctl_ops = &vivid_ioctl_ops; vfd->ioctl_ops = &vivid_ioctl_ops;
vfd->device_caps = dev->vbi_cap_caps;
vfd->release = video_device_release_empty; vfd->release = video_device_release_empty;
vfd->v4l2_dev = &dev->v4l2_dev; vfd->v4l2_dev = &dev->v4l2_dev;
vfd->queue = &dev->vb_vbi_cap_q; vfd->queue = &dev->vb_vbi_cap_q;
...@@ -1207,6 +1195,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst) ...@@ -1207,6 +1195,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst)
vfd->vfl_dir = VFL_DIR_TX; vfd->vfl_dir = VFL_DIR_TX;
vfd->fops = &vivid_fops; vfd->fops = &vivid_fops;
vfd->ioctl_ops = &vivid_ioctl_ops; vfd->ioctl_ops = &vivid_ioctl_ops;
vfd->device_caps = dev->vbi_out_caps;
vfd->release = video_device_release_empty; vfd->release = video_device_release_empty;
vfd->v4l2_dev = &dev->v4l2_dev; vfd->v4l2_dev = &dev->v4l2_dev;
vfd->queue = &dev->vb_vbi_out_q; vfd->queue = &dev->vb_vbi_out_q;
...@@ -1229,6 +1218,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst) ...@@ -1229,6 +1218,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst)
strlcpy(vfd->name, "vivid-sdr-cap", sizeof(vfd->name)); strlcpy(vfd->name, "vivid-sdr-cap", sizeof(vfd->name));
vfd->fops = &vivid_fops; vfd->fops = &vivid_fops;
vfd->ioctl_ops = &vivid_ioctl_ops; vfd->ioctl_ops = &vivid_ioctl_ops;
vfd->device_caps = dev->sdr_cap_caps;
vfd->release = video_device_release_empty; vfd->release = video_device_release_empty;
vfd->v4l2_dev = &dev->v4l2_dev; vfd->v4l2_dev = &dev->v4l2_dev;
vfd->queue = &dev->vb_sdr_cap_q; vfd->queue = &dev->vb_sdr_cap_q;
...@@ -1247,6 +1237,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst) ...@@ -1247,6 +1237,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst)
strlcpy(vfd->name, "vivid-rad-rx", sizeof(vfd->name)); strlcpy(vfd->name, "vivid-rad-rx", sizeof(vfd->name));
vfd->fops = &vivid_radio_fops; vfd->fops = &vivid_radio_fops;
vfd->ioctl_ops = &vivid_ioctl_ops; vfd->ioctl_ops = &vivid_ioctl_ops;
vfd->device_caps = dev->radio_rx_caps;
vfd->release = video_device_release_empty; vfd->release = video_device_release_empty;
vfd->v4l2_dev = &dev->v4l2_dev; vfd->v4l2_dev = &dev->v4l2_dev;
vfd->lock = &dev->mutex; vfd->lock = &dev->mutex;
...@@ -1265,6 +1256,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst) ...@@ -1265,6 +1256,7 @@ static int vivid_create_instance(struct platform_device *pdev, int inst)
vfd->vfl_dir = VFL_DIR_TX; vfd->vfl_dir = VFL_DIR_TX;
vfd->fops = &vivid_radio_fops; vfd->fops = &vivid_radio_fops;
vfd->ioctl_ops = &vivid_ioctl_ops; vfd->ioctl_ops = &vivid_ioctl_ops;
vfd->device_caps = dev->radio_tx_caps;
vfd->release = video_device_release_empty; vfd->release = video_device_release_empty;
vfd->v4l2_dev = &dev->v4l2_dev; vfd->v4l2_dev = &dev->v4l2_dev;
vfd->lock = &dev->mutex; vfd->lock = &dev->mutex;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册