Commit ed4c5fa4 authored by Ricardo Ribalda's avatar Ricardo Ribalda Committed by Mauro Carvalho Chehab

media: uvcvideo: use dev_printk() for uvc_trace()

Instead of calling prink() inside uvc_trace, use dev_printk(), which adds
context to the output.

Now that we are at it, regroup the strings so the messages can be easily
"grepable".
Suggested-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarRicardo Ribalda <ribalda@chromium.org>
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent 59e92bf6
...@@ -906,8 +906,8 @@ static struct uvc_control *uvc_find_control(struct uvc_video_chain *chain, ...@@ -906,8 +906,8 @@ static struct uvc_control *uvc_find_control(struct uvc_video_chain *chain,
} }
if (ctrl == NULL && !next) if (ctrl == NULL && !next)
uvc_trace(UVC_TRACE_CONTROL, "Control 0x%08x not found.\n", uvc_trace(chain->dev, UVC_TRACE_CONTROL,
v4l2_id); "Control 0x%08x not found.\n", v4l2_id);
return ctrl; return ctrl;
} }
...@@ -1800,9 +1800,9 @@ static int uvc_ctrl_fill_xu_info(struct uvc_device *dev, ...@@ -1800,9 +1800,9 @@ static int uvc_ctrl_fill_xu_info(struct uvc_device *dev,
ret = uvc_query_ctrl(dev, UVC_GET_LEN, ctrl->entity->id, dev->intfnum, ret = uvc_query_ctrl(dev, UVC_GET_LEN, ctrl->entity->id, dev->intfnum,
info->selector, data, 2); info->selector, data, 2);
if (ret < 0) { if (ret < 0) {
uvc_trace(UVC_TRACE_CONTROL, uvc_trace(dev, UVC_TRACE_CONTROL,
"GET_LEN failed on control %pUl/%u (%d).\n", "GET_LEN failed on control %pUl/%u (%d).\n",
info->entity, info->selector, ret); info->entity, info->selector, ret);
goto done; goto done;
} }
...@@ -1813,7 +1813,7 @@ static int uvc_ctrl_fill_xu_info(struct uvc_device *dev, ...@@ -1813,7 +1813,7 @@ static int uvc_ctrl_fill_xu_info(struct uvc_device *dev,
ret = uvc_ctrl_get_flags(dev, ctrl, info); ret = uvc_ctrl_get_flags(dev, ctrl, info);
if (ret < 0) { if (ret < 0) {
uvc_trace(UVC_TRACE_CONTROL, uvc_trace(dev, UVC_TRACE_CONTROL,
"Failed to get flags for control %pUl/%u (%d).\n", "Failed to get flags for control %pUl/%u (%d).\n",
info->entity, info->selector, ret); info->entity, info->selector, ret);
goto done; goto done;
...@@ -1821,8 +1821,8 @@ static int uvc_ctrl_fill_xu_info(struct uvc_device *dev, ...@@ -1821,8 +1821,8 @@ static int uvc_ctrl_fill_xu_info(struct uvc_device *dev,
uvc_ctrl_fixup_xu_info(dev, ctrl, info); uvc_ctrl_fixup_xu_info(dev, ctrl, info);
uvc_trace(UVC_TRACE_CONTROL, "XU control %pUl/%u queried: len %u, " uvc_trace(dev, UVC_TRACE_CONTROL,
"flags { get %u set %u auto %u }.\n", "XU control %pUl/%u queried: len %u, flags { get %u set %u auto %u }.\n",
info->entity, info->selector, info->size, info->entity, info->selector, info->size,
(info->flags & UVC_CTRL_FLAG_GET_CUR) ? 1 : 0, (info->flags & UVC_CTRL_FLAG_GET_CUR) ? 1 : 0,
(info->flags & UVC_CTRL_FLAG_SET_CUR) ? 1 : 0, (info->flags & UVC_CTRL_FLAG_SET_CUR) ? 1 : 0,
...@@ -1851,9 +1851,10 @@ static int uvc_ctrl_init_xu_ctrl(struct uvc_device *dev, ...@@ -1851,9 +1851,10 @@ static int uvc_ctrl_init_xu_ctrl(struct uvc_device *dev,
ret = uvc_ctrl_add_info(dev, ctrl, &info); ret = uvc_ctrl_add_info(dev, ctrl, &info);
if (ret < 0) if (ret < 0)
uvc_trace(UVC_TRACE_CONTROL, "Failed to initialize control " uvc_trace(dev, UVC_TRACE_CONTROL,
"%pUl/%u on device %s entity %u\n", info.entity, "Failed to initialize control %pUl/%u on device %s entity %u\n",
info.selector, dev->udev->devpath, ctrl->entity->id); info.entity, info.selector, dev->udev->devpath,
ctrl->entity->id);
return ret; return ret;
} }
...@@ -1881,8 +1882,8 @@ int uvc_xu_ctrl_query(struct uvc_video_chain *chain, ...@@ -1881,8 +1882,8 @@ int uvc_xu_ctrl_query(struct uvc_video_chain *chain,
} }
if (!found) { if (!found) {
uvc_trace(UVC_TRACE_CONTROL, "Extension unit %u not found.\n", uvc_trace(chain->dev, UVC_TRACE_CONTROL,
xqry->unit); "Extension unit %u not found.\n", xqry->unit);
return -ENOENT; return -ENOENT;
} }
...@@ -1897,8 +1898,9 @@ int uvc_xu_ctrl_query(struct uvc_video_chain *chain, ...@@ -1897,8 +1898,9 @@ int uvc_xu_ctrl_query(struct uvc_video_chain *chain,
} }
if (!found) { if (!found) {
uvc_trace(UVC_TRACE_CONTROL, "Control %pUl/%u not found.\n", uvc_trace(chain->dev, UVC_TRACE_CONTROL,
entity->guid, xqry->selector); "Control %pUl/%u not found.\n", entity->guid,
xqry->selector);
return -ENOENT; return -ENOENT;
} }
...@@ -2046,9 +2048,10 @@ static int uvc_ctrl_add_info(struct uvc_device *dev, struct uvc_control *ctrl, ...@@ -2046,9 +2048,10 @@ static int uvc_ctrl_add_info(struct uvc_device *dev, struct uvc_control *ctrl,
ctrl->initialized = 1; ctrl->initialized = 1;
uvc_trace(UVC_TRACE_CONTROL, "Added control %pUl/%u to device %s " uvc_trace(dev, UVC_TRACE_CONTROL,
"entity %u\n", ctrl->info.entity, ctrl->info.selector, "Added control %pUl/%u to device %s entity %u\n",
dev->udev->devpath, ctrl->entity->id); ctrl->info.entity, ctrl->info.selector, dev->udev->devpath,
ctrl->entity->id);
return 0; return 0;
} }
...@@ -2085,9 +2088,9 @@ static int __uvc_ctrl_add_mapping(struct uvc_device *dev, ...@@ -2085,9 +2088,9 @@ static int __uvc_ctrl_add_mapping(struct uvc_device *dev,
map->set = uvc_set_le_value; map->set = uvc_set_le_value;
list_add_tail(&map->list, &ctrl->info.mappings); list_add_tail(&map->list, &ctrl->info.mappings);
uvc_trace(UVC_TRACE_CONTROL, uvc_trace(dev, UVC_TRACE_CONTROL,
"Adding mapping '%s' to control %pUl/%u.\n", "Adding mapping '%s' to control %pUl/%u.\n",
map->name, ctrl->info.entity, ctrl->info.selector); map->name, ctrl->info.entity, ctrl->info.selector);
return 0; return 0;
} }
...@@ -2103,9 +2106,9 @@ int uvc_ctrl_add_mapping(struct uvc_video_chain *chain, ...@@ -2103,9 +2106,9 @@ int uvc_ctrl_add_mapping(struct uvc_video_chain *chain,
int ret; int ret;
if (mapping->id & ~V4L2_CTRL_ID_MASK) { if (mapping->id & ~V4L2_CTRL_ID_MASK) {
uvc_trace(UVC_TRACE_CONTROL, "Can't add mapping '%s', control " uvc_trace(dev, UVC_TRACE_CONTROL,
"id 0x%08x is invalid.\n", mapping->name, "Can't add mapping '%s', control id 0x%08x is invalid.\n",
mapping->id); mapping->name, mapping->id);
return -EINVAL; return -EINVAL;
} }
...@@ -2150,9 +2153,9 @@ int uvc_ctrl_add_mapping(struct uvc_video_chain *chain, ...@@ -2150,9 +2153,9 @@ int uvc_ctrl_add_mapping(struct uvc_video_chain *chain,
list_for_each_entry(map, &ctrl->info.mappings, list) { list_for_each_entry(map, &ctrl->info.mappings, list) {
if (mapping->id == map->id) { if (mapping->id == map->id) {
uvc_trace(UVC_TRACE_CONTROL, "Can't add mapping '%s', " uvc_trace(dev, UVC_TRACE_CONTROL,
"control id 0x%08x already exists.\n", "Can't add mapping '%s', control id 0x%08x already exists.\n",
mapping->name, mapping->id); mapping->name, mapping->id);
ret = -EEXIST; ret = -EEXIST;
goto done; goto done;
} }
...@@ -2161,9 +2164,9 @@ int uvc_ctrl_add_mapping(struct uvc_video_chain *chain, ...@@ -2161,9 +2164,9 @@ int uvc_ctrl_add_mapping(struct uvc_video_chain *chain,
/* Prevent excess memory consumption */ /* Prevent excess memory consumption */
if (atomic_inc_return(&dev->nmappings) > UVC_MAX_CONTROL_MAPPINGS) { if (atomic_inc_return(&dev->nmappings) > UVC_MAX_CONTROL_MAPPINGS) {
atomic_dec(&dev->nmappings); atomic_dec(&dev->nmappings);
uvc_trace(UVC_TRACE_CONTROL, "Can't add mapping '%s', maximum " uvc_trace(dev, UVC_TRACE_CONTROL,
"mappings count (%u) exceeded.\n", mapping->name, "Can't add mapping '%s', maximum mappings count (%u) exceeded.\n",
UVC_MAX_CONTROL_MAPPINGS); mapping->name, UVC_MAX_CONTROL_MAPPINGS);
ret = -ENOMEM; ret = -ENOMEM;
goto done; goto done;
} }
...@@ -2232,8 +2235,9 @@ static void uvc_ctrl_prune_entity(struct uvc_device *dev, ...@@ -2232,8 +2235,9 @@ static void uvc_ctrl_prune_entity(struct uvc_device *dev,
!uvc_test_bit(controls, blacklist[i].index)) !uvc_test_bit(controls, blacklist[i].index))
continue; continue;
uvc_trace(UVC_TRACE_CONTROL, "%u/%u control is black listed, " uvc_trace(dev, UVC_TRACE_CONTROL,
"removing it.\n", entity->id, blacklist[i].index); "%u/%u control is black listed, removing it.\n",
entity->id, blacklist[i].index);
uvc_clear_bit(controls, blacklist[i].index); uvc_clear_bit(controls, blacklist[i].index);
} }
......
This diff is collapsed.
...@@ -40,6 +40,7 @@ static int isight_decode(struct uvc_video_queue *queue, struct uvc_buffer *buf, ...@@ -40,6 +40,7 @@ static int isight_decode(struct uvc_video_queue *queue, struct uvc_buffer *buf,
0xde, 0xad, 0xfa, 0xce 0xde, 0xad, 0xfa, 0xce
}; };
struct uvc_streaming *stream = uvc_queue_to_stream(queue);
unsigned int maxlen, nbytes; unsigned int maxlen, nbytes;
u8 *mem; u8 *mem;
int is_header = 0; int is_header = 0;
...@@ -49,15 +50,16 @@ static int isight_decode(struct uvc_video_queue *queue, struct uvc_buffer *buf, ...@@ -49,15 +50,16 @@ static int isight_decode(struct uvc_video_queue *queue, struct uvc_buffer *buf,
if ((len >= 14 && memcmp(&data[2], hdr, 12) == 0) || if ((len >= 14 && memcmp(&data[2], hdr, 12) == 0) ||
(len >= 15 && memcmp(&data[3], hdr, 12) == 0)) { (len >= 15 && memcmp(&data[3], hdr, 12) == 0)) {
uvc_trace(UVC_TRACE_FRAME, "iSight header found\n"); uvc_trace(stream->dev, UVC_TRACE_FRAME,
"iSight header found\n");
is_header = 1; is_header = 1;
} }
/* Synchronize to the input stream by waiting for a header packet. */ /* Synchronize to the input stream by waiting for a header packet. */
if (buf->state != UVC_BUF_STATE_ACTIVE) { if (buf->state != UVC_BUF_STATE_ACTIVE) {
if (!is_header) { if (!is_header) {
uvc_trace(UVC_TRACE_FRAME, "Dropping packet (out of " uvc_trace(stream->dev, UVC_TRACE_FRAME,
"sync).\n"); "Dropping packet (out of sync).\n");
return 0; return 0;
} }
...@@ -85,8 +87,8 @@ static int isight_decode(struct uvc_video_queue *queue, struct uvc_buffer *buf, ...@@ -85,8 +87,8 @@ static int isight_decode(struct uvc_video_queue *queue, struct uvc_buffer *buf,
buf->bytesused += nbytes; buf->bytesused += nbytes;
if (len > maxlen || buf->bytesused == buf->length) { if (len > maxlen || buf->bytesused == buf->length) {
uvc_trace(UVC_TRACE_FRAME, "Frame complete " uvc_trace(stream->dev, UVC_TRACE_FRAME,
"(overflow).\n"); "Frame complete (overflow).\n");
buf->state = UVC_BUF_STATE_DONE; buf->state = UVC_BUF_STATE_DONE;
} }
} }
...@@ -103,8 +105,8 @@ void uvc_video_decode_isight(struct uvc_urb *uvc_urb, struct uvc_buffer *buf, ...@@ -103,8 +105,8 @@ void uvc_video_decode_isight(struct uvc_urb *uvc_urb, struct uvc_buffer *buf,
for (i = 0; i < urb->number_of_packets; ++i) { for (i = 0; i < urb->number_of_packets; ++i) {
if (urb->iso_frame_desc[i].status < 0) { if (urb->iso_frame_desc[i].status < 0) {
uvc_trace(UVC_TRACE_FRAME, "USB isochronous frame " uvc_trace(stream->dev, UVC_TRACE_FRAME,
"lost (%d).\n", "USB isochronous frame lost (%d).\n",
urb->iso_frame_desc[i].status); urb->iso_frame_desc[i].status);
} }
......
...@@ -32,12 +32,6 @@ ...@@ -32,12 +32,6 @@
* the driver. * the driver.
*/ */
static inline struct uvc_streaming *
uvc_queue_to_stream(struct uvc_video_queue *queue)
{
return container_of(queue, struct uvc_streaming, queue);
}
static inline struct uvc_buffer *uvc_vbuf_to_buffer(struct vb2_v4l2_buffer *buf) static inline struct uvc_buffer *uvc_vbuf_to_buffer(struct vb2_v4l2_buffer *buf)
{ {
return container_of(buf, struct uvc_buffer, buf); return container_of(buf, struct uvc_buffer, buf);
...@@ -109,7 +103,8 @@ static int uvc_buffer_prepare(struct vb2_buffer *vb) ...@@ -109,7 +103,8 @@ static int uvc_buffer_prepare(struct vb2_buffer *vb)
if (vb->type == V4L2_BUF_TYPE_VIDEO_OUTPUT && if (vb->type == V4L2_BUF_TYPE_VIDEO_OUTPUT &&
vb2_get_plane_payload(vb, 0) > vb2_plane_size(vb, 0)) { vb2_get_plane_payload(vb, 0) > vb2_plane_size(vb, 0)) {
uvc_trace(UVC_TRACE_CAPTURE, "[E] Bytes used out of bounds.\n"); uvc_trace(uvc_queue_to_stream(queue)->dev, UVC_TRACE_CAPTURE,
"[E] Bytes used out of bounds.\n");
return -EINVAL; return -EINVAL;
} }
......
...@@ -93,20 +93,20 @@ static void uvc_event_streaming(struct uvc_device *dev, ...@@ -93,20 +93,20 @@ static void uvc_event_streaming(struct uvc_device *dev,
struct uvc_streaming_status *status, int len) struct uvc_streaming_status *status, int len)
{ {
if (len < 3) { if (len < 3) {
uvc_trace(UVC_TRACE_STATUS, "Invalid streaming status event " uvc_trace(dev, UVC_TRACE_STATUS,
"received.\n"); "Invalid streaming status event received.\n");
return; return;
} }
if (status->bEvent == 0) { if (status->bEvent == 0) {
if (len < 4) if (len < 4)
return; return;
uvc_trace(UVC_TRACE_STATUS, "Button (intf %u) %s len %d\n", uvc_trace(dev, UVC_TRACE_STATUS, "Button (intf %u) %s len %d\n",
status->bOriginator, status->bOriginator,
status->bValue[0] ? "pressed" : "released", len); status->bValue[0] ? "pressed" : "released", len);
uvc_input_report_key(dev, KEY_CAMERA, status->bValue[0]); uvc_input_report_key(dev, KEY_CAMERA, status->bValue[0]);
} else { } else {
uvc_trace(UVC_TRACE_STATUS, uvc_trace(dev, UVC_TRACE_STATUS,
"Stream %u error event %02x len %d.\n", "Stream %u error event %02x len %d.\n",
status->bOriginator, status->bEvent, len); status->bOriginator, status->bEvent, len);
} }
...@@ -163,12 +163,12 @@ static bool uvc_event_control(struct urb *urb, ...@@ -163,12 +163,12 @@ static bool uvc_event_control(struct urb *urb,
if (len < 6 || status->bEvent != 0 || if (len < 6 || status->bEvent != 0 ||
status->bAttribute >= ARRAY_SIZE(attrs)) { status->bAttribute >= ARRAY_SIZE(attrs)) {
uvc_trace(UVC_TRACE_STATUS, "Invalid control status event " uvc_trace(dev, UVC_TRACE_STATUS,
"received.\n"); "Invalid control status event received.\n");
return false; return false;
} }
uvc_trace(UVC_TRACE_STATUS, "Control %u/%u %s change len %d.\n", uvc_trace(dev, UVC_TRACE_STATUS, "Control %u/%u %s change len %d.\n",
status->bOriginator, status->bSelector, status->bOriginator, status->bSelector,
attrs[status->bAttribute], len); attrs[status->bAttribute], len);
...@@ -237,8 +237,9 @@ static void uvc_status_complete(struct urb *urb) ...@@ -237,8 +237,9 @@ static void uvc_status_complete(struct urb *urb)
} }
default: default:
uvc_trace(UVC_TRACE_STATUS, "Unknown status event " uvc_trace(dev, UVC_TRACE_STATUS,
"type %u.\n", dev->status[0]); "Unknown status event type %u.\n",
dev->status[0]);
break; break;
} }
} }
......
...@@ -75,8 +75,9 @@ static int uvc_ioctl_ctrl_map(struct uvc_video_chain *chain, ...@@ -75,8 +75,9 @@ static int uvc_ioctl_ctrl_map(struct uvc_video_chain *chain,
break; break;
default: default:
uvc_trace(UVC_TRACE_CONTROL, "Unsupported V4L2 control type " uvc_trace(chain->dev, UVC_TRACE_CONTROL,
"%u.\n", xmap->v4l2_type); "Unsupported V4L2 control type %u.\n",
xmap->v4l2_type);
ret = -ENOTTY; ret = -ENOTTY;
goto free_map; goto free_map;
} }
...@@ -164,10 +165,11 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream, ...@@ -164,10 +165,11 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream,
return -EINVAL; return -EINVAL;
fcc = (u8 *)&fmt->fmt.pix.pixelformat; fcc = (u8 *)&fmt->fmt.pix.pixelformat;
uvc_trace(UVC_TRACE_FORMAT, "Trying format 0x%08x (%c%c%c%c): %ux%u.\n", uvc_trace(stream->dev, UVC_TRACE_FORMAT,
fmt->fmt.pix.pixelformat, "Trying format 0x%08x (%c%c%c%c): %ux%u.\n",
fcc[0], fcc[1], fcc[2], fcc[3], fmt->fmt.pix.pixelformat,
fmt->fmt.pix.width, fmt->fmt.pix.height); fcc[0], fcc[1], fcc[2], fcc[3],
fmt->fmt.pix.width, fmt->fmt.pix.height);
/* Check if the hardware supports the requested format, use the default /* Check if the hardware supports the requested format, use the default
* format otherwise. * format otherwise.
...@@ -207,16 +209,18 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream, ...@@ -207,16 +209,18 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream,
} }
if (frame == NULL) { if (frame == NULL) {
uvc_trace(UVC_TRACE_FORMAT, "Unsupported size %ux%u.\n", uvc_trace(stream->dev, UVC_TRACE_FORMAT,
fmt->fmt.pix.width, fmt->fmt.pix.height); "Unsupported size %ux%u.\n", fmt->fmt.pix.width,
fmt->fmt.pix.height);
return -EINVAL; return -EINVAL;
} }
/* Use the default frame interval. */ /* Use the default frame interval. */
interval = frame->dwDefaultFrameInterval; interval = frame->dwDefaultFrameInterval;
uvc_trace(UVC_TRACE_FORMAT, "Using default frame interval %u.%u us " uvc_trace(stream->dev, UVC_TRACE_FORMAT,
"(%u.%u fps).\n", interval/10, interval%10, 10000000/interval, "Using default frame interval %u.%u us (%u.%u fps).\n",
(100000000/interval)%10); interval / 10, interval % 10, 10000000 / interval,
(100000000 / interval) % 10);
/* Set the format index, frame index and frame interval. */ /* Set the format index, frame index and frame interval. */
memset(probe, 0, sizeof(*probe)); memset(probe, 0, sizeof(*probe));
...@@ -260,7 +264,7 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream, ...@@ -260,7 +264,7 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream,
} }
if (i == stream->nformats) if (i == stream->nformats)
uvc_trace(UVC_TRACE_FORMAT, uvc_trace(stream->dev, UVC_TRACE_FORMAT,
"Unknown bFormatIndex %u, using default\n", "Unknown bFormatIndex %u, using default\n",
probe->bFormatIndex); probe->bFormatIndex);
...@@ -272,7 +276,7 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream, ...@@ -272,7 +276,7 @@ static int uvc_v4l2_try_format(struct uvc_streaming *stream,
} }
if (i == format->nframes) if (i == format->nframes)
uvc_trace(UVC_TRACE_FORMAT, uvc_trace(stream->dev, UVC_TRACE_FORMAT,
"Unknown bFrameIndex %u, using default\n", "Unknown bFrameIndex %u, using default\n",
probe->bFrameIndex); probe->bFrameIndex);
...@@ -416,8 +420,9 @@ static int uvc_v4l2_set_streamparm(struct uvc_streaming *stream, ...@@ -416,8 +420,9 @@ static int uvc_v4l2_set_streamparm(struct uvc_streaming *stream,
interval = uvc_fraction_to_interval(timeperframe.numerator, interval = uvc_fraction_to_interval(timeperframe.numerator,
timeperframe.denominator); timeperframe.denominator);
uvc_trace(UVC_TRACE_FORMAT, "Setting frame interval to %u/%u (%u).\n", uvc_trace(stream->dev, UVC_TRACE_FORMAT,
timeperframe.numerator, timeperframe.denominator, interval); "Setting frame interval to %u/%u (%u).\n",
timeperframe.numerator, timeperframe.denominator, interval);
mutex_lock(&stream->mutex); mutex_lock(&stream->mutex);
...@@ -545,8 +550,8 @@ static int uvc_v4l2_open(struct file *file) ...@@ -545,8 +550,8 @@ static int uvc_v4l2_open(struct file *file)
struct uvc_fh *handle; struct uvc_fh *handle;
int ret = 0; int ret = 0;
uvc_trace(UVC_TRACE_CALLS, "uvc_v4l2_open\n");
stream = video_drvdata(file); stream = video_drvdata(file);
uvc_trace(stream->dev, UVC_TRACE_CALLS, "%s\n", __func__);
ret = usb_autopm_get_interface(stream->dev->intf); ret = usb_autopm_get_interface(stream->dev->intf);
if (ret < 0) if (ret < 0)
...@@ -588,7 +593,7 @@ static int uvc_v4l2_release(struct file *file) ...@@ -588,7 +593,7 @@ static int uvc_v4l2_release(struct file *file)
struct uvc_fh *handle = file->private_data; struct uvc_fh *handle = file->private_data;
struct uvc_streaming *stream = handle->stream; struct uvc_streaming *stream = handle->stream;
uvc_trace(UVC_TRACE_CALLS, "uvc_v4l2_release\n"); uvc_trace(stream->dev, UVC_TRACE_CALLS, "%s\n", __func__);
/* Only free resources if this is a privileged handle. */ /* Only free resources if this is a privileged handle. */
if (uvc_has_privileges(handle)) if (uvc_has_privileges(handle))
...@@ -1461,7 +1466,11 @@ static long uvc_v4l2_compat_ioctl32(struct file *file, ...@@ -1461,7 +1466,11 @@ static long uvc_v4l2_compat_ioctl32(struct file *file,
static ssize_t uvc_v4l2_read(struct file *file, char __user *data, static ssize_t uvc_v4l2_read(struct file *file, char __user *data,
size_t count, loff_t *ppos) size_t count, loff_t *ppos)
{ {
uvc_trace(UVC_TRACE_CALLS, "uvc_v4l2_read: not implemented.\n"); struct uvc_fh *handle = file->private_data;
struct uvc_streaming *stream = handle->stream;
uvc_trace(stream->dev, UVC_TRACE_CALLS,
"uvc_v4l2_read: not implemented.\n");
return -EINVAL; return -EINVAL;
} }
...@@ -1470,7 +1479,7 @@ static int uvc_v4l2_mmap(struct file *file, struct vm_area_struct *vma) ...@@ -1470,7 +1479,7 @@ static int uvc_v4l2_mmap(struct file *file, struct vm_area_struct *vma)
struct uvc_fh *handle = file->private_data; struct uvc_fh *handle = file->private_data;
struct uvc_streaming *stream = handle->stream; struct uvc_streaming *stream = handle->stream;
uvc_trace(UVC_TRACE_CALLS, "uvc_v4l2_mmap\n"); uvc_trace(stream->dev, UVC_TRACE_CALLS, "%s\n", __func__);
return uvc_queue_mmap(&stream->queue, vma); return uvc_queue_mmap(&stream->queue, vma);
} }
...@@ -1480,7 +1489,7 @@ static __poll_t uvc_v4l2_poll(struct file *file, poll_table *wait) ...@@ -1480,7 +1489,7 @@ static __poll_t uvc_v4l2_poll(struct file *file, poll_table *wait)
struct uvc_fh *handle = file->private_data; struct uvc_fh *handle = file->private_data;
struct uvc_streaming *stream = handle->stream; struct uvc_streaming *stream = handle->stream;
uvc_trace(UVC_TRACE_CALLS, "uvc_v4l2_poll\n"); uvc_trace(stream->dev, UVC_TRACE_CALLS, "%s\n", __func__);
return uvc_queue_poll(&stream->queue, file, wait); return uvc_queue_poll(&stream->queue, file, wait);
} }
...@@ -1493,7 +1502,7 @@ static unsigned long uvc_v4l2_get_unmapped_area(struct file *file, ...@@ -1493,7 +1502,7 @@ static unsigned long uvc_v4l2_get_unmapped_area(struct file *file,
struct uvc_fh *handle = file->private_data; struct uvc_fh *handle = file->private_data;
struct uvc_streaming *stream = handle->stream; struct uvc_streaming *stream = handle->stream;
uvc_trace(UVC_TRACE_CALLS, "uvc_v4l2_get_unmapped_area\n"); uvc_trace(stream->dev, UVC_TRACE_CALLS, "%s\n", __func__);
return uvc_queue_get_unmapped_area(&stream->queue, pgoff); return uvc_queue_get_unmapped_area(&stream->queue, pgoff);
} }
......
...@@ -95,7 +95,7 @@ int uvc_query_ctrl(struct uvc_device *dev, u8 query, u8 unit, ...@@ -95,7 +95,7 @@ int uvc_query_ctrl(struct uvc_device *dev, u8 query, u8 unit,
if (ret != 1) if (ret != 1)
return ret < 0 ? ret : -EPIPE; return ret < 0 ? ret : -EPIPE;
uvc_trace(UVC_TRACE_CONTROL, "Control error %u\n", error); uvc_trace(dev, UVC_TRACE_CONTROL, "Control error %u\n", error);
switch (error) { switch (error) {
case 0: case 0:
...@@ -705,8 +705,8 @@ void uvc_video_clock_update(struct uvc_streaming *stream, ...@@ -705,8 +705,8 @@ void uvc_video_clock_update(struct uvc_streaming *stream,
sof = y; sof = y;
uvc_trace(UVC_TRACE_CLOCK, "%s: PTS %u y %llu.%06llu SOF %u.%06llu " uvc_trace(stream->dev, UVC_TRACE_CLOCK,
"(x1 %u x2 %u y1 %u y2 %u SOF offset %u)\n", "%s: PTS %u y %llu.%06llu SOF %u.%06llu (x1 %u x2 %u y1 %u y2 %u SOF offset %u)\n",
stream->dev->name, buf->pts, stream->dev->name, buf->pts,
y >> 16, div_u64((y & 0xffff) * 1000000, 65536), y >> 16, div_u64((y & 0xffff) * 1000000, 65536),
sof >> 16, div_u64(((u64)sof & 0xffff) * 1000000LLU, 65536), sof >> 16, div_u64(((u64)sof & 0xffff) * 1000000LLU, 65536),
...@@ -740,8 +740,8 @@ void uvc_video_clock_update(struct uvc_streaming *stream, ...@@ -740,8 +740,8 @@ void uvc_video_clock_update(struct uvc_streaming *stream,
timestamp = ktime_to_ns(first->host_time) + y - y1; timestamp = ktime_to_ns(first->host_time) + y - y1;
uvc_trace(UVC_TRACE_CLOCK, "%s: SOF %u.%06llu y %llu ts %llu " uvc_trace(stream->dev, UVC_TRACE_CLOCK,
"buf ts %llu (x1 %u/%u/%u x2 %u/%u/%u y1 %u y2 %u)\n", "%s: SOF %u.%06llu y %llu ts %llu buf ts %llu (x1 %u/%u/%u x2 %u/%u/%u y1 %u y2 %u)\n",
stream->dev->name, stream->dev->name,
sof >> 16, div_u64(((u64)sof & 0xffff) * 1000000LLU, 65536), sof >> 16, div_u64(((u64)sof & 0xffff) * 1000000LLU, 65536),
y, timestamp, vbuf->vb2_buf.timestamp, y, timestamp, vbuf->vb2_buf.timestamp,
...@@ -875,9 +875,8 @@ static void uvc_video_stats_update(struct uvc_streaming *stream) ...@@ -875,9 +875,8 @@ static void uvc_video_stats_update(struct uvc_streaming *stream)
{ {
struct uvc_stats_frame *frame = &stream->stats.frame; struct uvc_stats_frame *frame = &stream->stats.frame;
uvc_trace(UVC_TRACE_STATS, "frame %u stats: %u/%u/%u packets, " uvc_trace(stream->dev, UVC_TRACE_STATS,
"%u/%u/%u pts (%searly %sinitial), %u/%u scr, " "frame %u stats: %u/%u/%u packets, %u/%u/%u pts (%searly %sinitial), %u/%u scr, last pts/stc/sof %u/%u/%u\n",
"last pts/stc/sof %u/%u/%u\n",
stream->sequence, frame->first_data, stream->sequence, frame->first_data,
frame->nb_packets - frame->nb_empty, frame->nb_packets, frame->nb_packets - frame->nb_empty, frame->nb_packets,
frame->nb_pts_diffs, frame->last_pts_diff, frame->nb_pts, frame->nb_pts_diffs, frame->last_pts_diff, frame->nb_pts,
...@@ -1039,8 +1038,8 @@ static int uvc_video_decode_start(struct uvc_streaming *stream, ...@@ -1039,8 +1038,8 @@ static int uvc_video_decode_start(struct uvc_streaming *stream,
/* Mark the buffer as bad if the error bit is set. */ /* Mark the buffer as bad if the error bit is set. */
if (data[1] & UVC_STREAM_ERR) { if (data[1] & UVC_STREAM_ERR) {
uvc_trace(UVC_TRACE_FRAME, "Marking buffer as bad (error bit " uvc_trace(stream->dev, UVC_TRACE_FRAME,
"set).\n"); "Marking buffer as bad (error bit set).\n");
buf->error = 1; buf->error = 1;
} }
...@@ -1054,8 +1053,8 @@ static int uvc_video_decode_start(struct uvc_streaming *stream, ...@@ -1054,8 +1053,8 @@ static int uvc_video_decode_start(struct uvc_streaming *stream,
*/ */
if (buf->state != UVC_BUF_STATE_ACTIVE) { if (buf->state != UVC_BUF_STATE_ACTIVE) {
if (fid == stream->last_fid) { if (fid == stream->last_fid) {
uvc_trace(UVC_TRACE_FRAME, "Dropping payload (out of " uvc_trace(stream->dev, UVC_TRACE_FRAME,
"sync).\n"); "Dropping payload (out of sync).\n");
if ((stream->dev->quirks & UVC_QUIRK_STREAM_NO_FID) && if ((stream->dev->quirks & UVC_QUIRK_STREAM_NO_FID) &&
(data[1] & UVC_STREAM_EOF)) (data[1] & UVC_STREAM_EOF))
stream->last_fid ^= UVC_STREAM_FID; stream->last_fid ^= UVC_STREAM_FID;
...@@ -1086,8 +1085,8 @@ static int uvc_video_decode_start(struct uvc_streaming *stream, ...@@ -1086,8 +1085,8 @@ static int uvc_video_decode_start(struct uvc_streaming *stream,
* previous payload had the EOF bit set. * previous payload had the EOF bit set.
*/ */
if (fid != stream->last_fid && buf->bytesused != 0) { if (fid != stream->last_fid && buf->bytesused != 0) {
uvc_trace(UVC_TRACE_FRAME, "Frame complete (FID bit " uvc_trace(stream->dev, UVC_TRACE_FRAME,
"toggled).\n"); "Frame complete (FID bit toggled).\n");
buf->state = UVC_BUF_STATE_READY; buf->state = UVC_BUF_STATE_READY;
return -EAGAIN; return -EAGAIN;
} }
...@@ -1148,7 +1147,8 @@ static void uvc_video_decode_data(struct uvc_urb *uvc_urb, ...@@ -1148,7 +1147,8 @@ static void uvc_video_decode_data(struct uvc_urb *uvc_urb,
/* Complete the current frame if the buffer size was exceeded. */ /* Complete the current frame if the buffer size was exceeded. */
if (len > maxlen) { if (len > maxlen) {
uvc_trace(UVC_TRACE_FRAME, "Frame complete (overflow).\n"); uvc_trace(uvc_urb->stream->dev, UVC_TRACE_FRAME,
"Frame complete (overflow).\n");
buf->error = 1; buf->error = 1;
buf->state = UVC_BUF_STATE_READY; buf->state = UVC_BUF_STATE_READY;
} }
...@@ -1161,9 +1161,11 @@ static void uvc_video_decode_end(struct uvc_streaming *stream, ...@@ -1161,9 +1161,11 @@ static void uvc_video_decode_end(struct uvc_streaming *stream,
{ {
/* Mark the buffer as done if the EOF marker is set. */ /* Mark the buffer as done if the EOF marker is set. */
if (data[1] & UVC_STREAM_EOF && buf->bytesused != 0) { if (data[1] & UVC_STREAM_EOF && buf->bytesused != 0) {
uvc_trace(UVC_TRACE_FRAME, "Frame complete (EOF found).\n"); uvc_trace(stream->dev, UVC_TRACE_FRAME,
"Frame complete (EOF found).\n");
if (data[0] == len) if (data[0] == len)
uvc_trace(UVC_TRACE_FRAME, "EOF in empty payload.\n"); uvc_trace(stream->dev, UVC_TRACE_FRAME,
"EOF in empty payload.\n");
buf->state = UVC_BUF_STATE_READY; buf->state = UVC_BUF_STATE_READY;
if (stream->dev->quirks & UVC_QUIRK_STREAM_NO_FID) if (stream->dev->quirks & UVC_QUIRK_STREAM_NO_FID)
stream->last_fid ^= UVC_STREAM_FID; stream->last_fid ^= UVC_STREAM_FID;
...@@ -1279,7 +1281,7 @@ static void uvc_video_decode_meta(struct uvc_streaming *stream, ...@@ -1279,7 +1281,7 @@ static void uvc_video_decode_meta(struct uvc_streaming *stream,
memcpy(&meta->length, mem, length); memcpy(&meta->length, mem, length);
meta_buf->bytesused += length + sizeof(meta->ns) + sizeof(meta->sof); meta_buf->bytesused += length + sizeof(meta->ns) + sizeof(meta->sof);
uvc_trace(UVC_TRACE_FRAME, uvc_trace(stream->dev, UVC_TRACE_FRAME,
"%s(): t-sys %lluns, SOF %u, len %u, flags 0x%x, PTS %u, STC %u frame SOF %u\n", "%s(): t-sys %lluns, SOF %u, len %u, flags 0x%x, PTS %u, STC %u frame SOF %u\n",
__func__, ktime_to_ns(time), meta->sof, meta->length, __func__, ktime_to_ns(time), meta->sof, meta->length,
meta->flags, meta->flags,
...@@ -1339,8 +1341,9 @@ static void uvc_video_decode_isoc(struct uvc_urb *uvc_urb, ...@@ -1339,8 +1341,9 @@ static void uvc_video_decode_isoc(struct uvc_urb *uvc_urb,
for (i = 0; i < urb->number_of_packets; ++i) { for (i = 0; i < urb->number_of_packets; ++i) {
if (urb->iso_frame_desc[i].status < 0) { if (urb->iso_frame_desc[i].status < 0) {
uvc_trace(UVC_TRACE_FRAME, "USB isochronous frame " uvc_trace(stream->dev, UVC_TRACE_FRAME,
"lost (%d).\n", urb->iso_frame_desc[i].status); "USB isochronous frame lost (%d).\n",
urb->iso_frame_desc[i].status);
/* Mark the buffer as faulty. */ /* Mark the buffer as faulty. */
if (buf != NULL) if (buf != NULL)
buf->error = 1; buf->error = 1;
...@@ -1628,15 +1631,16 @@ static int uvc_alloc_urb_buffers(struct uvc_streaming *stream, ...@@ -1628,15 +1631,16 @@ static int uvc_alloc_urb_buffers(struct uvc_streaming *stream,
} }
if (i == UVC_URBS) { if (i == UVC_URBS) {
uvc_trace(UVC_TRACE_VIDEO, "Allocated %u URB buffers " uvc_trace(stream->dev, UVC_TRACE_VIDEO,
"of %ux%u bytes each.\n", UVC_URBS, npackets, "Allocated %u URB buffers of %ux%u bytes each.\n",
psize); UVC_URBS, npackets, psize);
return npackets; return npackets;
} }
} }
uvc_trace(UVC_TRACE_VIDEO, "Failed to allocate URB buffers (%u bytes " uvc_trace(stream->dev, UVC_TRACE_VIDEO,
"per packet).\n", psize); "Failed to allocate URB buffers (%u bytes per packet).\n",
psize);
return 0; return 0;
} }
...@@ -1835,12 +1839,13 @@ static int uvc_video_start_transfer(struct uvc_streaming *stream, ...@@ -1835,12 +1839,13 @@ static int uvc_video_start_transfer(struct uvc_streaming *stream,
bandwidth = stream->ctrl.dwMaxPayloadTransferSize; bandwidth = stream->ctrl.dwMaxPayloadTransferSize;
if (bandwidth == 0) { if (bandwidth == 0) {
uvc_trace(UVC_TRACE_VIDEO, "Device requested null " uvc_trace(stream->dev, UVC_TRACE_VIDEO,
"bandwidth, defaulting to lowest.\n"); "Device requested null bandwidth, defaulting to lowest.\n");
bandwidth = 1; bandwidth = 1;
} else { } else {
uvc_trace(UVC_TRACE_VIDEO, "Device requested %u " uvc_trace(stream->dev, UVC_TRACE_VIDEO,
"B/frame bandwidth.\n", bandwidth); "Device requested %u B/frame bandwidth.\n",
bandwidth);
} }
for (i = 0; i < intf->num_altsetting; ++i) { for (i = 0; i < intf->num_altsetting; ++i) {
...@@ -1863,13 +1868,14 @@ static int uvc_video_start_transfer(struct uvc_streaming *stream, ...@@ -1863,13 +1868,14 @@ static int uvc_video_start_transfer(struct uvc_streaming *stream,
} }
if (best_ep == NULL) { if (best_ep == NULL) {
uvc_trace(UVC_TRACE_VIDEO, "No fast enough alt setting " uvc_trace(stream->dev, UVC_TRACE_VIDEO,
"for requested bandwidth.\n"); "No fast enough alt setting for requested bandwidth.\n");
return -EIO; return -EIO;
} }
uvc_trace(UVC_TRACE_VIDEO, "Selecting alternate setting %u " uvc_trace(stream->dev, UVC_TRACE_VIDEO,
"(%u B/frame bandwidth).\n", altsetting, best_psize); "Selecting alternate setting %u (%u B/frame bandwidth).\n",
altsetting, best_psize);
ret = usb_set_interface(stream->dev->udev, intfnum, altsetting); ret = usb_set_interface(stream->dev->udev, intfnum, altsetting);
if (ret < 0) if (ret < 0)
......
...@@ -752,10 +752,11 @@ extern unsigned int uvc_trace_param; ...@@ -752,10 +752,11 @@ extern unsigned int uvc_trace_param;
extern unsigned int uvc_timeout_param; extern unsigned int uvc_timeout_param;
extern unsigned int uvc_hw_timestamps_param; extern unsigned int uvc_hw_timestamps_param;
#define uvc_trace(flag, fmt, ...) \ #define uvc_trace(_dev, flag, fmt, ...) \
do { \ do { \
if (uvc_trace_param & flag) \ if (uvc_trace_param & flag) \
printk(KERN_DEBUG "uvcvideo: " fmt, ##__VA_ARGS__); \ dev_printk(KERN_DEBUG, &(_dev)->udev->dev, fmt, \
##__VA_ARGS__); \
} while (0) } while (0)
#define uvc_trace_cont(flag, fmt, ...) \ #define uvc_trace_cont(flag, fmt, ...) \
...@@ -817,6 +818,12 @@ static inline int uvc_queue_streaming(struct uvc_video_queue *queue) ...@@ -817,6 +818,12 @@ static inline int uvc_queue_streaming(struct uvc_video_queue *queue)
return vb2_is_streaming(&queue->queue); return vb2_is_streaming(&queue->queue);
} }
static inline struct uvc_streaming *
uvc_queue_to_stream(struct uvc_video_queue *queue)
{
return container_of(queue, struct uvc_streaming, queue);
}
/* V4L2 interface */ /* V4L2 interface */
extern const struct v4l2_ioctl_ops uvc_ioctl_ops; extern const struct v4l2_ioctl_ops uvc_ioctl_ops;
extern const struct v4l2_file_operations uvc_fops; extern const struct v4l2_file_operations uvc_fops;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment