Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp1267893pxu; Mon, 23 Nov 2020 16:32:18 -0800 (PST) X-Google-Smtp-Source: ABdhPJx/epqCBBCoPtwh/vRlcPL7a7YFr02hAr3PWuUm/h7q6nH34XiLHov17VhcJoOxxBSCxr0e X-Received: by 2002:a05:6402:1542:: with SMTP id p2mr1666331edx.298.1606177938147; Mon, 23 Nov 2020 16:32:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606177938; cv=none; d=google.com; s=arc-20160816; b=Tdjkc3D57L+gtEKjYeLneOrrEgS9uijpaKijAf8osbagqiqFpoEMkibBlsZrqMIxW9 dTkosnFM5k9R3d4qWg57n9u3A+Nihx1gghGqJ5psZ5ekdeRzffOqv4LomGXlH93RWaH6 FSsWMhDpwd9ESjPZJcVMRRGcFY3Cj8mojEvWE6ccLYXrl5kv/YQp0P5J6f/lt1v5zzFC AXxvTouLIo93xp47AAnhNSXp3vqM+fRMfjVmP4evushnYNDb1HXw2ScvivAxXpltFn7x l6wHUozkSGkYhEz/fLxBtpFZo08UC0+bTllScZQgWrLQWE167ojM+AB/2cuK+HMSJG5O q5hA== 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=eE2REjZ2KihgeWAB19FrZ0Eh0oguIUq3o8nfc663G2c=; b=zakbJQqSAmgOU5NM+PDP7tlDRhPOYwaJYWQMiQbzI/jR7ZDoHlewlYdm1EQZmpL4Ou GjW/gZ9x7HR/miWIrKTM/AluMIFAbFYhU3O22WvyzAMVRslt1Nw+CAjQg1K1xTm2Ltdl 0FDWywqzY5iwnePseyJU8WmIlfUejEq8SmVTFi2jcrj/hZ9JOxKFpYlrMzs+KT00hplH S+Qs6amkmnUdNJbSEqv094otgHHl0rmrKIqfWj4LHgx0EFLACXnBztA2N8F0BowAlOGE kg73kGLaNWjMMvg/t5HZIQ5FO1stSz6EQ47/0cjJwRDUQ5xQRpTvl7cSjjTdxHW8UiDW 31Rw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=C1TDHyTm; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y15si3340304eju.55.2020.11.23.16.31.55; Mon, 23 Nov 2020 16:32:18 -0800 (PST) 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=@google.com header.s=20161025 header.b=C1TDHyTm; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731669AbgKWPDb (ORCPT + 99 others); Mon, 23 Nov 2020 10:03:31 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51438 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729244AbgKWPD3 (ORCPT ); Mon, 23 Nov 2020 10:03:29 -0500 Received: from mail-yb1-xb43.google.com (mail-yb1-xb43.google.com [IPv6:2607:f8b0:4864:20::b43]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4E416C061A4D for ; Mon, 23 Nov 2020 07:03:29 -0800 (PST) Received: by mail-yb1-xb43.google.com with SMTP id x17so16209186ybr.8 for ; Mon, 23 Nov 2020 07:03:29 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=eE2REjZ2KihgeWAB19FrZ0Eh0oguIUq3o8nfc663G2c=; b=C1TDHyTmuOqGvQ/rAULYHA0VLje7ffu6HS7n4sv+fyvdOxVc7UkxxVj3BEy7y3WuTc Kjt5liroMkMCkloTAPiLKfD+KfeppntNvDAtssxhSgjeemxx4g5BBS+yDJk21kWvKrxC HdEmGU56FLIAcIIttOPxGlbStJLytRRvFr3riyLlajJRdvn0DPBLpxPrL/A1ZalaHT2F 7/wQgJ0wc14zTxFW2J9xyRpWlffW9o+PEiCb0icVpepVPrs3VQtbXUIQMDI9r5v6Otdl ykL0BExM8ZZ2RbqHfXll3zqrqFrDhUmZNBC6hNjueYT+0SxigKXDWpZb2bYW+48kmo5K PwuQ== 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=eE2REjZ2KihgeWAB19FrZ0Eh0oguIUq3o8nfc663G2c=; b=tHiZ1N8MqKPilHTnGEXWMxUQjLL5VCTo67xO6UEPrPv9YGsBaAYeyHhGswW2sjCjMR tL4E4TZC4SKct4i2S6lI0v8MMbzaPKy63WVVsegUJkPl6OvM6O5i/pU5MFfB8cuK/ewN d09/4jaI17irCEiNhRWO4lPRwdECA6s51r3Kb0hV7Tj3aGCunsn1AdrJ6WqearUQWT0f lf9+aUherhAAiA7BptY4KBKS3onA1oiQgkUDSIzgmx2ZpP4vycMxNcq8/LQlfOuVgVNX NN/54anGS+RXSXT+nlFqwHoCT6uQ3zAR6DYAJbrD+iVZgsgK6Ok8XtOuk4UZJdH2mRRn t9Ww== X-Gm-Message-State: AOAM530hPVe6uxXddAaSQNEN0u3wfrFLbgiu85NUdFRMGbM05bCgV0DU C7w71M8tYF8IPknIoD7br+ZZdEuUk76uskWoeTHtDA== X-Received: by 2002:a25:7453:: with SMTP id p80mr45946317ybc.31.1606143807765; Mon, 23 Nov 2020 07:03:27 -0800 (PST) MIME-Version: 1.0 References: <5ff0fc487272a7c21f63a929bfceee1ac9b43348.camel@debian.org> In-Reply-To: From: Adam Goode Date: Mon, 23 Nov 2020 10:02:51 -0500 Message-ID: Subject: Re: PROBLEM: Broken pixel format for Elgato Cam Link 4K To: Benjamin Drung Cc: Laurent Pinchart , Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-kernel Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Nov 22, 2020 at 2:34 PM Benjamin Drung wrote: > > Am Freitag, den 20.11.2020, 16:45 -0500 schrieb Adam Goode: > > On Fri, Nov 20, 2020 at 1:52 PM Benjamin Drung > > wrote: > > > > > > Hi, > > > > > > I own an Elgato Cam Link 4K which is a very popular USB HDMI > > > capture > > > device (number one capture card by click rates on Geizhals [1]). > > > The > > > problem is that the video feed is distorted when using the > > > /dev/videoX > > > device in the browser (tested on Firefox and Chromium) for video > > > conferencing (tested with Jitsi Meet and Google Meet). The same > > > distortion is present when opening `v4l2:///dev/video0` with VLC. > > > > > > The Elgato Cam Link 4K reports to have three different pixel > > > formats: > > > > > > ``` > > > $ v4l2-ctl -d /dev/video0 --list-formats-ext > > > ioctl: VIDIOC_ENUM_FMT > > > Type: Video Capture > > > > > > [0]: 'NV12' (Y/CbCr 4:2:0) > > > Size: Discrete 3840x2160 > > > Interval: Discrete 0.040s (25.000 fps) > > > [1]: 'NV12' (Y/CbCr 4:2:0) > > > Size: Discrete 3840x2160 > > > Interval: Discrete 0.040s (25.000 fps) > > > [2]: 'YU12' (Planar YUV 4:2:0) > > > Size: Discrete 3840x2160 > > > Interval: Discrete 0.040s (25.000 fps) > > > ``` > > > > > > When specifying the video format 'YU12' to VLC, the video is > > > distorted > > > the same way as using the default video format. When specifying > > > 'NV12' > > > to VLC, the video feed is displayed correctly: > > > > > > ``` > > > vlc v4l2:///dev/video0 --v4l2-chroma=NV12 > > > ``` > > > > > > In OBS, the video feed is always displayed correctly. All video > > > formats > > > 'Y/CbCr 4:2:0', 'Planar YUV 4:2:0', 'BGR3 (Emulated)', and 'YV12 > > > (Emulated)' combined with the color ranges 'Default', 'Partial', > > > and > > > 'Full' produce the same correct output. > > > > > > With Linux >= 5.9 this behavior in OBS changes: The video format > > > 'Y/CbCr 4:2:0' displays the video correctly. Switching to 'Planar > > > YUV > > > 4:2:0', 'BGR3 (Emulated)', or 'YV12 (Emulated)' shows the video > > > distorted and OBS shows this error message: > > > > > > ``` > > > info: v4l2-input: Pixelformat: NV12 > > > [...] > > > libv4l2: error set_fmt gave us a different result than try_fmt! > > > info: v4l2-input: Resolution: 3840x2160 > > > info: v4l2-input: Pixelformat: NV12 > > > ``` > > > > > > Changing the video format back does not have an effect until I also > > > change the color range (does seem to be relevant what to select > > > there). > > > > > > Workaround > > > ---------- > > > > > > You can create a v4l2loopback device and use ffmpeg to stream from > > > the > > > Cam Link 4K to the loopback device: > > > > > > ``` > > > ffmpeg -f v4l2 -input_format yuv420p -video_size 3840x2160 \ > > > -i "$camlink" -codec copy -f v4l2 "$loopdev" > > > ``` > > > > > > This workaround works, but is cumbersome and burns CPU cycles. > > > > > > Other reports > > > ------------- > > > > > > Searching the web for "Cam Link 4K Linux" reveals many similar > > > reports > > > like this. Noteworthy is blog post [3] from Mike Walters who > > > patched > > > the Cam Link 4K firmware to report the correct video format. I am > > > willing to debug this issue and do test, but I don't want to flash > > > the > > > firmware to not break the warrenty (bisides I lack the hardware for > > > flashing). > > > > > > Environment > > > ----------- > > > > > > This problem is present in Ubuntu 20.04 with linux 5.4.0-54.60 and > > > Ubuntu 20.10 with linux 5.8.0-29.31. I also tested the mainline > > > kernels > > > builds 5.9.8-050908.202011101634 and 5.10.0-051000rc4.202011152030 > > > from > > > Ubuntu [2]. > > > > > > The Cam Link 4K shows follow entries in dmesg: > > > > > > ``` > > > [ 1.575753] usb 2-3: new SuperSpeed Gen 1 USB device number 2 > > > using xhci_hcd > > > [ 1.596664] usb 2-3: LPM exit latency is zeroed, disabling LPM. > > > [ 1.598557] usb 2-3: New USB device found, idVendor=0fd9, > > > idProduct=0066, bcdDevice= 0.00 > > > [ 1.598558] usb 2-3: New USB device strings: Mfr=1, Product=2, > > > SerialNumber=4 > > > [ 1.598559] usb 2-3: Product: Cam Link 4K > > > [ 1.598560] usb 2-3: Manufacturer: Elgato > > > ``` > > > > > > I have another problems with 5.9.8-050908.202011101634 and 5.10.0- > > > 051000rc4.202011152030: Chromium fail to access the video device of > > > Cam > > > Link 4K and the notebook integrated webcam has a too low > > > brightness. > > > > > > [1] https://geizhals.de/?cat=vidext > > > [2] https://kernel.ubuntu.com/~kernel-ppa/mainline/ > > > [3] > > > https://assortedhackery.com/patching-cam-link-to-play-nicer-on-linux/ > > > > > > -- > > > Benjamin Drung > > > Debian & Ubuntu Developer > > > > > > > > > Hi, > > > > I am running on Fedora 32 which has the fix I wrote for the buggy > > elgato firmware. The bug in the firmware makes it impossible to > > properly select a non-0 pixel format when following the UVC > > negotiation protocol. This is because the firmware returns the pixel > > format in the wrong byte of the packet. The driver was following the > > UVC protocol but did not send the pixel format back to the v4l2 > > subsystem. It does that now. > > > > I'm not surprised that other bugs are emerging now. Ultimately the > > firmware is buggy and announces pixel formats that it then rejects. > > If > > I flip through the settings in OBS, I do manage to wedge the > > interface. But most of the programs I've seen that use v4l2 are buggy > > in this way. A reliable one is the qv4l2 test program. I've also had > > no problems with Chromium. > > > > That reverse engineering is interesting! But I think it hides the > > real > > problem, where the pixel format negotiation on the firmware writes > > into the wrong byte of the packet. > > Hi Adam, > > you are talking about commit ec2c23f628802317f73fab5255cc62a776bc7930 > and 8a652a17e3c005dcdae31b6c8fdf14382a29cbbe that are part of > v5.10-rc1? > > What do you suggest to fix the issue? Should I contact Elgato > requesting a firmware update? Can the kernel ship a quirk for the Cam > Link 4K to workaround the firmware bug? I would be happy to try out > patches. > I would file a ticket. I did so some time ago, but there have been no firmware updates for many months. > I tested the qv4l2 with Linux 5.10.0-051000rc4.202011152030. When using > the default settings, it displays the video correctly, but with a > vertical green one-pixel-wide line. The terminal prints "error" four > times. Sadly there is no debug mode to figure out where that error > comes from. I'm not sure where this line is coming from. Can you post a link to a screenshot or capture? I have never encountered this issue. Can you reproduce on a Windows or Mac computer? > > Selecting "YU12 (Planar YUV 4:2:0)" print the following error message > and switches back to the previous format: > > libv4l2: error set_fmt gave us a different result than try_fmt! > Yes, this is the kernel coping with the buggy firmware. These errors are expected. It is also expected that YU12 does not work (the device advertises it, then rejects it when selected). I believe Windows and Mac (you can use OBS to try) do the same thing. A quirk is possible (I hacked something up with libuvc when I was debugging this) but it's not something I have time to look at right now. Adam > -- > Benjamin Drung > Debian & Ubuntu Developer >