diff options
author | Trent Piepho <xyzzy@speakeasy.org> | 2007-01-23 20:38:13 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2007-02-21 10:34:55 -0500 |
commit | 52ebc763d8e0c9f2ab48af89a75e90e2318bac86 (patch) | |
tree | 5699ff9425fb1da30a18b00661fcea659ace6a72 /drivers/media/video/pvrusb2/pvrusb2-hdw.c | |
parent | dbbff48f39263f7e5c96a55624da87879de2bf71 (diff) |
V4L/DVB (5146): Make VIDIOC_INT_[SG]_REGISTER ioctls no longer internal only
The direct register access ioctls were defined as kernel internal only,
but they are very useful for debugging hardware from userspace and are
used as such. Officially export them.
VIDIOC_INT_[SG]_REGISTER is renamed to VIDIOC_DBG_[SG]_REGISTER
Definition of ioctl and struct v4l2_register is moved from v4l2-common.h
to videodev2.h.
Types used in struct v4l2_register are changed to the userspace
exportable versions (u32 -> __u32, etc).
Use of VIDIOC_DBG_S_REGISTER requires CAP_SYS_ADMIN permission, so move
the check into the video_ioctl2() dispatcher so it doesn't need to be
duplicated in each driver's call-back function. CAP_SYS_ADMIN check is
added to pvrusb2 (which doesn't use video_ioctl2).
Signed-off-by: Trent Piepho <xyzzy@speakeasy.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/video/pvrusb2/pvrusb2-hdw.c')
-rw-r--r-- | drivers/media/video/pvrusb2/pvrusb2-hdw.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/media/video/pvrusb2/pvrusb2-hdw.c b/drivers/media/video/pvrusb2/pvrusb2-hdw.c index 5e166ed19fc5..2a350755bd30 100644 --- a/drivers/media/video/pvrusb2/pvrusb2-hdw.c +++ b/drivers/media/video/pvrusb2/pvrusb2-hdw.c | |||
@@ -3277,7 +3277,7 @@ static int pvr2_hdw_get_eeprom_addr(struct pvr2_hdw *hdw) | |||
3277 | 3277 | ||
3278 | 3278 | ||
3279 | int pvr2_hdw_register_access(struct pvr2_hdw *hdw, | 3279 | int pvr2_hdw_register_access(struct pvr2_hdw *hdw, |
3280 | u32 chip_id,unsigned long reg_id, | 3280 | u32 chip_id, u32 reg_id, |
3281 | int setFl,u32 *val_ptr) | 3281 | int setFl,u32 *val_ptr) |
3282 | { | 3282 | { |
3283 | #ifdef CONFIG_VIDEO_ADV_DEBUG | 3283 | #ifdef CONFIG_VIDEO_ADV_DEBUG |
@@ -3295,8 +3295,8 @@ int pvr2_hdw_register_access(struct pvr2_hdw *hdw, | |||
3295 | cp = list_entry(item,struct pvr2_i2c_client,list); | 3295 | cp = list_entry(item,struct pvr2_i2c_client,list); |
3296 | if (cp->client->driver->id != chip_id) continue; | 3296 | if (cp->client->driver->id != chip_id) continue; |
3297 | stat = pvr2_i2c_client_cmd( | 3297 | stat = pvr2_i2c_client_cmd( |
3298 | cp,(setFl ? VIDIOC_INT_S_REGISTER : | 3298 | cp,(setFl ? VIDIOC_DBG_S_REGISTER : |
3299 | VIDIOC_INT_G_REGISTER),&req); | 3299 | VIDIOC_DBG_G_REGISTER),&req); |
3300 | if (!setFl) *val_ptr = req.val; | 3300 | if (!setFl) *val_ptr = req.val; |
3301 | okFl = !0; | 3301 | okFl = !0; |
3302 | break; | 3302 | break; |