Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3062164pxj; Mon, 7 Jun 2021 00:55:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwxKBkXDYewH12go+31ic1Mtu7NvgJ/MW7sAJKMM9z6ibVWcTDIfzM7gnW76FJvFmW64Bm+ X-Received: by 2002:a50:d54c:: with SMTP id f12mr18416586edj.301.1623052529486; Mon, 07 Jun 2021 00:55:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623052529; cv=none; d=google.com; s=arc-20160816; b=mgy+qtSgldu5WIoHtI63JsLhljTJJv2edf7V+Y/Z13zEXN/ro5a2UBzs1QukCGh5vH XP31NWMpnLiE4sMkS7EzSk2+sm+hkw6p09BZFU1nqS/Izv5Ep97fcvycgaJFV9+PXmHo lOFUVN9SgFqaix+jeTWuaGvGG7Dub2yl73QPq70YiZ2FzSWxEfOxIR2RzSq32l0oe98r s/gSJRLQsufPcQ72rirPcxcsLdICuAiPXYJHuOmqmua6tuP/Jyz0LJyxjFcPX0TGVcST CtPwEPPI9yPpuxa0/nMUs3w3I/LBwBovZyEgRWItoGjNjAGDiM1PQ+NDzgyzB5d23UYq 3Gew== 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=VnwLRNd5kR0LUPEcbUD7x6J+EfFd1ZumEapw+492kUI=; b=wgMk9a2FGUMt60Q2orAlXWO1LNsK2Wu6Pkra1pe+7OgDr0dQhzHX7lz44tsDFHFh43 Zu7e130cWPm2DQ0vYlACKSMQjlOPZLqqsO5LnkPJ5Wb+tFj8RFDUTOROkCI/h8LzP428 oP9FdkKpx/FHYanduHyxdnl4eq0a/oGAPPmrNnxmq/4Z7DzoiEAz1jnk5ypbd13sylyC Pi4X9jQLO7di1UBUpvTgsRrnNsSpp+VHGht5Wtau6vHOKHP7sinD+z3LVp7HLkFKNGiR G+tJdiOjt5wY+6ErIoHxbszrV09zifnUlBffwg7VHWklNcXReDylm2nIrxGJUM8PStRs bwtA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=M6YHQmqD; 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 ba17si8075511edb.400.2021.06.07.00.55.07; Mon, 07 Jun 2021 00:55:29 -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=M6YHQmqD; 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 S230197AbhFGHyb (ORCPT + 99 others); Mon, 7 Jun 2021 03:54:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49524 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229436AbhFGHya (ORCPT ); Mon, 7 Jun 2021 03:54:30 -0400 Received: from mail-lj1-x22a.google.com (mail-lj1-x22a.google.com [IPv6:2a00:1450:4864:20::22a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 87F5EC061766 for ; Mon, 7 Jun 2021 00:52:39 -0700 (PDT) Received: by mail-lj1-x22a.google.com with SMTP id e2so20933588ljk.4 for ; Mon, 07 Jun 2021 00:52:39 -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=VnwLRNd5kR0LUPEcbUD7x6J+EfFd1ZumEapw+492kUI=; b=M6YHQmqDQrHfqJsSaBCfrOSFeYuAx/4Wuvxqxfz55b1SM2edz/SvDqQXdLIzSnXa// Pmy+lXBSk4AVN0Ua2/qwhB/5yWuvGtiQdGZnG1ZrTghgDXGH8W/pC6UPS+ZnP5yu4ocG ZLj3bhWthn4w9J7LzPEyEuqZzaVSXUb9NrSsVMcW7s4i++gu2GoyImrsXh/lJFkNj+k8 lvLBTozTgdtSUrDcQQ+xF7yxIBLY4noTaY5vHWPsjSuOfDo2UIvVYpJEhUILYE5YpNzC aCwzGGPoRoyyWSFmzpxalQLHJAFZLr/mag5V6p8Sn90DdYx6D24J3AWODazxugWCsemb e4vA== 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=VnwLRNd5kR0LUPEcbUD7x6J+EfFd1ZumEapw+492kUI=; b=B/wj+AHk0WIUDt2I+X29oRLyFb1EfLeivafSghZLNInx1FPw7UoDw6jWfDdWche+fR Cdbxe2InI0RBlCZGkoh3d9LVTUKQHNILrmIWG1jT6tr64DXMpBxWw/9fw+l0FygGZnHG jfm4CMfvvWbaivbdvC2tSAD3/eMFPWgQmmg60oKaeO5oq4MGm3Q0D+YbeXb9uQspSIRQ /eMoEfCbQHCATU8ob9I/kbllUUmlC60Gox+yC7y7SUZ/Yc5EP0uge9b4JGGxg54LVne4 fIdnC/Qsy+4YCUuwk0KjjUidhhbNPTZGoe4Z51EMndo1BdDO7lBQfCZI6evirmRcuZpM NwFw== X-Gm-Message-State: AOAM530fD2Glm1zYsIxf+ijE/4TwYUi0Jcut/0aBqR+aN7Jmo79lvZ/7 LmmgIs5zVnx8CMnUTiBEsRU= X-Received: by 2002:a05:651c:1138:: with SMTP id e24mr13811331ljo.403.1623052357820; Mon, 07 Jun 2021 00:52:37 -0700 (PDT) Received: from eldfell ([194.136.85.206]) by smtp.gmail.com with ESMTPSA id e9sm896925lfc.144.2021.06.07.00.52.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 07 Jun 2021 00:52:37 -0700 (PDT) Date: Mon, 7 Jun 2021 10:52:34 +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 Subject: Re: [PATCH 2/4] drm/uAPI: Add "active bpc" as feedback channel for "max bpc" drm property Message-ID: <20210607105234.4bb8aae6@eldfell> In-Reply-To: <20210604171723.10276-3-wse@tuxedocomputers.com> References: <20210604171723.10276-1-wse@tuxedocomputers.com> <20210604171723.10276-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_/Pr+2/0V=PQE=VGC=tSRkY=f"; protocol="application/pgp-signature" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --Sig_/Pr+2/0V=PQE=VGC=tSRkY=f Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: quoted-printable On Fri, 4 Jun 2021 19:17:21 +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 available. >=20 > Signed-off-by: Werner Sembach > --- > drivers/gpu/drm/drm_atomic_uapi.c | 2 ++ > drivers/gpu/drm/drm_connector.c | 40 +++++++++++++++++++++++++++++++ > include/drm/drm_connector.h | 15 ++++++++++++ > 3 files changed, 57 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..5f42a5be5822 100644 > --- a/drivers/gpu/drm/drm_connector.c > +++ b/drivers/gpu/drm/drm_connector.c > @@ -1195,6 +1195,13 @@ 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 is used by userspace check the bit depth > + * actually applied by the GPU driver after evaluation all hardware > + * capabilities and max bpc. Drivers to use the function > + * drm_connector_attach_active_bpc_property() to create and attach the > + * property to the connector during initialization. > + * Hi Werner, the idea looks good to me, but the above doc could be a little more fluent. May I suggest something like: This read-only range property tells userspace the pixel color bit depth 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 install this property. There should also be something said about dithering done by the display engine (not monitor), but I'm not sure how that should be worded. It may also depend on if and how userspace can know about dithering. So if a dithering related property is added later, maybe add a note here too in that patch. Thanks, pq > * Connectors also have one standardized atomic property: > * > * CRTC_ID: > @@ -2150,6 +2157,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_/Pr+2/0V=PQE=VGC=tSRkY=f Content-Type: application/pgp-signature Content-Description: OpenPGP digital signature -----BEGIN PGP SIGNATURE----- iQIzBAEBCAAdFiEEJQjwWQChkWOYOIONI1/ltBGqqqcFAmC90EIACgkQI1/ltBGq qqdGCQ//cRerWSb24BlhxlzYGB8NQvHZrLXOSiGRs2viHwBP913JnXJGRViEDx5x clhIXqdHwsmh+ezmYxHhAgi6lrgNhCr+9MBkLqhX5YbHmXdwSzQBWezRibzXjbYW KeTvPx0z8Nvh3ViRHcb/dd4LcXflp7Ii9ksSW2avNktSJR7EZu6o+krZxTuOgKmx nOWXVqxEwTcLDxp/ubDbEEOTvaaYyQVpGa3wSuyOVuW4ea4i/cm9Ax+N2f0/aHCH Bj0F9S2qYNgGTDpGSm3myipPx2Lqd/teEqiEXH+Gxr6+vI8V+cfZz/xjoe0Ko84b 2BEuD3t22bDLSlC6C214virxbxV7R5fWRD72XfyDmDJrILVBWV2b2ftG9pKbS4GE hJSbYs8eRS44o7RplbFYrJMVRf7DK3k/l8H9kpasLG36GxRMvaVtSCgrZLUBnCEb gMKcqvf824YjA7FWFEAASHr0lDbroSxGuzxU8Ts2wYLyuK6PCvXv9TDwc3tcMB94 zhB3rToba+3Rmw+/lSLwp85EyHvtRTV/OrJMAZASLRVJs/mMsYCWupW1783Ueh4L tvRnZ/MBz48DoZpYo3bOLySG4Nb7jhGgjmYI6I9huWXHUuBcknGf4oFn7cwPXFR2 3IOghkwAL3prSMIz80cfPeLBg7ahq2zA6C8KGj1xLU8IOST/knU= =6CeT -----END PGP SIGNATURE----- --Sig_/Pr+2/0V=PQE=VGC=tSRkY=f--