Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp41028pxb; Wed, 18 Aug 2021 15:25:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxptU/TA0PBepS5rjddr5U9UaDjERCexdQFj31/65jjnVk/bxDMHUk5LqTFOmWjDLB4G/Ae X-Received: by 2002:a05:6638:3382:: with SMTP id h2mr9826196jav.77.1629325550495; Wed, 18 Aug 2021 15:25:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629325550; cv=none; d=google.com; s=arc-20160816; b=e7pvp6B1vv3oTdSez1VquHQpmjs+dx0ypVAE4rmB6PDGO9n5MrqhHbp4thHbUKbjUU EbwDzWuC2uAUwaF895PffHhZbfi20PHUAVgbOuyVQLsw/8mifek7lRyk/i2xQr52dNmI sdPHN7WhQZd5oPYgweFQGY717SZwda94fZIqcEiKs5NI8PryfXeQYOGckusRU9CF4vke oxsaksKS6NcQeuJs5+ikGbPzjxY9aa/whaz4GFkJKQ1eYVwaPwLeWudUvift4myGwArb +GO0B+YR0IXhDvTWJK2AmmYFnRZz2l9tmOWiF5+Eo2esHjGZpcbPubFaIqlo7WoRFrjy L2LQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=N3LoNoDXvq5uXKpOMqArPPc3h+pKyjLG4zety+86ARs=; b=al7X6umGTmqqkoCysM9kpVr2TR5EJ74MLdB4stHWg6m4eddddAu/k1Bu5fNg469Cvi uKBsQcqmPsvueJETT2V2u63dzZzsi24TJk+9vTxf8N1tEyjRcTE7qo7ZVqyatcYdmOnZ nrHSlBAqonWH7nAmPrpW38S9B2c3CTNvwGXpRB+VzXit2+eY7q4i6bk0k3QV0bEy6bbK eFxtjFa7pyAcw8vMUhR8kkC8z6HBR4PUZzo3th2hwIwJwA8xCpWmPXTCgVZVMohLTRk8 8DWcs2G0ZJFLnNuJgpXLZjHX9QfC+f3Sr/kLk4m+ROk7UltWhThMOIKM6OCKlSX4nmAy zyVQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b="R/9HwdTB"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m18si1146081iow.66.2021.08.18.15.25.38; Wed, 18 Aug 2021 15:25:50 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b="R/9HwdTB"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234211AbhHRWXd (ORCPT + 99 others); Wed, 18 Aug 2021 18:23:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47606 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232456AbhHRWXc (ORCPT ); Wed, 18 Aug 2021 18:23:32 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5F2D0C061764; Wed, 18 Aug 2021 15:22:57 -0700 (PDT) Received: from pendragon.ideasonboard.com (62-78-145-57.bb.dnainternet.fi [62.78.145.57]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id CA93D2A8; Thu, 19 Aug 2021 00:22:53 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1629325374; bh=iglJOCDJskdnnATm9m1oJieHqRlccWM7jKQUDh9x17c=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=R/9HwdTBDj3/4PyAXUw9w+Zk3CxuQc6r4fQcycUvpdcXX/BmOjYF4q+FVxz/gmQUu VUVmjforztb5UhQc0dhjc3iRXlt6otxNJeCin+LoGRBlm6nK7kBuyxbYvV/GhqP+zq F/vkqxC/f6djlwaYleF7sfQAcAU8AN0sD+wo8hWI= Date: Thu, 19 Aug 2021 01:22:45 +0300 From: Laurent Pinchart To: Ricardo Ribalda Cc: Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2] media: uvcvideo: Quirk for hardware with invalid sof Message-ID: References: <20210818203502.269889-1-ribalda@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20210818203502.269889-1-ribalda@chromium.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Ricardo, Thank you for the patch. On Wed, Aug 18, 2021 at 10:35:02PM +0200, Ricardo Ribalda wrote: > The hardware timestamping code has the assumption than the device_sof > and the host_sof run at the same frequency (1 KHz). > > Unfortunately, this is not the case for all the hardware. Add a quirk to > support such hardware. > > Note on how to identify such hardware: > When running with "yavta -c /dev/videoX" Look for periodic jumps of the > fps. Eg: > > 30 (6) [-] none 30 614400 B 21.245557 21.395214 34.133 fps ts mono/SoE > 31 (7) [-] none 31 614400 B 21.275327 21.427246 33.591 fps ts mono/SoE > 32 (0) [-] none 32 614400 B 21.304739 21.459256 34.000 fps ts mono/SoE > 33 (1) [-] none 33 614400 B 21.334324 21.495274 33.801 fps ts mono/SoE > 34 (2) [-] none 34 614400 B 21.529237 21.527297 5.130 fps ts mono/SoE > 35 (3) [-] none 35 614400 B 21.649416 21.559306 8.321 fps ts mono/SoE > 36 (4) [-] none 36 614400 B 21.678789 21.595320 34.045 fps ts mono/SoE > ... > 99 (3) [-] none 99 614400 B 23.542226 23.696352 33.541 fps ts mono/SoE > 100 (4) [-] none 100 614400 B 23.571578 23.728404 34.069 fps ts mono/SoE > 101 (5) [-] none 101 614400 B 23.601425 23.760420 33.504 fps ts mono/SoE > 102 (6) [-] none 102 614400 B 23.798324 23.796428 5.079 fps ts mono/SoE > 103 (7) [-] none 103 614400 B 23.916271 23.828450 8.478 fps ts mono/SoE > 104 (0) [-] none 104 614400 B 23.945720 23.860479 33.957 fps ts mono/SoE > > They happen because the delta_sof calculated at > uvc_video_clock_host_sof(), wraps periodically, as both clocks drift. That looks plain wrong. First of all, the whole purpose of the SOF clock is to have a shared clock between the host and the device. It makes no sense for a device to have a free-running "SOF" clock. Given the log above, the issue occurs so quickly that it doesn't seem to be a mere drift of a free running clock. Could you investigate this more carefully ? > Signed-off-by: Ricardo Ribalda > --- > v2: Fix typo in frequency > > drivers/media/usb/uvc/uvc_driver.c | 9 +++++++++ > drivers/media/usb/uvc/uvc_video.c | 11 +++++++++-- > drivers/media/usb/uvc/uvcvideo.h | 2 ++ > 3 files changed, 20 insertions(+), 2 deletions(-) > > diff --git a/drivers/media/usb/uvc/uvc_driver.c b/drivers/media/usb/uvc/uvc_driver.c > index 9a791d8ef200..d1e6cba10b15 100644 > --- a/drivers/media/usb/uvc/uvc_driver.c > +++ b/drivers/media/usb/uvc/uvc_driver.c > @@ -2771,6 +2771,15 @@ static const struct usb_device_id uvc_ids[] = { > .bInterfaceSubClass = 1, > .bInterfaceProtocol = 0, > .driver_info = UVC_INFO_QUIRK(UVC_QUIRK_RESTORE_CTRLS_ON_INIT) }, > + /* Logitech HD Pro Webcam C922 */ > + { .match_flags = USB_DEVICE_ID_MATCH_DEVICE > + | USB_DEVICE_ID_MATCH_INT_INFO, > + .idVendor = 0x046d, > + .idProduct = 0x085c, > + .bInterfaceClass = USB_CLASS_VIDEO, > + .bInterfaceSubClass = 1, > + .bInterfaceProtocol = 0, > + .driver_info = UVC_INFO_QUIRK(UVC_QUIRK_INVALID_DEVICE_SOF) }, > /* Chicony CNF7129 (Asus EEE 100HE) */ > { .match_flags = USB_DEVICE_ID_MATCH_DEVICE > | USB_DEVICE_ID_MATCH_INT_INFO, > diff --git a/drivers/media/usb/uvc/uvc_video.c b/drivers/media/usb/uvc/uvc_video.c > index 6d0e474671a2..760ab015cf9c 100644 > --- a/drivers/media/usb/uvc/uvc_video.c > +++ b/drivers/media/usb/uvc/uvc_video.c > @@ -518,13 +518,20 @@ uvc_video_clock_decode(struct uvc_streaming *stream, struct uvc_buffer *buf, > /* To limit the amount of data, drop SCRs with an SOF identical to the > * previous one. > */ > - dev_sof = get_unaligned_le16(&data[header_size - 2]); > + if (stream->dev->quirks & UVC_QUIRK_INVALID_DEVICE_SOF) > + dev_sof = usb_get_current_frame_number(stream->dev->udev); > + else > + dev_sof = get_unaligned_le16(&data[header_size - 2]); > + > if (dev_sof == stream->clock.last_sof) > return; > > stream->clock.last_sof = dev_sof; > > - host_sof = usb_get_current_frame_number(stream->dev->udev); > + if (stream->dev->quirks & UVC_QUIRK_INVALID_DEVICE_SOF) > + host_sof = dev_sof; > + else > + host_sof = usb_get_current_frame_number(stream->dev->udev); > time = uvc_video_get_time(); > > /* The UVC specification allows device implementations that can't obtain > diff --git a/drivers/media/usb/uvc/uvcvideo.h b/drivers/media/usb/uvc/uvcvideo.h > index cce5e38133cd..89d909661915 100644 > --- a/drivers/media/usb/uvc/uvcvideo.h > +++ b/drivers/media/usb/uvc/uvcvideo.h > @@ -209,6 +209,8 @@ > #define UVC_QUIRK_RESTORE_CTRLS_ON_INIT 0x00000400 > #define UVC_QUIRK_FORCE_Y8 0x00000800 > #define UVC_QUIRK_FORCE_BPP 0x00001000 > +#define UVC_QUIRK_INVALID_DEVICE_SOF 0x00002000 > + > > /* Format flags */ > #define UVC_FMT_FLAG_COMPRESSED 0x00000001 -- Regards, Laurent Pinchart