Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp1055220lqp; Fri, 22 Mar 2024 04:28:40 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCV5SBCE6l8t9LQBp/O6lAyT+28PPQXncluDz1e4lPH/AtoFBPmkOV1XxLAEF6c2kT2p6jV0n71Drrn/n/4ecvVGCwD+UqADttyPwj5YxQ== X-Google-Smtp-Source: AGHT+IFJXEZibtzdRa4+Wgmyu7J1CuDXMsIOC+EsOfNDKfToy14EGWhBsoWfHhvqGFUVoO0exUTw X-Received: by 2002:a17:906:296a:b0:a46:eb9b:3306 with SMTP id x10-20020a170906296a00b00a46eb9b3306mr1310687ejd.37.1711106920002; Fri, 22 Mar 2024 04:28:40 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711106919; cv=pass; d=google.com; s=arc-20160816; b=B9KrZSLx+ubRC9FVkzWufVRBoH0qzLkMYSw1JdUFgPQtV0rkdfdkwvYf0L/KoHWqDy WYeERcNvXFVRy4KBg3xxdSPaWRvuA7GNUt4g+4UjN8VO7c1oA7YOVfNghKyfk851ApB1 VbA5sQzdwyKMjxX+ottEWJIlQexlx8RZ/uRomeysKN2j8FyQ2qewG/xKjhALOOhOBG3Z hy4eq9gcDxLtXo5u/qnEMoYUEwz9NY3OZ42bSKjI9Qf0G7349NODfxpEg0/4wcqCZ73Z z8X91AeoIgIVBWVwlF8IhjuHDBCwab/yCO2Vc6ban+vyv3cXSBmVQ+M/6/buycpQxGwv xACQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:dkim-signature:message-id; bh=uNC0CCmpYhCcH8TuokVlW8ASQZ45O/eH5PrkVa66tCA=; fh=YE+eNT49bRZROGmCeXQq1O38steEsxc97J45N6oQGu4=; b=YlxawzS/UekHngOsfn85R5YuyiT4VoITO1OsJJj8HRvC9sig0m9i0Z+bT4Hgd8V5+g +CQnkp2oDbND6BdRBvZku4/SEoSqLW/FwoHTpMLZJ6HEuP4dPI7Vi9pGMFroBWbGslPg lgt/t3sSaX1PSD7MbnlrEjgqCkGzC6w8dW1H4D/FpFIGAa5WVPkl2WzafKknAI9y/qvI Lg4A7OjNL2vFc48/IOivVH/o4QvNTe0N+QWRXy+gSL0QYr1TKgyP485mOyvacbEKerba 9Q1TM0IpTt5uv63WIXV1wBtt+OQFv5meImfs1GjzCrqNspluKIDqxPgnT0bXKiTyF0Vy k6yQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@linux.dev header.s=key1 header.b=IIB1jlFb; arc=pass (i=1 spf=pass spfdomain=linux.dev dkim=pass dkdomain=linux.dev dmarc=pass fromdomain=linux.dev); spf=pass (google.com: domain of linux-kernel+bounces-111365-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-111365-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.dev Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id ha15-20020a170906a88f00b00a461e7645fbsi821949ejb.413.2024.03.22.04.28.39 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 22 Mar 2024 04:28:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-111365-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@linux.dev header.s=key1 header.b=IIB1jlFb; arc=pass (i=1 spf=pass spfdomain=linux.dev dkim=pass dkdomain=linux.dev dmarc=pass fromdomain=linux.dev); spf=pass (google.com: domain of linux-kernel+bounces-111365-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-111365-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.dev Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id B86C81F22167 for ; Fri, 22 Mar 2024 11:28:39 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id CC0B93F9C2; Fri, 22 Mar 2024 11:28:30 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=linux.dev header.i=@linux.dev header.b="IIB1jlFb" Received: from out-184.mta0.migadu.com (out-184.mta0.migadu.com [91.218.175.184]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id DBFAA3EA66 for ; Fri, 22 Mar 2024 11:28:26 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=91.218.175.184 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711106910; cv=none; b=OGuBIpa5wImwwI+aViV76eqelfCZ78ctvcs9G5q1EadofQ0n5FeLAiqPR82hSmx71hkTKWN7jxa96zVv2YnLkgUg8z2ibdhns5BNRzlFaCVuV6lFc1mWgOyPQwAnmUpvOeVi56aUy7Se2sONIUET2yjEfu6Mw4RvoSaOYrohx3w= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711106910; c=relaxed/simple; bh=CknH/9xSPoJ1WEhhL4MAsXBaxhXJfc/14SdBokj/AFE=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=N8FQSM9YOYanlxxmvDIGvMQS2WprTpPpQ99WDbSiB2AXnvKsE9yTAA+BlmW65eWg4D+FKJpPNh3mCBUsQB0XBkxmAbEjaHS1v5E9UIkZQi/3IzYLopv0URIwSPZQOVK+NMjc7kqlfpM0g6lY8AEcok+mqR+uxJ7L4HRewjdOMlA= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linux.dev; spf=pass smtp.mailfrom=linux.dev; dkim=pass (1024-bit key) header.d=linux.dev header.i=@linux.dev header.b=IIB1jlFb; arc=none smtp.client-ip=91.218.175.184 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linux.dev Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linux.dev Message-ID: <6ea523f5-2628-4269-9194-dfb6bf07f4db@linux.dev> DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.dev; s=key1; t=1711106904; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=uNC0CCmpYhCcH8TuokVlW8ASQZ45O/eH5PrkVa66tCA=; b=IIB1jlFbZEqqghgVkJSf3iJOkGODQW2yz0EtVMKFmrmwi5YI2/k1T2ZNs9yLzICh1yGzfQ b1OTU/sKMALlLoLwIIS9N1aYn9LrVET8//z8YRlHr6aB6o3zKvgaSyCkjkTc47+pKf+/tF FzT2awU6tMmBerhJCJI7vciw4oeFL34= Date: Fri, 22 Mar 2024 19:28:08 +0800 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Subject: Re: [v10,20/27] drm/connector: hdmi: Add Infoframes generation To: Jani Nikula , Maxime Ripard , Maarten Lankhorst , Thomas Zimmermann , David Airlie , Daniel Vetter , Jonathan Corbet , Sandy Huang , =?UTF-8?Q?Heiko_St=C3=BCbner?= , Chen-Yu Tsai , Jernej Skrabec , Samuel Holland Cc: Hans Verkuil , Sebastian Wick , =?UTF-8?B?VmlsbGUgU3lyasOkbMOk?= , dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-sunxi@lists.linux.dev References: <20240321-kms-hdmi-connector-state-v10-20-e6c178361898@kernel.org> <07125064-2a78-4515-bb48-655f2aec140f@linux.dev> <87sf0iliyh.fsf@intel.com> Content-Language: en-US X-Report-Abuse: Please report any abuse attempt to abuse@migadu.com and include these headers. From: Sui Jingfeng In-Reply-To: <87sf0iliyh.fsf@intel.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Migadu-Flow: FLOW_OUT Hi, On 2024/3/22 17:22, Jani Nikula wrote: > On Fri, 22 Mar 2024, Sui Jingfeng wrote: >> Hi, >> >> >> On 2024/3/21 23:29, Maxime Ripard wrote: >>> Infoframes in KMS is usually handled by a bunch of low-level helpers >>> that require quite some boilerplate for drivers. This leads to >>> discrepancies with how drivers generate them, and which are actually >>> sent. >>> >>> Now that we have everything needed to generate them in the HDMI >>> connector state, we can generate them in our common logic so that >>> drivers can simply reuse what we precomputed. >>> >>> Signed-off-by: Maxime Ripard >>> --- >>> drivers/gpu/drm/Kconfig | 1 + >>> drivers/gpu/drm/drm_atomic_state_helper.c | 338 +++++++++++++++++++++ >>> drivers/gpu/drm/drm_connector.c | 14 + >>> .../gpu/drm/tests/drm_atomic_state_helper_test.c | 1 + >>> drivers/gpu/drm/tests/drm_connector_test.c | 12 + >>> include/drm/drm_atomic_state_helper.h | 8 + >>> include/drm/drm_connector.h | 109 +++++++ >>> 7 files changed, 483 insertions(+) >>> >>> diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig >>> index 16029435b750..3d3193c7aa5f 100644 >>> --- a/drivers/gpu/drm/Kconfig >>> +++ b/drivers/gpu/drm/Kconfig >>> @@ -97,10 +97,11 @@ config DRM_KUNIT_TEST >>> If in doubt, say "N". >>> >>> config DRM_KMS_HELPER >>> tristate >>> depends on DRM >>> + select DRM_DISPLAY_HDMI_HELPER >> Should we select DRM_DISPLAY_HELPER here? Otherwise there will have some compile error >> emerged with default config. > Can we stop abusing select instead of adding more selects to paper over > the issues? > > Use select only for non-visible symbols (no prompts anywhere) and for > symbols with no dependencies. OK, fine. You probably want to tell us a concrete method, then we will follow. But I guess that is up to Maxime will adopt it or not. Probably need some discussion then. > > BR, > Jani. > -- Best regards, Sui