Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3559089imu; Mon, 24 Dec 2018 04:29:01 -0800 (PST) X-Google-Smtp-Source: AFSGD/UN3o/10oNp4YMMltu1qDtwPPh7EYpnHGxeb1nuOd/AsJR7G+u43rGrifkk4vDobiJDgsS8 X-Received: by 2002:a62:32c4:: with SMTP id y187mr13405032pfy.195.1545654541617; Mon, 24 Dec 2018 04:29:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545654541; cv=none; d=google.com; s=arc-20160816; b=SsZBJ0QVFql2hUUxWhDUtYJdlB+G8dh1SvznOzr74BoQQHXJiNYTlUkC9Et3WVAh4H 4hmSY1o1d1OZv4CGS6JuhGxwh1dQm9bwnsoAapd1ZeLKP+N6kFNbEphOKzwKZHTI+5M5 P9llwPZXqsbzV2/ZJnegZ+Sj32c/eOimRRhMwObWOfcSymflvFlM1il6MKeqb5IqGXI4 Il6a6PLPdWb8mj1Hmn76PJWaPsZB5PNc7ktVRHm6m0Cad0+w4Y/4SoDR8CJ3XXjDZeWg R6oXCuJHbPGEGyDl6OAx/QvcqBSEXgtrtAM6Zy21edbUhOyC4xAtLlQiFgx14drSs8LI nv8A== 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 :message-id:date:subject:cc:to:from; bh=9K+ADlETzIYlRrqxrpjBxSmuTsxW4CRQSOb3h+Slcto=; b=VyR8QFWb+N3qZjDhPLwr133XDystDWt4AxMpR/xe8c9j81tbXJgjBgni3FdYXFGmeJ Jx3NQ/OEkaZTL8pruL8ylPHtb1/voRsFoaqnf6E+FxC9/xLKUPNMJgCDcMmUlYIs418/ eJ6bUhRjs5kXDZNO58pCn7lFDt+JlcW1VeEtZ3Jhlv9+vUrL6pMFcY6538OjL4RkD1ch VwR2vF1v/Zl7mLiItegFP3o5Bs2qY25NvP1pGwWX3TAfi2FV/wlazuwY0R9rbznejkkN W3yU+wkaiIt1YIV8DmYd1LTA+aaPAVw7JM09yM59HaPgq8hUiPwiPlzveB77n/kKQDQi 1Vlw== ARC-Authentication-Results: i=1; mx.google.com; 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 cf16si28872401plb.227.2018.12.24.04.28.46; Mon, 24 Dec 2018 04:29:01 -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; 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 S1725918AbeLXM0Z (ORCPT + 99 others); Mon, 24 Dec 2018 07:26:25 -0500 Received: from mail.bootlin.com ([62.4.15.54]:60522 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725308AbeLXM0Z (ORCPT ); Mon, 24 Dec 2018 07:26:25 -0500 Received: by mail.bootlin.com (Postfix, from userid 110) id 23A5D20A46; Mon, 24 Dec 2018 13:26:23 +0100 (CET) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT shortcircuit=ham autolearn=disabled version=3.4.2 Received: from localhost.localdomain (aaubervilliers-681-1-38-38.w90-88.abo.wanadoo.fr [90.88.157.38]) by mail.bootlin.com (Postfix) with ESMTPSA id DBC8B206F9; Mon, 24 Dec 2018 13:26:12 +0100 (CET) From: Paul Kocialkowski To: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Cc: Eric Anholt , David Airlie , Maxime Ripard , Eben Upton , Thomas Petazzoni , Paul Kocialkowski Subject: [PATCH] drm/vc4: Allow fb modifiers early enough to fill IN_FORMATS property Date: Mon, 24 Dec 2018 13:25:51 +0100 Message-Id: <20181224122551.9912-1-paul.kocialkowski@bootlin.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The KMS mode_config elements are currently configured in vc4_kms_load, that is called after all components are binded (component_bind_all). However, the CRTC component (for the Pixel Valve) needs to access the allow_fb_modifiers element at bind time, when initializing its planes through drm_universal_plane_init. This helpers checks allow_fb_modifiers to decide whether to fill the IN_FORMATS property. Because allow_fb_modifiers is still set to false at this point, the property is never filled and userspace cannot retrieve the combination of supported formats and modifiers. Fix this by setting allow_fb_modifiers right after calling drm_mode_config_init (which initializes the structure), before binding the components of the driver. Fixes: 423ad7b3cbd1 ("drm/vc4: Advertise supported modifiers for planes") Signed-off-by: Paul Kocialkowski --- drivers/gpu/drm/vc4/vc4_drv.c | 1 + drivers/gpu/drm/vc4/vc4_kms.c | 1 - 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/gpu/drm/vc4/vc4_drv.c b/drivers/gpu/drm/vc4/vc4_drv.c index 7195a0bcceb3..5c24f80dd34e 100644 --- a/drivers/gpu/drm/vc4/vc4_drv.c +++ b/drivers/gpu/drm/vc4/vc4_drv.c @@ -273,6 +273,7 @@ static int vc4_drm_bind(struct device *dev) goto dev_put; drm_mode_config_init(drm); + drm->mode_config.allow_fb_modifiers = true; vc4_gem_init(drm); diff --git a/drivers/gpu/drm/vc4/vc4_kms.c b/drivers/gpu/drm/vc4/vc4_kms.c index b0cbb869f659..b70931fd8cf0 100644 --- a/drivers/gpu/drm/vc4/vc4_kms.c +++ b/drivers/gpu/drm/vc4/vc4_kms.c @@ -530,7 +530,6 @@ int vc4_kms_load(struct drm_device *dev) dev->mode_config.funcs = &vc4_mode_funcs; dev->mode_config.preferred_depth = 24; dev->mode_config.async_page_flip = true; - dev->mode_config.allow_fb_modifiers = true; drm_modeset_lock_init(&vc4->ctm_state_lock); -- 2.20.1