return ret;
 }
 
+static int adv748x_csi2_get_mbus_config(struct v4l2_subdev *sd, unsigned int pad,
+                                       struct v4l2_mbus_config *config)
+{
+       struct adv748x_csi2 *tx = adv748x_sd_to_csi2(sd);
+
+       if (pad != ADV748X_CSI2_SOURCE)
+               return -EINVAL;
+
+       config->type = V4L2_MBUS_CSI2_DPHY;
+       switch (tx->active_lanes) {
+       case 1:
+               config->flags = V4L2_MBUS_CSI2_1_LANE;
+               break;
+
+       case 2:
+               config->flags = V4L2_MBUS_CSI2_2_LANE;
+               break;
+
+       case 3:
+               config->flags = V4L2_MBUS_CSI2_3_LANE;
+               break;
+
+       case 4:
+               config->flags = V4L2_MBUS_CSI2_4_LANE;
+               break;
+       }
+
+       return 0;
+}
+
 static const struct v4l2_subdev_pad_ops adv748x_csi2_pad_ops = {
        .get_fmt = adv748x_csi2_get_format,
        .set_fmt = adv748x_csi2_set_format,
+       .get_mbus_config = adv748x_csi2_get_mbus_config,
 };
 
 /* -----------------------------------------------------------------------------