Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp309343pxb; Wed, 18 Aug 2021 23:29:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx3MYk0jYPsrP/udgZ9ktgw19P6Lz4xEwK5Yjv9pYnbUodBtsSqpsHpkggbICpp7t6OeJqY X-Received: by 2002:aa7:db13:: with SMTP id t19mr14628429eds.72.1629354560582; Wed, 18 Aug 2021 23:29:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629354560; cv=none; d=google.com; s=arc-20160816; b=wjcwhuhsraD0HOjP/MDsr6wbSsNqTjJ9ZZXWBGny2OqsdApjWYxxWgG6+KYxvvG2U8 cV1DNS5VV6cR781zykMGj2MTTtJ9WwLNY7r25qf/pBYIkmRHPlZnBuebogy7rpw2vbzo Ms6QRQmZb+IWuP+rr3i3k3FDrrei3WzIC4CxLf734yTKJlO6N8WFcW0iSUW/NYsq/NuQ 1lPf0WEtDTMy85Gw2GmICzhYKH9TyIAiljCuNPHe+7Sdqy7Tn9fcOpc3Z6QILbmNAU1e bQK//fHgVT4rGSn250HcbSQGBSrTYoKvXHl0ySdWusKjE1T1mFwY3/wRGx1SKVueAirk t8cQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=ytAdw+4HbwxOixwhqqwAmgZxwbQ6ZemJDjSd2P3wFF4=; b=cAThx4v8yKKWD1A+wquzDsL0zY8wppah/iRf8o1fm+WeJWRnp3TfIIXSsFQZ80BKHG v9qy5AN76uKbchzdV4Bm1EcKiJUgWi4uXc40QtBi+HN5vDTC+UgeG+oEiSPyEh0p1OQf A1qMfcu2UA0AwcuQPZXCC2jx1d2QKcmgJgq5h/4vAwO5IvTVss47yuBgBjE6LQye4GVQ JJ97VsZw79H2wMA0deE8CCj6eb5VZr8Av57FXMtjiBvDREekptGfEg4+9OaivEbxsMGR tLvmWC2jnGmU21aCQQ1yMRvFwHjcnGp7KR1IxeEP+Xz0nve8UJW/cE2EyHc6+mTXjDU2 pYhg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b="BEC7/EhV"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hc33si2095315ejc.668.2021.08.18.23.28.54; Wed, 18 Aug 2021 23:29:20 -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 header.i=@chromium.org header.s=google header.b="BEC7/EhV"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230463AbhHSG1t (ORCPT + 99 others); Thu, 19 Aug 2021 02:27:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43644 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230263AbhHSG1s (ORCPT ); Thu, 19 Aug 2021 02:27:48 -0400 Received: from mail-il1-x129.google.com (mail-il1-x129.google.com [IPv6:2607:f8b0:4864:20::129]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 312A2C061575 for ; Wed, 18 Aug 2021 23:27:13 -0700 (PDT) Received: by mail-il1-x129.google.com with SMTP id v2so4838054ilg.12 for ; Wed, 18 Aug 2021 23:27:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=ytAdw+4HbwxOixwhqqwAmgZxwbQ6ZemJDjSd2P3wFF4=; b=BEC7/EhVvY7tvtV8oDyQd/m6axDnb0FgYYWumjx5Z2vf7CzIwceIWsKbqaNqdjRVHX I/8fp4pRY0VAaVkCilTbyRxB/is1D9ghUazxqokeWtm42jO2HTJ9fX3ZyJ0ZV/pV0681 v5RYXQrDD9UiC63u0Sj56ayUkebKlM6w7o9Mo= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=ytAdw+4HbwxOixwhqqwAmgZxwbQ6ZemJDjSd2P3wFF4=; b=ZsoDSoKPBE0Rxdk44AZJahkNA0nGR2DHtdQqdRkCgB0fmZR+ZIWdK5MkFZyf5lqBPR jCKbC8UN1r1iSnVoW5Hua4D/j6mTPzywkj66yf+v4e45b+0HqRJMwGy0j/sR4jANJqr6 /uzhnlGlO5incao+1HXgVz6bWuqjtXClVJaG5Ee+ZVFaj9tAjIGtOIn9gycLLpfTroG7 t+URaAmRPG0ij/dke3TlHHKku5Rg4Yw/R9H2iJ+4lw7i0JBJ9amt3RC3IFsV7gAOkzWv icpFAV1AREdvrSzqfZgiiOG2PQtcS8c9ywZF0K2168o5n+h+ElOJupt8cbaPvTTedORe bL2g== X-Gm-Message-State: AOAM531ntXm28F0iVWsfgV4t2cpXYmM9TtjV2JCBP4rAYEwVT32UAWmh aaYcK64q8wBVxZ+BZ+5XKb+ELgokob0eXw== X-Received: by 2002:a92:d10d:: with SMTP id a13mr9058851ilb.87.1629354432329; Wed, 18 Aug 2021 23:27:12 -0700 (PDT) Received: from mail-io1-f47.google.com (mail-io1-f47.google.com. [209.85.166.47]) by smtp.gmail.com with ESMTPSA id a8sm1026924ilq.63.2021.08.18.23.27.11 for (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 18 Aug 2021 23:27:11 -0700 (PDT) Received: by mail-io1-f47.google.com with SMTP id j18so6233754ioj.8 for ; Wed, 18 Aug 2021 23:27:11 -0700 (PDT) X-Received: by 2002:a6b:6603:: with SMTP id a3mr10605555ioc.68.1629354431072; Wed, 18 Aug 2021 23:27:11 -0700 (PDT) MIME-Version: 1.0 References: <20210818203502.269889-1-ribalda@chromium.org> In-Reply-To: From: Ricardo Ribalda Date: Thu, 19 Aug 2021 08:27:00 +0200 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH v2] media: uvcvideo: Quirk for hardware with invalid sof To: Laurent Pinchart Cc: Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Laurent Thanks for your prompt reply On Thu, 19 Aug 2021 at 00:22, Laurent Pinchart wrote: > > 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 > ? In my test the dev_sof runs at 887.91Hz and the dev_sof at 1000.35Hz. If I plot the difference of both clocks host_sof - (dev_sof % 2048), I get this nice graph https://imgur.com/a/5fQnKa7 I agree that it makes not sense to have a free-running "SOF", but the manufacturer thinks otherwise :) Best regards > > > 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 -- Ricardo Ribalda