Received: by 2002:a05:7412:b101:b0:e2:908c:2ebd with SMTP id az1csp3353380rdb; Thu, 16 Nov 2023 07:25:15 -0800 (PST) X-Google-Smtp-Source: AGHT+IG+ydo1GGF22Tm/JrVZ/LTHi1XBGBBSUbXUVjXR4k01JFkDRVIkKWcQSywP2xeYYWYxT1Qm X-Received: by 2002:a17:902:c40f:b0:1cc:7100:2d62 with SMTP id k15-20020a170902c40f00b001cc71002d62mr3478127plk.39.1700148314475; Thu, 16 Nov 2023 07:25:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700148314; cv=none; d=google.com; s=arc-20160816; b=V43+r6Ro0BaEKqXw0mc5iUBeR+AbeoXZ3NM3/Pl/ZUdw0iOxTDxIbPGhiqWjaI9BFj hBIUkGhvvkMMFhqQaBjAAawpg+t6n4SVQkEii0Dq2ej56UXCT5lCu0sdAVKFCPGw3iNG 0OnSIesEn6EayLOMWgXjRc6/DecPO4pYqd0mLwsJfU3t/E6hZzv7XIuD522dXh8lVlQk /2vkrstrNBCou1ZA74AGDrxSDu89+s2lnqbrOR01a8XoIUB5eTbgGkxAE8v5zQ2NIzt+ K0RWl0m89tx5wb9iSV5n1H3qGv8spBPZiPDirzGQU+CgxrbKINj0gv1xRzpNpn71qXTZ DthQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :subject:cc:to:from:date:dkim-signature; bh=dZMLQjPS1GVfcF+h6FS+KvNDB5/+HLLSBOl3wsUbQoQ=; fh=Cl7clyZomw1xVM96dLwG/jpq0knPPe7emAWOXeT54iI=; b=lgeU5X7S9PdqeMPvaiqMeCUTyc0rMfP0sADhjfswYu39Jtr4U1v3ZW6vtf3ZEuGZ7T nyWoIMgi7ZYYBkRv63YuMaKxS7zv+Rm6AHjVYoR9pbUYRfU05HBu9NFrFRL8fAVuLi7A ++qvLXxtj60k/SGGKRv6hSZXCYNpFZlE5LMA/IU6u9RZl+L84QyyLbwMsAPLihux2t9C QNziS1ehUuven6GCg1c6uNM67XWhju34Td4IiC9rFspNXF3Q7krpsWKlzitSRzBrenrQ JFFi7/ZipS+yoI2ujgdP0XjT5ZJQfaKxVG5uRK2mU510MhTttwq8peYL1ZDyQKbFBVcx H8Xw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=XpByk+9s; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id v5-20020a170903238500b001bf88e777f9si13176588plh.33.2023.11.16.07.25.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 16 Nov 2023 07:25:14 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=XpByk+9s; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id E690D8029DED; Thu, 16 Nov 2023 07:25:12 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230254AbjKPPZK (ORCPT + 99 others); Thu, 16 Nov 2023 10:25:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36730 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229562AbjKPPZI (ORCPT ); Thu, 16 Nov 2023 10:25:08 -0500 Received: from madras.collabora.co.uk (madras.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e5ab]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8165819B for ; Thu, 16 Nov 2023 07:25:04 -0800 (PST) Received: from eldfell (cola.collaboradmins.com [195.201.22.229]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: pq) by madras.collabora.co.uk (Postfix) with ESMTPSA id 2C8D8660734B; Thu, 16 Nov 2023 15:25:02 +0000 (GMT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1700148302; bh=KNKzR3AdYrcGsgvQ5hgYYumtewtEY9oprWir7jRod8g=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=XpByk+9s2bMzN6tEhHw2hV3ZhOTZv75dbBTGs5kkodE7sKIJ/UfYba760FJMlslJt jTrIQ+oly4RL5rdtaq4FOaAwmhGeH3529NWB5bRE7hf0bByZxumt6CHs8p6NfIgueb LBMye/6AXul0maQC+Zh95pS1tkTT1a+CY9uG7nKFPEyE9xrLwnOs5DkO7ZNmfOrGby WBF6FPebu57JNPEv44eUAEa9imsooyqANlfhrzxknp21PcZ27ZsPOiEcQ+0zhIK1m7 I3u+9ppp++pTQNAHj0+cwK83tXhuYeCd5MMZPui7S/vuX2gIhhJjBtbXA/AlMxtAfk B7DpNTeXuzhtA== Date: Thu, 16 Nov 2023 17:24:51 +0200 From: Pekka Paalanen To: Thomas Zimmermann Cc: Simon Ser , Sima Vetter , Bilal Elmoussaoui , Javier Martinez Canillas , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Maxime Ripard , Erico Nunes Subject: Re: [PATCH v2 4/5] drm/plane: Extend damage tracking kernel-doc Message-ID: <20231116172451.00a7ec9e.pekka.paalanen@collabora.com> In-Reply-To: <3b799dee-c366-4c0b-9efe-c75d189fc24b@suse.de> References: <20231115131549.2191589-1-javierm@redhat.com> <20231115131549.2191589-5-javierm@redhat.com> <3b799dee-c366-4c0b-9efe-c75d189fc24b@suse.de> X-Mailer: Claws Mail 4.1.1 (GTK 3.24.38; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: multipart/signed; boundary="Sig_/j+uUmYK70pFZfFAf/9klwKl"; protocol="application/pgp-signature"; micalg=pgp-sha256 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Thu, 16 Nov 2023 07:25:13 -0800 (PST) --Sig_/j+uUmYK70pFZfFAf/9klwKl Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: quoted-printable On Thu, 16 Nov 2023 13:34:07 +0100 Thomas Zimmermann wrote: > Hi >=20 > Am 16.11.23 um 13:14 schrieb Simon Ser: > > On Thursday, November 16th, 2023 at 13:06, Thomas Zimmermann wrote: > > =20 > >>> + * Note that there are two types of damage handling: frame damage an= d buffer > >>> + * damage. The type of damage handling implemented depends on a driv= er's upload > >>> + * target. Drivers implementing a per-plane or per-CRTC upload targe= t need to > >>> + * handle frame damage while drivers implementing a per-buffer uploa= d target > >>> + * need to handle buffer damage. > >>> + * > >>> + * The existing damage helpers only support the frame damage type, t= here is no > >>> + * buffer age support or similar damage accumulation algorithm imple= mented yet. > >>> + * > >>> + * Only drivers handling frame damage can use the mentiored damage h= elpers to =20 > >=20 > > Typo: mentioned > > =20 > >>> + * iterate over the damaged regions. Drivers that handle buffer dama= ge, need to > >>> + * set &struct drm_plane_state.ignore_damage_clips as an indication = to > >>> + * drm_atomic_helper_damage_iter_init() that the damage clips should= be ignored. > >>> + * In that case, the returned damage rectangle is the &drm_plane_sta= te.src since > >>> + * a full plane update should happen. > >>> + * > >>> + * For more information about the two type of damage, see: > >>> + * https://registry.khronos.org/EGL/extensions/KHR/EGL_KHR_swap_buff= ers_with_damage.txt > >>> + * https://emersion.fr/blog/2019/intro-to-damage-tracking/ =20 > >> > >> One thought you might want to consider. > >> > >> These URLs are helpful. The only issue I have is that frame damage and > >> buffer damage are user-space concepts. The kernel bug is that damage > >> handling expects the backing storage/upload buffer not to change for a > >> given plane. If the upload buffer changes between page flips, the new > >> upload buffer has to be updated as a whole. Hence no damage handling t= hen. =20 > >=20 > > Why would these concepts be specific to user-space? The kernel could > > better handle buffer damage instead of forcing full damage, by doing > > something similar to what user-space does. =20 >=20 > The terms 'frame damage' and 'buffer damage' do not exist in the kernel.= =20 > The problem can be better described in wording that is common within the= =20 > context of the kernel drivers. What terms does the kernel use for these two different concepts of damage? Thanks, pq --Sig_/j+uUmYK70pFZfFAf/9klwKl Content-Type: application/pgp-signature Content-Description: OpenPGP digital signature -----BEGIN PGP SIGNATURE----- iQIzBAEBCAAdFiEEJQjwWQChkWOYOIONI1/ltBGqqqcFAmVWNEMACgkQI1/ltBGq qqd06RAAhfgSXquqYQp3UhAgvMrBtAt6PmgvhPU6+C+e8YHBIV6Q2GlLzHEAidAG d0Hm1lxUIjGFtu9GC5wkPcIMR5UWYCCF4E3RGJrmWGs2IXYeR0tfpWVH2Wdb4KAg oisO5yllQmhzuSixwK9QKkiCzpemaT5MNAIXLtGz6+u626kkTRzHuAoRwLhZOznF K7xgm9Sx3kBAA0gBf6APAht+QRcjsZWI5fBu3RC2w20BXP137AtUAZdBbMV4KzpX UNrkpAuxmMXvxjQP+PhHaJw2PaKgOi9gGSVZ6hL4wdmEoe9Y/Lyexvw0VAekrCbb klXn+WRZWd094v2DjDkYputfWOX06h4eVupBd2DMiv/XXSe6g0hINIotp9uZg0IT YeiR9nQE+HID99kRn5EZfw/R7WtVgT42IY7LCQfrPeq9CnqtrFG14lSFeloQwOGf N+Oj3y0oiKzD4osuOn6sgJMWVGf+KVIKWzAq4E45UWBgi7ch8vNC7SLmyXILeqDT stxQ2WhaLnF4lBYDVo7k2Bo93TqnOvWQfZoyA6cLaMPYjfOR7QqiCvJKG2vv7gob 1Z5FWHIyWeHPlu+f6FKTAJ3N9stSlV1tmSPVtCJ/JXuhOjqxVyYMYxROKjQ7Z7BE Ir2Mp/FSZ3X5dEcyQwEP7Y4XMduiVBf7HEaRSacNmU5Sae0jSGc= =AFrP -----END PGP SIGNATURE----- --Sig_/j+uUmYK70pFZfFAf/9klwKl--