 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From fc99206e967233b5460e132caa55381f20f9faae Mon Sep 17 00:00:00 2001
 | |
| From: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
 | |
| Date: Tue, 3 Oct 2023 13:59:02 +0300
 | |
| Subject: [PATCH 0782/1085] media: rp1: csi2: Use standard link_validate
 | |
| 
 | |
| The current csi2_link_validate() skips some important checks. Let's
 | |
| rather use the standard v4l2_subdev_link_validate_default() as the
 | |
| link_validate hook.
 | |
| 
 | |
| Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
 | |
| ---
 | |
|  .../media/platform/raspberrypi/rp1_cfe/csi2.c | 41 +------------------
 | |
|  1 file changed, 1 insertion(+), 40 deletions(-)
 | |
| 
 | |
| --- a/drivers/media/platform/raspberrypi/rp1_cfe/csi2.c
 | |
| +++ b/drivers/media/platform/raspberrypi/rp1_cfe/csi2.c
 | |
| @@ -462,11 +462,6 @@ void csi2_close_rx(struct csi2_device *c
 | |
|  	csi2_reg_write(csi2, CSI2_IRQ_MASK, 0);
 | |
|  }
 | |
|  
 | |
| -static struct csi2_device *to_csi2_device(struct v4l2_subdev *subdev)
 | |
| -{
 | |
| -	return container_of(subdev, struct csi2_device, sd);
 | |
| -}
 | |
| -
 | |
|  static int csi2_init_cfg(struct v4l2_subdev *sd,
 | |
|  			 struct v4l2_subdev_state *state)
 | |
|  {
 | |
| @@ -554,45 +549,11 @@ static int csi2_pad_set_fmt(struct v4l2_
 | |
|  	return 0;
 | |
|  }
 | |
|  
 | |
| -static int csi2_link_validate(struct v4l2_subdev *sd, struct media_link *link,
 | |
| -			      struct v4l2_subdev_format *source_fmt,
 | |
| -			      struct v4l2_subdev_format *sink_fmt)
 | |
| -{
 | |
| -	struct csi2_device *csi2 = to_csi2_device(sd);
 | |
| -
 | |
| -	csi2_dbg("%s: link \"%s\":%u -> \"%s\":%u\n", __func__,
 | |
| -		 link->source->entity->name, link->source->index,
 | |
| -		 link->sink->entity->name, link->sink->index);
 | |
| -
 | |
| -	if ((link->source->entity == &csi2->sd.entity &&
 | |
| -	     link->source->index == 1) ||
 | |
| -	    (link->sink->entity == &csi2->sd.entity &&
 | |
| -	     link->sink->index == 1)) {
 | |
| -		csi2_dbg("Ignore metadata pad for now\n");
 | |
| -		return 0;
 | |
| -	}
 | |
| -
 | |
| -	/* The width, height and code must match. */
 | |
| -	if (source_fmt->format.width != sink_fmt->format.width ||
 | |
| -	    source_fmt->format.width != sink_fmt->format.width ||
 | |
| -	    source_fmt->format.code != sink_fmt->format.code) {
 | |
| -		csi2_err("%s: format does not match (source %ux%u 0x%x, sink %ux%u 0x%x)\n",
 | |
| -			 __func__,
 | |
| -			 source_fmt->format.width, source_fmt->format.height,
 | |
| -			 source_fmt->format.code,
 | |
| -			 sink_fmt->format.width, sink_fmt->format.height,
 | |
| -			 sink_fmt->format.code);
 | |
| -		return -EPIPE;
 | |
| -	}
 | |
| -
 | |
| -	return 0;
 | |
| -}
 | |
| -
 | |
|  static const struct v4l2_subdev_pad_ops csi2_subdev_pad_ops = {
 | |
|  	.init_cfg = csi2_init_cfg,
 | |
|  	.get_fmt = v4l2_subdev_get_fmt,
 | |
|  	.set_fmt = csi2_pad_set_fmt,
 | |
| -	.link_validate = csi2_link_validate,
 | |
| +	.link_validate = v4l2_subdev_link_validate_default,
 | |
|  };
 | |
|  
 | |
|  static const struct media_entity_operations csi2_entity_ops = {
 |