Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp505160pxj; Fri, 7 May 2021 13:34:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwgS2ayCOgUTjvoLG6mk3wTWn7HUy0B9RUhcRWl8kNgISg1QkT+G5a3kkl07wXdsc13xIvG X-Received: by 2002:a17:90a:f491:: with SMTP id bx17mr25916464pjb.176.1620419673305; Fri, 07 May 2021 13:34:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620419673; cv=none; d=google.com; s=arc-20160816; b=bzDu+APzryhndKVyOBwXGC88tubmgOq98XdosvlECtf2iKxnYv+lNP0vZGHtytqjkk Klol7sfzYo+RxkAbPZmi+XdSd0vq7IoeAnvTMFJv3Y/O4tj7JkEct4E9nAwqH4vSZiP/ lzlFTLMonHV5j3n0594cbQH5X5Z6w02Ct+XId6+MovP184L6YS+WEwiZXluUwNOQ1GFG DxwXkJy+637HTRM2gOVK7uraaUR7UCU6z7QmDHjfsK3eFVbfp5mDYXHYLcFEegV8mg5C OrTVYszm9lpa51XFInKNsbefuDH0XuQ9O6jR/WJ3H7jAtinwWYq7SNKOGv0d6c9Kb7bV JbKA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=T9SpMzl1q+s1906Os/AnP69uN9aGkDuHBQjjuLERysg=; b=B2CmcYZxBlZgQ3WTxPoaigMrs2BwtyHC1hmKkR9HrciYVNG2YT+sfeKXXjJmyOgO8c ErTctPzkIXnKb5gAAam2zJh/lcROfPAUs/9BRtMTZZG4kXXs76GzvWaJYZpvIKRCW2Cg 2Srvu8WdK/MaFoaemLHziqeBVRqcr5cnEQiBdrGbtexrV4iZg7+Bn16n/jR1bd8oavVg 911vmVjMW9Qs6NzrE7iZEZcu9YNFzb1T/2ogSbmUGZcaN5EOoat0y1uQjYjsDuRd5I91 tr28hb5fqTGeVzBaX4GDTYaNvf0kslA6B+lEVfJjBZw+mvZNXlH7Ysw2SA8Ss7Bqb+H8 fi7g== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t7si8439281pfh.14.2021.05.07.13.34.19; Fri, 07 May 2021 13:34:33 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230166AbhEGUeK (ORCPT + 99 others); Fri, 7 May 2021 16:34:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52066 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229675AbhEGUeK (ORCPT ); Fri, 7 May 2021 16:34:10 -0400 Received: from srv6.fidu.org (srv6.fidu.org [IPv6:2a01:4f8:231:de0::2]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 88A31C061574 for ; Fri, 7 May 2021 13:33:09 -0700 (PDT) Received: from localhost (localhost.localdomain [127.0.0.1]) by srv6.fidu.org (Postfix) with ESMTP id 1621FC800A2; Fri, 7 May 2021 22:33:07 +0200 (CEST) X-Virus-Scanned: Debian amavisd-new at srv6.fidu.org Received: from srv6.fidu.org ([127.0.0.1]) by localhost (srv6.fidu.org [127.0.0.1]) (amavisd-new, port 10024) with LMTP id OmTbmMgJ_Wnx; Fri, 7 May 2021 22:33:06 +0200 (CEST) Received: from [IPv6:2003:e3:7f12:f200:d51b:e97d:b8e4:23b2] (p200300E37f12F200d51be97dB8e423B2.dip0.t-ipconnect.de [IPv6:2003:e3:7f12:f200:d51b:e97d:b8e4:23b2]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: wse@tuxedocomputers.com) by srv6.fidu.org (Postfix) with ESMTPSA id 53E38C800A1; Fri, 7 May 2021 22:33:06 +0200 (CEST) Subject: Re: [PATCH v6 1/3] drm/i915/display: New function to avoid duplicate code in upcomming commits To: =?UTF-8?B?VmlsbGUgU3lyasOkbMOk?= Cc: airlied@linux.ie, daniel@ffwll.ch, intel-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20210506172325.1995964-1-wse@tuxedocomputers.com> <20210507084903.28877-1-wse@tuxedocomputers.com> <20210507084903.28877-2-wse@tuxedocomputers.com> From: Werner Sembach Message-ID: Date: Fri, 7 May 2021 22:33:05 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am 07.05.21 um 19:47 schrieb Ville Syrjälä: > On Fri, May 07, 2021 at 10:49:01AM +0200, Werner Sembach wrote: >> Moves some checks that later will be performed 2 times to an own function. >> This avoids duplicate code later on. >> >> Signed-off-by: Werner Sembach >> --- >> drivers/gpu/drm/i915/display/intel_hdmi.c | 41 ++++++++++++++--------- >> 1 file changed, 26 insertions(+), 15 deletions(-) >> >> diff --git a/drivers/gpu/drm/i915/display/intel_hdmi.c b/drivers/gpu/drm/i915/display/intel_hdmi.c >> index 46de56af33db..576d3d910d06 100644 >> --- a/drivers/gpu/drm/i915/display/intel_hdmi.c >> +++ b/drivers/gpu/drm/i915/display/intel_hdmi.c >> @@ -1861,6 +1861,31 @@ static int intel_hdmi_port_clock(int clock, int bpc) >> return clock * bpc / 8; >> } >> >> +static enum drm_mode_status >> +intel_hdmi_mode_clock_valid(struct intel_hdmi *hdmi, int clock, bool has_hdmi_sink) >> +{ >> + struct drm_device *dev = intel_hdmi_to_dev(hdmi); >> + struct drm_i915_private *dev_priv = to_i915(dev); >> + enum drm_mode_status status; >> + >> + /* check if we can do 8bpc */ >> + status = hdmi_port_clock_valid(hdmi, clock, true, has_hdmi_sink); >> + >> + if (has_hdmi_sink) { >> + /* if we can't do 8bpc we may still be able to do 12bpc */ >> + if (status != MODE_OK && !HAS_GMCH(dev_priv)) >> + status = hdmi_port_clock_valid(hdmi, clock * 3 / 2, > Seems we've lost intel_hdmi_port_clock() here somehow. Yes, I think it happened when I rebased from torvalds/master to drm-tip/drm-tip. Thanks for pointing it out. Fixed. > >> + true, has_hdmi_sink); >> + >> + /* if we can't do 8,12bpc we may still be able to do 10bpc */ >> + if (status != MODE_OK && INTEL_GEN(dev_priv) >= 11) >> + status = hdmi_port_clock_valid(hdmi, clock * 5 / 4, > Also here. > >> + true, has_hdmi_sink); >> + } >> + >> + return status; >> +} >> + >> static enum drm_mode_status >> intel_hdmi_mode_valid(struct drm_connector *connector, >> struct drm_display_mode *mode) >> @@ -1891,21 +1916,7 @@ intel_hdmi_mode_valid(struct drm_connector *connector, >> if (drm_mode_is_420_only(&connector->display_info, mode)) >> clock /= 2; >> >> - /* check if we can do 8bpc */ >> - status = hdmi_port_clock_valid(hdmi, intel_hdmi_port_clock(clock, 8), >> - true, has_hdmi_sink); >> - >> - if (has_hdmi_sink) { >> - /* if we can't do 8bpc we may still be able to do 12bpc */ >> - if (status != MODE_OK && !HAS_GMCH(dev_priv)) >> - status = hdmi_port_clock_valid(hdmi, intel_hdmi_port_clock(clock, 12), >> - true, has_hdmi_sink); >> - >> - /* if we can't do 8,12bpc we may still be able to do 10bpc */ >> - if (status != MODE_OK && DISPLAY_VER(dev_priv) >= 11) >> - status = hdmi_port_clock_valid(hdmi, intel_hdmi_port_clock(clock, 10), >> - true, has_hdmi_sink); >> - } >> + status = intel_hdmi_mode_clock_valid(hdmi, clock, has_hdmi_sink); >> if (status != MODE_OK) >> return status; >> >> -- >> 2.25.1