Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp924997imu; Tue, 11 Dec 2018 09:38:23 -0800 (PST) X-Google-Smtp-Source: AFSGD/X2vqG1GIgC2CPnHMhz7WO31IAED0UleOER9LL+LWYMwdo3VQvMEJWl/PL/4WqyQPH0eHBe X-Received: by 2002:a17:902:be08:: with SMTP id r8mr3245435pls.289.1544549903559; Tue, 11 Dec 2018 09:38:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544549903; cv=none; d=google.com; s=arc-20160816; b=fJZ8v2FBjLzYZccLAXK4fcljd777Y5jdqrQQy/Dgwl+qNtL1qPgFHI9neAfSFisFKD Bszdn/wPart4cA7UE/S9At5cMu6NQNvV+CSt2/MrD3/RTU3HAT0sr/7oAHyxt0pVeC/s Pb1pzlbrB2K6CIUV86v68hEoaEWNVH+SKBeOujv8Itm1FJe5yzzX4E7zCN4favuPnC7i lRHEMBhSz+wSYwRLcsMEBTgK/UBpiLUkXc+Boz+BdNl111bSDhDfEukf841/P7x4QRyt R0BGyzAHDKlHXLYjX3nP2mZg6/qplsIOge0w7XH2qbYnENS1f9y5101bXGuwNZBoXy1b Zg8A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=8HioAeqzq0dl6NstrZ5Oz6jVD03apamk3g1+c+0GN8Q=; b=a24/HY7dRPfpR8Hro3WRY1dfwfcFQv/9fErNoTbMM1qCeAvn05ygndwTm0yFo4ebIs cHiA2P2z+oHHS5uzadiLzgLsK69CuQkZh60lea6p20yewsFFB5n4T2f7uyUJdwP8xioH TzGVo4iAcr2OCQ2G+mORHZBZDW98ksQm+yayEt+Sx+JxP87YegIs8q03oOHMh8lv8oK5 /JcWE4aKSCamv6CestwGWX4kPCh46YWzvtAW8/A+WH4zaNxgqDvBhwP7ahjrexd7cW0W mFpMVehzn//TKK4xx+OGku8JPN2p3D/UONOludbNw/flBNf0Bdqg04ADHJUMw1zx0oar lHkQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=eIAi5awx; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 85si13236707pfc.145.2018.12.11.09.38.08; Tue, 11 Dec 2018 09:38:23 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=eIAi5awx; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729568AbeLKPy5 (ORCPT + 99 others); Tue, 11 Dec 2018 10:54:57 -0500 Received: from mail.kernel.org ([198.145.29.99]:43512 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730282AbeLKPyy (ORCPT ); Tue, 11 Dec 2018 10:54:54 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 60B5820855; Tue, 11 Dec 2018 15:54:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1544543693; bh=gv2QnKT0KoR97nO5M8vqZQEAs5RW/cZavRnuV7gk9l8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=eIAi5awx1kWloPlr8DIP0hhlNe1inHC1/fwXi3IFNs14t9K+juEcgWUM2fd6TgNAB xLgRfdtJs0kurY1si9sJ8IzKsWk3g1LSeVVabUbpi0smWW2dPnkD0ARkToLk8eKPdq l9sjbCpawmvc47glc9iqLo0gT4mJUYe1MSsnrLbI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Nicholas Kazlauskas , Alex Deucher , Harry Wentland , Sasha Levin Subject: [PATCH 4.19 027/118] drm/amdgpu: Add amdgpu "max bpc" connector property (v2) Date: Tue, 11 Dec 2018 16:40:46 +0100 Message-Id: <20181211151645.333445528@linuxfoundation.org> X-Mailer: git-send-email 2.20.0 In-Reply-To: <20181211151644.216668863@linuxfoundation.org> References: <20181211151644.216668863@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 69756c6ff0de478c10100481f16c966dde3b5339 ] [Why] Many panels support more than 8bpc but some modes are unavailable while running at greater than 8bpc due to DP/HDMI bandwidth constraints. Support for more than 8bpc was added recently in the driver but it defaults to the maximum supported bpc - locking out these modes. This should be a user configurable option such that the user can select what bpc configuration they would like. [How] This patch introduces the "max bpc" amdgpu driver specific connector property so the user can limit the maximum bpc. It ranges from 8 to 16. This doesn't directly set the preferred bpc for the panel since it follows Intel's existing driver conventions. This proprety should be removed once common drm support for max bpc lands. v2: rebase on upstream (Alex) Signed-off-by: Nicholas Kazlauskas Acked-by: Alex Deucher Reviewed-by: Harry Wentland Signed-off-by: Alex Deucher Signed-off-by: Sasha Levin --- drivers/gpu/drm/amd/amdgpu/amdgpu_display.c | 7 +++++++ drivers/gpu/drm/amd/amdgpu/amdgpu_mode.h | 2 ++ 2 files changed, 9 insertions(+) diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c index 6748cd7fc129..686a26de50f9 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_display.c @@ -626,6 +626,13 @@ int amdgpu_display_modeset_create_props(struct amdgpu_device *adev) "dither", amdgpu_dither_enum_list, sz); + if (amdgpu_device_has_dc_support(adev)) { + adev->mode_info.max_bpc_property = + drm_property_create_range(adev->ddev, 0, "max bpc", 8, 16); + if (!adev->mode_info.max_bpc_property) + return -ENOMEM; + } + return 0; } diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_mode.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_mode.h index b9e9e8b02fb7..d1b4d9b6aae0 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_mode.h +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_mode.h @@ -339,6 +339,8 @@ struct amdgpu_mode_info { struct drm_property *audio_property; /* FMT dithering */ struct drm_property *dither_property; + /* maximum number of bits per channel for monitor color */ + struct drm_property *max_bpc_property; /* hardcoded DFP edid from BIOS */ struct edid *bios_hardcoded_edid; int bios_hardcoded_edid_size; -- 2.19.1