Hi Hans,

Thank you for the patch.

On Wed, Jun 26, 2019 at 11:58:02AM +0200, Hans Verkuil wrote:
> The priv field of struct v4l2_pix_format shouldn't be set by drivers,
> it's set by the v4l2 core instead to V4L2_PIX_FMT_PRIV_MAGIC.
> 
> Drop this from the few media drivers that still do this.
> 
> Note that the gspca patch is slightly more involved since some of the
> sub-gspca drivers use the priv field internally.

Do they use it in a non-standard way towards userspace, or just for
communication with the gspca driver within the kernel ? In the former
case, are you aware of applications using that ?

> Signed-off-by: Hans Verkuil <hverkuil-ci...@xs4all.nl>

For everything but gspca,

Reviewed-by: Laurent Pinchart <laurent.pinch...@ideasonboard.com>

> ---
> diff --git a/drivers/media/pci/cobalt/cobalt-v4l2.c 
> b/drivers/media/pci/cobalt/cobalt-v4l2.c
> index 39dabd4da60f..c8cd4c407540 100644
> --- a/drivers/media/pci/cobalt/cobalt-v4l2.c
> +++ b/drivers/media/pci/cobalt/cobalt-v4l2.c
> @@ -788,7 +788,6 @@ static int cobalt_try_fmt_vid_cap(struct file *file, void 
> *priv_fh,
> 
>       pix->sizeimage = pix->bytesperline * pix->height;
>       pix->field = V4L2_FIELD_NONE;
> -     pix->priv = 0;
> 
>       return 0;
>  }
> diff --git a/drivers/media/pci/solo6x10/solo6x10-v4l2-enc.c 
> b/drivers/media/pci/solo6x10/solo6x10-v4l2-enc.c
> index 609100a46ff8..88e0cb0bf592 100644
> --- a/drivers/media/pci/solo6x10/solo6x10-v4l2-enc.c
> +++ b/drivers/media/pci/solo6x10/solo6x10-v4l2-enc.c
> @@ -886,7 +886,6 @@ static int solo_enc_try_fmt_cap(struct file *file, void 
> *priv,
>       pix->colorspace = V4L2_COLORSPACE_SMPTE170M;
>       pix->sizeimage = FRAME_BUF_SIZE;
>       pix->bytesperline = 0;
> -     pix->priv = 0;
> 
>       return 0;
>  }
> @@ -941,7 +940,6 @@ static int solo_enc_get_fmt_cap(struct file *file, void 
> *priv,
>                    V4L2_FIELD_NONE;
>       pix->sizeimage = FRAME_BUF_SIZE;
>       pix->colorspace = V4L2_COLORSPACE_SMPTE170M;
> -     pix->priv = 0;
> 
>       return 0;
>  }
> diff --git a/drivers/media/pci/solo6x10/solo6x10-v4l2.c 
> b/drivers/media/pci/solo6x10/solo6x10-v4l2.c
> index a968f75920b5..a670fe8e4f9c 100644
> --- a/drivers/media/pci/solo6x10/solo6x10-v4l2.c
> +++ b/drivers/media/pci/solo6x10/solo6x10-v4l2.c
> @@ -479,7 +479,6 @@ static int solo_try_fmt_cap(struct file *file, void *priv,
>       pix->field = V4L2_FIELD_INTERLACED;
>       pix->pixelformat = V4L2_PIX_FMT_UYVY;
>       pix->colorspace = V4L2_COLORSPACE_SMPTE170M;
> -     pix->priv = 0;
>       return 0;
>  }
> 
> @@ -509,7 +508,6 @@ static int solo_get_fmt_cap(struct file *file, void *priv,
>       pix->sizeimage = solo_image_size(solo_dev);
>       pix->colorspace = V4L2_COLORSPACE_SMPTE170M;
>       pix->bytesperline = solo_bytesperline(solo_dev);
> -     pix->priv = 0;
> 
>       return 0;
>  }
> diff --git a/drivers/media/pci/tw68/tw68-video.c 
> b/drivers/media/pci/tw68/tw68-video.c
> index 8e0952d65ad4..d0c2ec70f9cd 100644
> --- a/drivers/media/pci/tw68/tw68-video.c
> +++ b/drivers/media/pci/tw68/tw68-video.c
> @@ -592,7 +592,6 @@ static int tw68_g_fmt_vid_cap(struct file *file, void 
> *priv,
>       f->fmt.pix.sizeimage =
>               f->fmt.pix.height * f->fmt.pix.bytesperline;
>       f->fmt.pix.colorspace   = V4L2_COLORSPACE_SMPTE170M;
> -     f->fmt.pix.priv = 0;
>       return 0;
>  }
> 
> diff --git a/drivers/media/platform/davinci/vpif_capture.c 
> b/drivers/media/platform/davinci/vpif_capture.c
> index f0f7ef638c56..21a2ba797d0a 100644
> --- a/drivers/media/platform/davinci/vpif_capture.c
> +++ b/drivers/media/platform/davinci/vpif_capture.c
> @@ -979,7 +979,6 @@ static int vpif_try_fmt_vid_cap(struct file *file, void 
> *priv,
>               pixfmt->bytesperline = common->fmt.fmt.pix.width * 2;
>               pixfmt->sizeimage = pixfmt->bytesperline * pixfmt->height;
>       }
> -     pixfmt->priv = 0;
> 
>       dev_dbg(vpif_dev, "%s: %d x %d; pitch=%d pixelformat=0x%08x, field=%d, 
> size=%d\n", __func__,
>               pixfmt->width, pixfmt->height,
> diff --git a/drivers/media/usb/au0828/au0828-video.c 
> b/drivers/media/usb/au0828/au0828-video.c
> index 5e00019bce8a..37acfcb56822 100644
> --- a/drivers/media/usb/au0828/au0828-video.c
> +++ b/drivers/media/usb/au0828/au0828-video.c
> @@ -1153,7 +1153,6 @@ static int au0828_set_format(struct au0828_dev *dev, 
> unsigned int cmd,
>       format->fmt.pix.sizeimage = width * height * 2;
>       format->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M;
>       format->fmt.pix.field = V4L2_FIELD_INTERLACED;
> -     format->fmt.pix.priv = 0;
> 
>       if (cmd == VIDIOC_TRY_FMT)
>               return 0;
> @@ -1231,7 +1230,6 @@ static int vidioc_g_fmt_vid_cap(struct file *file, void 
> *priv,
>       f->fmt.pix.sizeimage = dev->frame_size;
>       f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M; /* NTSC/PAL */
>       f->fmt.pix.field = V4L2_FIELD_INTERLACED;
> -     f->fmt.pix.priv = 0;
>       return 0;
>  }
> 
> diff --git a/drivers/media/usb/cpia2/cpia2_v4l.c 
> b/drivers/media/usb/cpia2/cpia2_v4l.c
> index 0feae825cebb..9232461669c8 100644
> --- a/drivers/media/usb/cpia2/cpia2_v4l.c
> +++ b/drivers/media/usb/cpia2/cpia2_v4l.c
> @@ -338,7 +338,6 @@ static int cpia2_try_fmt_vid_cap(struct file *file, void 
> *fh,
>       f->fmt.pix.bytesperline = 0;
>       f->fmt.pix.sizeimage = cam->frame_size;
>       f->fmt.pix.colorspace = V4L2_COLORSPACE_JPEG;
> -     f->fmt.pix.priv = 0;
> 
>       switch (cpia2_match_video_size(f->fmt.pix.width, f->fmt.pix.height)) {
>       case VIDEOSIZE_VGA:
> @@ -449,7 +448,6 @@ static int cpia2_g_fmt_vid_cap(struct file *file, void 
> *fh,
>       f->fmt.pix.bytesperline = 0;
>       f->fmt.pix.sizeimage = cam->frame_size;
>       f->fmt.pix.colorspace = V4L2_COLORSPACE_JPEG;
> -     f->fmt.pix.priv = 0;
> 
>       return 0;
>  }
> diff --git a/drivers/media/usb/em28xx/em28xx-video.c 
> b/drivers/media/usb/em28xx/em28xx-video.c
> index 0512e1959394..9a6956813259 100644
> --- a/drivers/media/usb/em28xx/em28xx-video.c
> +++ b/drivers/media/usb/em28xx/em28xx-video.c
> @@ -1517,7 +1517,6 @@ static int vidioc_try_fmt_vid_cap(struct file *file, 
> void *priv,
>       else
>               f->fmt.pix.field = v4l2->interlaced_fieldmode ?
>                          V4L2_FIELD_INTERLACED : V4L2_FIELD_TOP;
> -     f->fmt.pix.priv = 0;
> 
>       return 0;
>  }
> diff --git a/drivers/media/usb/gspca/gspca.c b/drivers/media/usb/gspca/gspca.c
> index be11f7830bca..072d280c1824 100644
> --- a/drivers/media/usb/gspca/gspca.c
> +++ b/drivers/media/usb/gspca/gspca.c
> @@ -1040,11 +1040,11 @@ static int vidioc_g_fmt_vid_cap(struct file *file, 
> void *priv,
>                           struct v4l2_format *fmt)
>  {
>       struct gspca_dev *gspca_dev = video_drvdata(file);
> +     u32 priv = fmt->fmt.pix.priv;
> 
>       fmt->fmt.pix = gspca_dev->pixfmt;
> -     /* some drivers use priv internally, zero it before giving it back to
> -        the core */
> -     fmt->fmt.pix.priv = 0;
> +     /* some drivers use priv internally, so keep the original value */
> +     fmt->fmt.pix.priv = priv;
>       return 0;
>  }
> 
> @@ -1079,9 +1079,6 @@ static int try_fmt_vid_cap(struct gspca_dev *gspca_dev,
>               fmt->fmt.pix.height = h;
>               gspca_dev->sd_desc->try_fmt(gspca_dev, fmt);
>       }
> -     /* some drivers use priv internally, zero it before giving it back to
> -        the core */
> -     fmt->fmt.pix.priv = 0;
>       return mode;                    /* used when s_fmt */
>  }
> 
> @@ -1090,9 +1087,12 @@ static int vidioc_try_fmt_vid_cap(struct file *file,
>                             struct v4l2_format *fmt)
>  {
>       struct gspca_dev *gspca_dev = video_drvdata(file);
> +     u32 priv = fmt->fmt.pix.priv;
> 
>       if (try_fmt_vid_cap(gspca_dev, fmt) < 0)
>               return -EINVAL;
> +     /* some drivers use priv internally, so keep the original value */
> +     fmt->fmt.pix.priv = priv;
>       return 0;
>  }
> 
> @@ -1100,6 +1100,7 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void 
> *priv,
>                           struct v4l2_format *fmt)
>  {
>       struct gspca_dev *gspca_dev = video_drvdata(file);
> +     u32 priv = fmt->fmt.pix.priv;
>       int mode;
> 
>       if (vb2_is_busy(&gspca_dev->queue))
> @@ -1115,6 +1116,8 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void 
> *priv,
>               gspca_dev->pixfmt = fmt->fmt.pix;
>       else
>               gspca_dev->pixfmt = gspca_dev->cam.cam_mode[mode];
> +     /* some drivers use priv internally, so keep the original value */
> +     fmt->fmt.pix.priv = priv;
>       return 0;
>  }
> 
> diff --git a/drivers/media/usb/s2255/s2255drv.c 
> b/drivers/media/usb/s2255/s2255drv.c
> index aa90558479f7..1a5b46c6992b 100644
> --- a/drivers/media/usb/s2255/s2255drv.c
> +++ b/drivers/media/usb/s2255/s2255drv.c
> @@ -759,7 +759,6 @@ static int vidioc_g_fmt_vid_cap(struct file *file, void 
> *priv,
>       f->fmt.pix.bytesperline = f->fmt.pix.width * (vc->fmt->depth >> 3);
>       f->fmt.pix.sizeimage = f->fmt.pix.height * f->fmt.pix.bytesperline;
>       f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M;
> -     f->fmt.pix.priv = 0;
>       return 0;
>  }
> 
> @@ -811,7 +810,6 @@ static int vidioc_try_fmt_vid_cap(struct file *file, void 
> *priv,
>       f->fmt.pix.bytesperline = (f->fmt.pix.width * fmt->depth) >> 3;
>       f->fmt.pix.sizeimage = f->fmt.pix.height * f->fmt.pix.bytesperline;
>       f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M;
> -     f->fmt.pix.priv = 0;
>       dprintk(vc->dev, 50, "%s: set width %d height %d field %d\n", __func__,
>               f->fmt.pix.width, f->fmt.pix.height, f->fmt.pix.field);
>       return 0;
> diff --git a/drivers/media/usb/uvc/uvc_v4l2.c 
> b/drivers/media/usb/uvc/uvc_v4l2.c
> index 203329cadbc4..0335e69b70ab 100644
> --- a/drivers/media/usb/uvc/uvc_v4l2.c
> +++ b/drivers/media/usb/uvc/uvc_v4l2.c
> @@ -253,7 +253,6 @@ static int uvc_v4l2_try_format(struct uvc_streaming 
> *stream,
>       fmt->fmt.pix.bytesperline = uvc_v4l2_get_bytesperline(format, frame);
>       fmt->fmt.pix.sizeimage = probe->dwMaxVideoFrameSize;
>       fmt->fmt.pix.colorspace = format->colorspace;
> -     fmt->fmt.pix.priv = 0;
> 
>       if (uvc_format != NULL)
>               *uvc_format = format;
> @@ -290,7 +289,6 @@ static int uvc_v4l2_get_format(struct uvc_streaming 
> *stream,
>       fmt->fmt.pix.bytesperline = uvc_v4l2_get_bytesperline(format, frame);
>       fmt->fmt.pix.sizeimage = stream->ctrl.dwMaxVideoFrameSize;
>       fmt->fmt.pix.colorspace = format->colorspace;
> -     fmt->fmt.pix.priv = 0;
> 
>  done:
>       mutex_unlock(&stream->mutex);

-- 
Regards,

Laurent Pinchart

Reply via email to