[media] v4l2: put VIDIOC_DBG_G_CHIP_NAME under ADV_DEBUG
Only enable this ioctl if the VIDEO_ADV_DEBUG config option is set. This prevents abuse from both userspace and kernelspace (some bridge drivers abuse DBG_G_CHIP_IDENT, lets prevent that from happening again with this ioctl). Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
		
					parent
					
						
							
								dfc2e12df0
							
						
					
				
			
			
				commit
				
					
						cd634f1bfc
					
				
			
		
					 5 changed files with 13 additions and 10 deletions
				
			
		|  | @ -63,6 +63,9 @@ card. Regular applications must not use it. When you found a chip | ||||||
| specific bug, please contact the linux-media mailing list (&v4l-ml;) | specific bug, please contact the linux-media mailing list (&v4l-ml;) | ||||||
| so it can be fixed.</para> | so it can be fixed.</para> | ||||||
| 
 | 
 | ||||||
|  |     <para>Additionally the Linux kernel must be compiled with the | ||||||
|  | <constant>CONFIG_VIDEO_ADV_DEBUG</constant> option to enable this ioctl.</para> | ||||||
|  | 
 | ||||||
|     <para>To query the driver applications must initialize the |     <para>To query the driver applications must initialize the | ||||||
| <structfield>match.type</structfield> and | <structfield>match.type</structfield> and | ||||||
| <structfield>match.addr</structfield> or <structfield>match.name</structfield> | <structfield>match.addr</structfield> or <structfield>match.name</structfield> | ||||||
|  |  | ||||||
|  | @ -1331,6 +1331,7 @@ static int vidioc_g_chip_ident(struct file *file, void *priv, | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||||||
| static int vidioc_g_chip_name(struct file *file, void *priv, | static int vidioc_g_chip_name(struct file *file, void *priv, | ||||||
| 	       struct v4l2_dbg_chip_name *chip) | 	       struct v4l2_dbg_chip_name *chip) | ||||||
| { | { | ||||||
|  | @ -1346,7 +1347,6 @@ static int vidioc_g_chip_name(struct file *file, void *priv, | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #ifdef CONFIG_VIDEO_ADV_DEBUG |  | ||||||
| static int em28xx_reg_len(int reg) | static int em28xx_reg_len(int reg) | ||||||
| { | { | ||||||
| 	switch (reg) { | 	switch (reg) { | ||||||
|  | @ -1796,8 +1796,8 @@ static const struct v4l2_ioctl_ops video_ioctl_ops = { | ||||||
| 	.vidioc_subscribe_event = v4l2_ctrl_subscribe_event, | 	.vidioc_subscribe_event = v4l2_ctrl_subscribe_event, | ||||||
| 	.vidioc_unsubscribe_event = v4l2_event_unsubscribe, | 	.vidioc_unsubscribe_event = v4l2_event_unsubscribe, | ||||||
| 	.vidioc_g_chip_ident        = vidioc_g_chip_ident, | 	.vidioc_g_chip_ident        = vidioc_g_chip_ident, | ||||||
| 	.vidioc_g_chip_name         = vidioc_g_chip_name, |  | ||||||
| #ifdef CONFIG_VIDEO_ADV_DEBUG | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||||||
|  | 	.vidioc_g_chip_name         = vidioc_g_chip_name, | ||||||
| 	.vidioc_g_register          = vidioc_g_register, | 	.vidioc_g_register          = vidioc_g_register, | ||||||
| 	.vidioc_s_register          = vidioc_s_register, | 	.vidioc_s_register          = vidioc_s_register, | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | @ -591,8 +591,8 @@ static void determine_valid_ioctls(struct video_device *vdev) | ||||||
| 	SET_VALID_IOCTL(ops, VIDIOC_G_FREQUENCY, vidioc_g_frequency); | 	SET_VALID_IOCTL(ops, VIDIOC_G_FREQUENCY, vidioc_g_frequency); | ||||||
| 	SET_VALID_IOCTL(ops, VIDIOC_S_FREQUENCY, vidioc_s_frequency); | 	SET_VALID_IOCTL(ops, VIDIOC_S_FREQUENCY, vidioc_s_frequency); | ||||||
| 	SET_VALID_IOCTL(ops, VIDIOC_LOG_STATUS, vidioc_log_status); | 	SET_VALID_IOCTL(ops, VIDIOC_LOG_STATUS, vidioc_log_status); | ||||||
| 	set_bit(_IOC_NR(VIDIOC_DBG_G_CHIP_NAME), valid_ioctls); |  | ||||||
| #ifdef CONFIG_VIDEO_ADV_DEBUG | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||||||
|  | 	set_bit(_IOC_NR(VIDIOC_DBG_G_CHIP_NAME), valid_ioctls); | ||||||
| 	set_bit(_IOC_NR(VIDIOC_DBG_G_REGISTER), valid_ioctls); | 	set_bit(_IOC_NR(VIDIOC_DBG_G_REGISTER), valid_ioctls); | ||||||
| 	set_bit(_IOC_NR(VIDIOC_DBG_S_REGISTER), valid_ioctls); | 	set_bit(_IOC_NR(VIDIOC_DBG_S_REGISTER), valid_ioctls); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | @ -1873,6 +1873,7 @@ static int v4l_dbg_g_chip_ident(const struct v4l2_ioctl_ops *ops, | ||||||
| static int v4l_dbg_g_chip_name(const struct v4l2_ioctl_ops *ops, | static int v4l_dbg_g_chip_name(const struct v4l2_ioctl_ops *ops, | ||||||
| 				struct file *file, void *fh, void *arg) | 				struct file *file, void *fh, void *arg) | ||||||
| { | { | ||||||
|  | #ifdef CONFIG_VIDEO_ADV_DEBUG | ||||||
| 	struct video_device *vfd = video_devdata(file); | 	struct video_device *vfd = video_devdata(file); | ||||||
| 	struct v4l2_dbg_chip_name *p = arg; | 	struct v4l2_dbg_chip_name *p = arg; | ||||||
| 	struct v4l2_subdev *sd; | 	struct v4l2_subdev *sd; | ||||||
|  | @ -1880,12 +1881,10 @@ static int v4l_dbg_g_chip_name(const struct v4l2_ioctl_ops *ops, | ||||||
| 
 | 
 | ||||||
| 	switch (p->match.type) { | 	switch (p->match.type) { | ||||||
| 	case V4L2_CHIP_MATCH_BRIDGE: | 	case V4L2_CHIP_MATCH_BRIDGE: | ||||||
| #ifdef CONFIG_VIDEO_ADV_DEBUG |  | ||||||
| 		if (ops->vidioc_s_register) | 		if (ops->vidioc_s_register) | ||||||
| 			p->flags |= V4L2_CHIP_FL_WRITABLE; | 			p->flags |= V4L2_CHIP_FL_WRITABLE; | ||||||
| 		if (ops->vidioc_g_register) | 		if (ops->vidioc_g_register) | ||||||
| 			p->flags |= V4L2_CHIP_FL_READABLE; | 			p->flags |= V4L2_CHIP_FL_READABLE; | ||||||
| #endif |  | ||||||
| 		if (ops->vidioc_g_chip_name) | 		if (ops->vidioc_g_chip_name) | ||||||
| 			return ops->vidioc_g_chip_name(file, fh, arg); | 			return ops->vidioc_g_chip_name(file, fh, arg); | ||||||
| 		if (p->match.addr) | 		if (p->match.addr) | ||||||
|  | @ -1904,12 +1903,10 @@ static int v4l_dbg_g_chip_name(const struct v4l2_ioctl_ops *ops, | ||||||
| 			break; | 			break; | ||||||
| 		v4l2_device_for_each_subdev(sd, vfd->v4l2_dev) { | 		v4l2_device_for_each_subdev(sd, vfd->v4l2_dev) { | ||||||
| 			if (v4l_dbg_found_match(&p->match, sd, idx++)) { | 			if (v4l_dbg_found_match(&p->match, sd, idx++)) { | ||||||
| #ifdef CONFIG_VIDEO_ADV_DEBUG |  | ||||||
| 				if (sd->ops->core && sd->ops->core->s_register) | 				if (sd->ops->core && sd->ops->core->s_register) | ||||||
| 					p->flags |= V4L2_CHIP_FL_WRITABLE; | 					p->flags |= V4L2_CHIP_FL_WRITABLE; | ||||||
| 				if (sd->ops->core && sd->ops->core->g_register) | 				if (sd->ops->core && sd->ops->core->g_register) | ||||||
| 					p->flags |= V4L2_CHIP_FL_READABLE; | 					p->flags |= V4L2_CHIP_FL_READABLE; | ||||||
| #endif |  | ||||||
| 				strlcpy(p->name, sd->name, sizeof(p->name)); | 				strlcpy(p->name, sd->name, sizeof(p->name)); | ||||||
| 				return 0; | 				return 0; | ||||||
| 			} | 			} | ||||||
|  | @ -1917,6 +1914,9 @@ static int v4l_dbg_g_chip_name(const struct v4l2_ioctl_ops *ops, | ||||||
| 		break; | 		break; | ||||||
| 	} | 	} | ||||||
| 	return -EINVAL; | 	return -EINVAL; | ||||||
|  | #else | ||||||
|  | 	return -ENOTTY; | ||||||
|  | #endif | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int v4l_dqevent(const struct v4l2_ioctl_ops *ops, | static int v4l_dqevent(const struct v4l2_ioctl_ops *ops, | ||||||
|  |  | ||||||
|  | @ -243,12 +243,12 @@ struct v4l2_ioctl_ops { | ||||||
| 					struct v4l2_dbg_register *reg); | 					struct v4l2_dbg_register *reg); | ||||||
| 	int (*vidioc_s_register)       (struct file *file, void *fh, | 	int (*vidioc_s_register)       (struct file *file, void *fh, | ||||||
| 					const struct v4l2_dbg_register *reg); | 					const struct v4l2_dbg_register *reg); | ||||||
| #endif |  | ||||||
| 	int (*vidioc_g_chip_ident)     (struct file *file, void *fh, |  | ||||||
| 					struct v4l2_dbg_chip_ident *chip); |  | ||||||
| 
 | 
 | ||||||
| 	int (*vidioc_g_chip_name)      (struct file *file, void *fh, | 	int (*vidioc_g_chip_name)      (struct file *file, void *fh, | ||||||
| 					struct v4l2_dbg_chip_name *chip); | 					struct v4l2_dbg_chip_name *chip); | ||||||
|  | #endif | ||||||
|  | 	int (*vidioc_g_chip_ident)     (struct file *file, void *fh, | ||||||
|  | 					struct v4l2_dbg_chip_ident *chip); | ||||||
| 
 | 
 | ||||||
| 	int (*vidioc_enum_framesizes)   (struct file *file, void *fh, | 	int (*vidioc_enum_framesizes)   (struct file *file, void *fh, | ||||||
| 					 struct v4l2_frmsizeenum *fsize); | 					 struct v4l2_frmsizeenum *fsize); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Hans Verkuil
				Hans Verkuil