mirror of
				https://github.com/Ysurac/openmptcprouter.git
				synced 2025-03-09 15:40:20 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			104 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 9a48e250947df4d220051c66da45ad62caa19e6a Mon Sep 17 00:00:00 2001
 | |
| From: Dave Stevenson <dave.stevenson@raspberrypi.com>
 | |
| Date: Sat, 12 Feb 2022 09:47:38 +0000
 | |
| Subject: [PATCH 744/828] media: i2c: ov7251: V4L2_CID_PIXEL_RATE is fixed
 | |
| 
 | |
| The pixel rate doesn't actually change based on the mode, and
 | |
| can not be set by userspace.
 | |
| 
 | |
| Fix the control. The control is already read only as set by the core.
 | |
| 
 | |
| Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com>
 | |
| ---
 | |
|  drivers/media/i2c/ov7251.c | 24 +++++-------------------
 | |
|  1 file changed, 5 insertions(+), 19 deletions(-)
 | |
| 
 | |
| --- a/drivers/media/i2c/ov7251.c
 | |
| +++ b/drivers/media/i2c/ov7251.c
 | |
| @@ -54,6 +54,8 @@
 | |
|  #define OV7251_PLL2_SYS_DIV_REG		0x309a
 | |
|  #define OV7251_PLL2_ADC_DIV_REG		0x309b
 | |
|  
 | |
| +#define OV7251_PIXEL_CLOCK 48000000
 | |
| +
 | |
|  struct reg_value {
 | |
|  	u16 reg;
 | |
|  	u8 val;
 | |
| @@ -64,7 +66,6 @@ struct ov7251_mode_info {
 | |
|  	u32 height;
 | |
|  	const struct reg_value *data;
 | |
|  	u32 data_size;
 | |
| -	u32 pixel_clock;
 | |
|  	u32 link_freq;
 | |
|  	u16 exposure_max;
 | |
|  	u16 exposure_def;
 | |
| @@ -112,7 +113,6 @@ struct ov7251 {
 | |
|  	const struct ov7251_mode_info *current_mode;
 | |
|  
 | |
|  	struct v4l2_ctrl_handler ctrls;
 | |
| -	struct v4l2_ctrl *pixel_clock;
 | |
|  	struct v4l2_ctrl *link_freq;
 | |
|  	struct v4l2_ctrl *exposure;
 | |
|  	struct v4l2_ctrl *gain;
 | |
| @@ -591,7 +591,6 @@ static const struct ov7251_mode_info ov7
 | |
|  		.height = 480,
 | |
|  		.data = ov7251_setting_vga_30fps,
 | |
|  		.data_size = ARRAY_SIZE(ov7251_setting_vga_30fps),
 | |
| -		.pixel_clock = 48000000,
 | |
|  		.link_freq = 0, /* an index in link_freq[] */
 | |
|  		.exposure_max = 1704,
 | |
|  		.exposure_def = 504,
 | |
| @@ -605,7 +604,6 @@ static const struct ov7251_mode_info ov7
 | |
|  		.height = 480,
 | |
|  		.data = ov7251_setting_vga_60fps,
 | |
|  		.data_size = ARRAY_SIZE(ov7251_setting_vga_60fps),
 | |
| -		.pixel_clock = 48000000,
 | |
|  		.link_freq = 0, /* an index in link_freq[] */
 | |
|  		.exposure_max = 840,
 | |
|  		.exposure_def = 504,
 | |
| @@ -619,7 +617,6 @@ static const struct ov7251_mode_info ov7
 | |
|  		.height = 480,
 | |
|  		.data = ov7251_setting_vga_90fps,
 | |
|  		.data_size = ARRAY_SIZE(ov7251_setting_vga_90fps),
 | |
| -		.pixel_clock = 48000000,
 | |
|  		.link_freq = 0, /* an index in link_freq[] */
 | |
|  		.exposure_max = 552,
 | |
|  		.exposure_def = 504,
 | |
| @@ -1155,11 +1152,6 @@ static int ov7251_set_format(struct v4l2
 | |
|  	__crop->height = new_mode->height;
 | |
|  
 | |
|  	if (format->which == V4L2_SUBDEV_FORMAT_ACTIVE) {
 | |
| -		ret = __v4l2_ctrl_s_ctrl_int64(ov7251->pixel_clock,
 | |
| -					       new_mode->pixel_clock);
 | |
| -		if (ret < 0)
 | |
| -			goto exit;
 | |
| -
 | |
|  		ret = __v4l2_ctrl_s_ctrl(ov7251->link_freq,
 | |
|  					 new_mode->link_freq);
 | |
|  		if (ret < 0)
 | |
| @@ -1319,11 +1311,6 @@ static int ov7251_set_frame_interval(str
 | |
|  	new_mode = ov7251_find_mode_by_ival(ov7251, &fi->interval);
 | |
|  
 | |
|  	if (new_mode != ov7251->current_mode) {
 | |
| -		ret = __v4l2_ctrl_s_ctrl_int64(ov7251->pixel_clock,
 | |
| -					       new_mode->pixel_clock);
 | |
| -		if (ret < 0)
 | |
| -			goto exit;
 | |
| -
 | |
|  		ret = __v4l2_ctrl_s_ctrl(ov7251->link_freq,
 | |
|  					 new_mode->link_freq);
 | |
|  		if (ret < 0)
 | |
| @@ -1571,10 +1558,9 @@ static int ov7251_probe(struct i2c_clien
 | |
|  				     V4L2_CID_TEST_PATTERN,
 | |
|  				     ARRAY_SIZE(ov7251_test_pattern_menu) - 1,
 | |
|  				     0, 0, ov7251_test_pattern_menu);
 | |
| -	ov7251->pixel_clock = v4l2_ctrl_new_std(&ov7251->ctrls,
 | |
| -						&ov7251_ctrl_ops,
 | |
| -						V4L2_CID_PIXEL_RATE,
 | |
| -						1, INT_MAX, 1, 1);
 | |
| +	v4l2_ctrl_new_std(&ov7251->ctrls, &ov7251_ctrl_ops,
 | |
| +			  V4L2_CID_PIXEL_RATE, OV7251_PIXEL_CLOCK,
 | |
| +			  OV7251_PIXEL_CLOCK, 1, OV7251_PIXEL_CLOCK);
 | |
|  	ov7251->link_freq = v4l2_ctrl_new_int_menu(&ov7251->ctrls,
 | |
|  						   &ov7251_ctrl_ops,
 | |
|  						   V4L2_CID_LINK_FREQ,
 |