Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp308815pxj; Thu, 10 Jun 2021 00:59:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwL4lNLVAHex5upoPqSXot7O28rIfkaZuoucwlc32HbJAK8QP0HUeUSq140dQrQ+HSgQLA8 X-Received: by 2002:a17:906:2b85:: with SMTP id m5mr3337893ejg.141.1623311964362; Thu, 10 Jun 2021 00:59:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623311964; cv=none; d=google.com; s=arc-20160816; b=TjfZXGBpLzRGjakCycXlmNCcJk9Vn0AXospyiUvWRUvOq1L8Z4xtDSqKU+8N7a9Wfc T+bvJKcg8ctx8uHhuirUsKvQ0ZEFec2QPzmcgxgAugJjh0xcNZlvkYi8bnq9FS/Y/Wm5 RN1aWCX6PHNN4yYJB9uZtU30Fxj0Tx7isYw7uFyDHPGfmCDvbJgEjyKuonT36N6VEojL e5AfydjegGqLed05lHrZHgXKQCyfZM/wJ0UpV0VM7/yTId1B/fMKWeFTSXLzp2KoSPvI UDzvIDulTrJkw4zduEIIxGXmwQKdicNW4n1tZqdm0DRzrNOPxwOC22o9VnoMszEx2uBl hNSw== 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=SA5Ivb0CCE59h380OTMfIw4pEztiT4MRBNH8ti8EjRg=; b=AjnHOm5r38EzkT3G/3OOtzFhns3X5KhoN/rVS9Vu4YONUuoSrc9Ue8vjinEZo/c3w4 g3V7LerPe+7h99AraGaSvOaD5XYAkGDYdCfs4AeSuqovICvwrzBF2ljq/+NPG79QMMkA zgNFX+zlTGeF4x/2GgJuVt+73xeG4p2vd6ZAlypSe569+Z+C9R+8IerqY0CfgqvnpNau mNLwhWLImoXux7qW8w8sc080q1T3cy6so2+MU45COPpWOq6N1rk2mhq/Q54Io7QeAN24 GZhSIVkJz49rxQTQglm24RGquwfnAoRURxVFtBWiMktlZD/FzDyT1fbiYHxiKv7+UN0O yY5Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="UsnB/8xo"; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n17si1725631ejl.429.2021.06.10.00.59.01; Thu, 10 Jun 2021 00:59:24 -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=@gmail.com header.s=20161025 header.b="UsnB/8xo"; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229935AbhFJH6t (ORCPT + 99 others); Thu, 10 Jun 2021 03:58:49 -0400 Received: from mail-lj1-f178.google.com ([209.85.208.178]:39527 "EHLO mail-lj1-f178.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229778AbhFJH6s (ORCPT ); Thu, 10 Jun 2021 03:58:48 -0400 Received: by mail-lj1-f178.google.com with SMTP id c11so3546304ljd.6 for ; Thu, 10 Jun 2021 00:56:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:in-reply-to:references :mime-version; bh=SA5Ivb0CCE59h380OTMfIw4pEztiT4MRBNH8ti8EjRg=; b=UsnB/8xogJHe8G+HURPvdy9xSpG3q17OyaxwZos6B9OkmHr3UPdrILT14c6jXIojl+ k5fcp7oj/ZZ4j8DZKt7NTp+68VQAGcq0bmTDzQkGiLUhW1EFMYyqQq7N3CE/WtRuE3+N KySdDSuuW9EhDIiadb2Cda85fZ0GYtk7gGNqinLYGI6q5xKPVMNkf4/K27+ljIX9Kklt 1UP11UZos81azcTn+0kTCJIZ5/jqxpc2h0qgfmWeoDJVWxAYQ0Q3SmLGnvN91VSLi4T3 7ABgyeXmcLUdBik/48NVhn3oixQ7Qrmhr0TRdaWTyCPzEFA/eFbg1qmsReEJ+lgBg4Ca Z+MQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:in-reply-to :references:mime-version; bh=SA5Ivb0CCE59h380OTMfIw4pEztiT4MRBNH8ti8EjRg=; b=qvIAKAPOtxlD/pk+o4cYjw6X+P4uPm4n/rnq0Jl7SziKmnPdr2ATOOcxdtewQ4aSz1 t0M3dnBnoCHD6j1dviNPuu7kW2YQ+yBgse30ki1MZhY4E+BE8BibdSdPvpBG36IioAVh 2TyWY/rMZRgtN04VBrmCSKeoIGC0PtM1OUF9/TfRHo48+ILAayIXITyxdb1YXY6LHL/A Oqr0MO5mASz/8hMKJExtGz+sLPsHH7iKYytqPz3Xu8QPC3XXlxe0r0bYmUxL9AS5FtAA /vJ+yrLbDySNZ+tuL/5o9TkNxq97OM/S8recd+ddZZPPWB+vziNMl2G9l7n4207z9yra VS5g== X-Gm-Message-State: AOAM533I0RY6q6IvLiw+nRCFTmqRltp/TtrZmt1mq5K9dGANtuFFGwMk ivk1Pz2iCmq3reb1g9QdViw= X-Received: by 2002:a05:651c:514:: with SMTP id o20mr1227077ljp.201.1623311738293; Thu, 10 Jun 2021 00:55:38 -0700 (PDT) Received: from eldfell ([194.136.85.206]) by smtp.gmail.com with ESMTPSA id r8sm240527lfc.90.2021.06.10.00.55.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 10 Jun 2021 00:55:37 -0700 (PDT) Date: Thu, 10 Jun 2021 10:55:24 +0300 From: Pekka Paalanen To: Werner Sembach Cc: harry.wentland@amd.com, sunpeng.li@amd.com, alexander.deucher@amd.com, christian.koenig@amd.com, airlied@linux.ie, daniel@ffwll.ch, maarten.lankhorst@linux.intel.com, mripard@kernel.org, tzimmermann@suse.de, jani.nikula@linux.intel.com, joonas.lahtinen@linux.intel.com, rodrigo.vivi@intel.com, amd-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, intel-gfx@lists.freedesktop.org, Mario Kleiner Subject: Re: [PATCH v2 2/7] drm/uAPI: Add "active bpc" as feedback channel for "max bpc" drm property Message-ID: <20210610105524.4dd2a40f@eldfell> In-Reply-To: <20210608174320.37429-3-wse@tuxedocomputers.com> References: <20210608174320.37429-1-wse@tuxedocomputers.com> <20210608174320.37429-3-wse@tuxedocomputers.com> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha256; boundary="Sig_/G9gjPWkKmqwLWKB6JjVFNYP"; protocol="application/pgp-signature" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --Sig_/G9gjPWkKmqwLWKB6JjVFNYP Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: quoted-printable On Tue, 8 Jun 2021 19:43:15 +0200 Werner Sembach wrote: > Add a new general drm property "active bpc" which can be used by graphic = drivers > to report the applied bit depth per pixel back to userspace. >=20 > While "max bpc" can be used to change the color depth, there was no way t= o check > which one actually got used. While in theory the driver chooses the best/= highest > color depth within the max bpc setting a user might not be fully aware wh= at his > hardware is or isn't capable off. This is meant as a quick way to double = check > the setup. >=20 > In the future, automatic color calibration for screens might also depend = on this > information being available. >=20 > Signed-off-by: Werner Sembach > --- > drivers/gpu/drm/drm_atomic_uapi.c | 2 ++ > drivers/gpu/drm/drm_connector.c | 41 +++++++++++++++++++++++++++++++ > include/drm/drm_connector.h | 15 +++++++++++ > 3 files changed, 58 insertions(+) >=20 > diff --git a/drivers/gpu/drm/drm_atomic_uapi.c b/drivers/gpu/drm/drm_atom= ic_uapi.c > index 268bb69c2e2f..7ae4e40936b5 100644 > --- a/drivers/gpu/drm/drm_atomic_uapi.c > +++ b/drivers/gpu/drm/drm_atomic_uapi.c > @@ -873,6 +873,8 @@ drm_atomic_connector_get_property(struct drm_connecto= r *connector, > *val =3D 0; > } else if (property =3D=3D connector->max_bpc_property) { > *val =3D state->max_requested_bpc; > + } else if (property =3D=3D connector->active_bpc_property) { > + *val =3D state->active_bpc; > } else if (connector->funcs->atomic_get_property) { > return connector->funcs->atomic_get_property(connector, > state, property, val); > diff --git a/drivers/gpu/drm/drm_connector.c b/drivers/gpu/drm/drm_connec= tor.c > index 7631f76e7f34..c0c3c09bfed0 100644 > --- a/drivers/gpu/drm/drm_connector.c > +++ b/drivers/gpu/drm/drm_connector.c > @@ -1195,6 +1195,14 @@ static const struct drm_prop_enum_list dp_colorspa= ces[] =3D { > * drm_connector_attach_max_bpc_property() to create and attach the > * property to the connector during initialization. > * > + * active bpc: > + * This read-only range property tells userspace the pixel color bit dep= th > + * actually used by the hardware display engine on "the cable" on a > + * connector. The chosen value depends on hardware capabilities, both > + * display engine and connected monitor, and the "max bpc" property. > + * Drivers shall use drm_connector_attach_active_bpc_property() to insta= ll > + * this property. > + * This description is now clear to me, but I wonder, is it also how others understand it wrt. dithering? Dithering done on monitor is irrelevant, because we are talking about "on the cable" pixels. But since we are talking about "on the cable" pixels, also dithering done by the display engine must not factor in. Should the dithering done by display engine result in higher "active bpc" number than what is actually transmitted on the cable? I cannot guess what userspace would want exactly. I think the strict "on the cable" interpretation is a safe bet, because it then gives a lower limit on observed bpc. Dithering settings should be exposed with other KMS properties, so userspace can factor those in. But to be absolutely sure, we'd have to ask some color management experts. Cc'ing Mario in case he has an opinion. Since "active bpc" is related to "max bpc", the both should follow the same definition. Do they do that now? Maybe a clarifying note about interaction with dithering would still be good to have here. I recall reading some comments from you about having problems with making this immutable. Is it properly immutable now? That is, drm_info reports the property as "(immutable)". https://github.com/ascent12/drm_info If we are not sure if DSC could result in lower observed bpc than "active bpc", then DSC state would need to be exposed as a KMS property too, with a note that it invalidates what "active bpc" shows. Or maybe "active bpc" should be "unknown" in that case? Thanks, pq > * Connectors also have one standardized atomic property: > * > * CRTC_ID: > @@ -2150,6 +2158,39 @@ int drm_connector_attach_max_bpc_property(struct d= rm_connector *connector, > } > EXPORT_SYMBOL(drm_connector_attach_max_bpc_property); > =20 > +/** > + * drm_connector_attach_active_bpc_property - attach "active bpc" proper= ty > + * @connector: connector to attach active bpc property on. > + * @min: The minimum bit depth supported by the connector. > + * @max: The maximum bit depth supported by the connector. > + * > + * This is used to check the applied bit depth on a connector. > + * > + * Returns: > + * Zero on success, negative errno on failure. > + */ > +int drm_connector_attach_active_bpc_property(struct drm_connector *conne= ctor, > + int min, int max) > +{ > + struct drm_device *dev =3D connector->dev; > + struct drm_property *prop; > + > + prop =3D connector->active_bpc_property; > + if (!prop) { > + prop =3D drm_property_create_range(dev, 0, "active bpc", min, max); > + if (!prop) > + return -ENOMEM; > + > + connector->active_bpc_property =3D prop; > + } > + > + drm_object_attach_property(&connector->base, prop, 0); > + connector->state->active_bpc =3D 0; > + > + return 0; > +} > +EXPORT_SYMBOL(drm_connector_attach_active_bpc_property); > + > /** > * drm_connector_set_vrr_capable_property - sets the variable refresh ra= te > * capable property for a connector > diff --git a/include/drm/drm_connector.h b/include/drm/drm_connector.h > index 1922b278ffad..c58cba2b6afe 100644 > --- a/include/drm/drm_connector.h > +++ b/include/drm/drm_connector.h > @@ -781,6 +781,13 @@ struct drm_connector_state { > */ > u8 max_bpc; > =20 > + /** > + * @active_bpc: Read only property set by the GPU driver to the actually > + * applied bit depth of the pixels after evaluating all hardware > + * limitations. > + */ > + u8 active_bpc; > + > /** > * @hdr_output_metadata: > * DRM blob property for HDR output metadata > @@ -1380,6 +1387,12 @@ struct drm_connector { > */ > struct drm_property *max_bpc_property; > =20 > + /** > + * @active_bpc_property: Default connector property for the active bpc > + * to be driven out of the connector. > + */ > + struct drm_property *active_bpc_property; > + > #define DRM_CONNECTOR_POLL_HPD (1 << 0) > #define DRM_CONNECTOR_POLL_CONNECT (1 << 1) > #define DRM_CONNECTOR_POLL_DISCONNECT (1 << 2) > @@ -1698,6 +1711,8 @@ int drm_connector_set_panel_orientation_with_quirk( > int width, int height); > int drm_connector_attach_max_bpc_property(struct drm_connector *connecto= r, > int min, int max); > +int drm_connector_attach_active_bpc_property(struct drm_connector *conne= ctor, > + int min, int max); > =20 > /** > * struct drm_tile_group - Tile group metadata --Sig_/G9gjPWkKmqwLWKB6JjVFNYP Content-Type: application/pgp-signature Content-Description: OpenPGP digital signature -----BEGIN PGP SIGNATURE----- iQIyBAEBCAAdFiEEJQjwWQChkWOYOIONI1/ltBGqqqcFAmDBxWwACgkQI1/ltBGq qqdx6Q/2Jx5o//7FCgMeDEoDPr3pod+Wxo2MlOMa8WmeEgg/7A4nmr0Of/btoEof IwDEbBZvN9gJIz0vA4GaLKNOjRFHek9l2ur6TsQ292J6CoC/MJclpee511ImuaCl a0GGw9vwcmUJLUInvM6fwcEzi9Vb+dj1H2VNqRq56QcpgX/+WjW5AkMc0LtsD+qi hs2DAnvHkTuaocgY7gCjLMlE9sBwmNUByzpvsl2Nwnn994hdUP2SylTXBJ5cm06j BKqEbFelKajhQzscjre7vU4d7EKalm7bKT83BubXg6Q3GAqYMMJhQU7IrH7YQPf4 Ns+Yjw93SxM8V/Gesyu7ZTh6Nclz51oDpcWZZB5GIDXpQWr58+Fa8H+ZgXxSVP59 A49M1SAjdmttofu0H1YCijuboKSlHOlq85zHJmIl/TRhMEqbKiej5Z4z/4FtjIHl HfiXcJIa2iWYcNYGeSktgFf0tu55+X06usqAippPXr8jiU0dYHeuHGrQjenKPWLg ooSpWddnrQgFpNhGOdtpiKHpYwWaob9P5tcgaEjt+lvGzJR2mDBi8IBAfBIWE7VZ qDRnSfZb0/0tWMftwxnTlbyv2Zyp9/aIaLShx3SmVmRVUzFK+oVwgXINju8Io+h/ fiOW3tUyC43DGNqVoBYglrGDGeyrjv8z9s2HQ3JfJlWapvLRaw== =ap5H -----END PGP SIGNATURE----- --Sig_/G9gjPWkKmqwLWKB6JjVFNYP--