struct v4l2_subdev_format *fmt)
 {
        struct cio2_queue *q = container_of(sd, struct cio2_queue, subdev);
-       struct v4l2_subdev_format format;
-       int ret;
 
-       if (fmt->which == V4L2_SUBDEV_FORMAT_TRY) {
+       if (fmt->which == V4L2_SUBDEV_FORMAT_TRY)
                fmt->format = *v4l2_subdev_get_try_format(sd, cfg, fmt->pad);
-               return 0;
-       }
-
-       if (fmt->pad == CIO2_PAD_SINK) {
-               format.which = V4L2_SUBDEV_FORMAT_ACTIVE;
-               ret = v4l2_subdev_call(sd, pad, get_fmt, NULL,
-                                      &format);
-
-               if (ret)
-                       return ret;
-               /* update colorspace etc */
-               q->subdev_fmt.colorspace = format.format.colorspace;
-               q->subdev_fmt.ycbcr_enc = format.format.ycbcr_enc;
-               q->subdev_fmt.quantization = format.format.quantization;
-               q->subdev_fmt.xfer_func = format.format.xfer_func;
-       }
-
-       fmt->format = q->subdev_fmt;
+       else
+               fmt->format = q->subdev_fmt;
 
        return 0;
 }