Received: by 2002:a05:6602:2086:0:0:0:0 with SMTP id a6csp4425273ioa; Wed, 27 Apr 2022 03:41:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx6mZvG1WsN58m4BtHfY84Z1UlE0s57DM1wC3+pH91PCrum0l2VrndWeUOBoatXquyJYuw1 X-Received: by 2002:a17:903:2406:b0:158:72dc:2d73 with SMTP id e6-20020a170903240600b0015872dc2d73mr28570227plo.46.1651056106505; Wed, 27 Apr 2022 03:41:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651056106; cv=none; d=google.com; s=arc-20160816; b=GjUMwPtAijUZzTCEhh+vtyw+CN0oq6DEzTAplCxKWWFlcuqwDduhOTAFy4uKxh7187 MsIHE4ae1SZCLuY5/1NC+UOVdri6L1oJi/mMpnulemThh+EuH8WoL11Bwj4K1zj2Vrrk j1eOQuBaigoy06dEkA/v9JIs3YwA6cReHqYoup/6K8f8zgwjKhG2ptNriCUz2EelFYPO wTZEMwJxK8k8nT2KrbCGK5+jQb/19WBLChYcz54DXHve7hONfaxY1mBMZ3qPr0VUIt8V CThFPcQ8EmdcLnFJPwvBm0QEWYYj/u6Polc/N2TGlBpHh2/BjbmWZ7/TBHtB0Y/rGV/i Zmog== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=yW+IVy1TYk/6dsQfiqAiApa9tYNgTKImjmG5uw6IEkk=; b=q8SwpQSu3YGJp+lk4YbDlHL1JcTxzxPYgLOfUkalAM20R9+mTtZZXR2Ci1F3ZqP0Or u0yFNY7FiUbHrf9wdrFXMlx+q636Jv+oBNtEG7IH5LdrnyqCaP2ruydtVEGwhXelruUk Xk1WPxVZMKhWk1GQrEVOoNM+7c+h+4K6oWHekQ33UF/pxVp7BEsIqcMQ/JO0dML4aeVq bfqtpJVtr9n1z80Rav7MFYhxkAftm6gtpmErE1meg6nFFZM7j50wtl6hwx32IM7q91PF LOr2pfuKadEuA3K0fw7D5zJJnH/bQIC4nhg+N77RUKev23BF1xrUmLIPYx9kBlEdPPn0 JUKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=gUztEt1f; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id e5-20020a170902e0c500b0015a1cc6686csi1082242pla.622.2022.04.27.03.41.46 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 Apr 2022 03:41:46 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=gUztEt1f; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: from out1.vger.email (out1.vger.email [IPv6:2620:137:e000::1:20]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 3751F3E8D5D; Wed, 27 Apr 2022 02:51:26 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347269AbiDZWYd (ORCPT + 99 others); Tue, 26 Apr 2022 18:24:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33220 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231913AbiDZWYa (ORCPT ); Tue, 26 Apr 2022 18:24:30 -0400 Received: from alexa-out-sd-02.qualcomm.com (alexa-out-sd-02.qualcomm.com [199.106.114.39]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2EFA71EAD2; Tue, 26 Apr 2022 15:21:21 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1651011682; x=1682547682; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=yW+IVy1TYk/6dsQfiqAiApa9tYNgTKImjmG5uw6IEkk=; b=gUztEt1fs2rQpuX+K0cMgmabLaviw67a8AnqqTIxswLDgsDmrhSgkZD+ uwZ9d88FEKdAvTCWVMAWTCaqatESSZUX25cZ6VxiIT1YnCz9ALpD2pVjl HrtSgDoT5p8zCHoARpucI+CJx9TURv0QClsLuHGfc82EtVPG6cvLXFJce A=; Received: from unknown (HELO ironmsg01-sd.qualcomm.com) ([10.53.140.141]) by alexa-out-sd-02.qualcomm.com with ESMTP; 26 Apr 2022 15:21:21 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg01-sd.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 26 Apr 2022 15:21:20 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Tue, 26 Apr 2022 15:21:20 -0700 Received: from [10.111.160.161] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Tue, 26 Apr 2022 15:21:17 -0700 Message-ID: <47bf6151-4a71-1ee1-62e6-acdf82563ff4@quicinc.com> Date: Tue, 26 Apr 2022 15:21:15 -0700 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.6.2 Subject: Re: [PATCH 1/2] drm/probe-helper: Add helper for drm_helper_probe_single_connector_modes() Content-Language: en-US To: Douglas Anderson , CC: , , , , , , , Daniel Vetter , David Airlie , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , References: <20220426114627.1.I2dd93486c6952bd52f2020904de0133970d11b29@changeid> From: Abhinav Kumar In-Reply-To: <20220426114627.1.I2dd93486c6952bd52f2020904de0133970d11b29@changeid> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01a.na.qualcomm.com (10.47.209.196) X-Spam-Status: No, score=-3.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,RDNS_NONE,SPF_HELO_NONE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/26/2022 11:46 AM, Douglas Anderson wrote: > The drm_helper_probe_single_connector_modes() is a bit long. Let's > break a chunk off to update and validate modes. This helps avoid one > goto and also will allow us to more easily call the helper a second > time in a future patch without adding looping or another goto. > > This change is intended to be a no-op change--just code movement. > > Signed-off-by: Douglas Anderson I think this cleanup looks reasonable to me. Hence, Reviewed-by: Abhinav Kumar > --- > > drivers/gpu/drm/drm_probe_helper.c | 105 ++++++++++++++++------------- > 1 file changed, 59 insertions(+), 46 deletions(-) > > diff --git a/drivers/gpu/drm/drm_probe_helper.c b/drivers/gpu/drm/drm_probe_helper.c > index 682359512996..819225629010 100644 > --- a/drivers/gpu/drm/drm_probe_helper.c > +++ b/drivers/gpu/drm/drm_probe_helper.c > @@ -354,6 +354,61 @@ drm_helper_probe_detect(struct drm_connector *connector, > } > EXPORT_SYMBOL(drm_helper_probe_detect); > > +static bool _drm_helper_update_and_validate(struct drm_connector *connector, > + uint32_t maxX, uint32_t maxY, > + struct drm_modeset_acquire_ctx *ctx) > +{ > + struct drm_device *dev = connector->dev; > + struct drm_display_mode *mode; > + int mode_flags = 0; > + int ret; > + > + drm_connector_list_update(connector); > + > + if (connector->interlace_allowed) > + mode_flags |= DRM_MODE_FLAG_INTERLACE; > + if (connector->doublescan_allowed) > + mode_flags |= DRM_MODE_FLAG_DBLSCAN; > + if (connector->stereo_allowed) > + mode_flags |= DRM_MODE_FLAG_3D_MASK; > + > + list_for_each_entry(mode, &connector->modes, head) { > + if (mode->status != MODE_OK) > + continue; > + > + mode->status = drm_mode_validate_driver(dev, mode); > + if (mode->status != MODE_OK) > + continue; > + > + mode->status = drm_mode_validate_size(mode, maxX, maxY); > + if (mode->status != MODE_OK) > + continue; > + > + mode->status = drm_mode_validate_flag(mode, mode_flags); > + if (mode->status != MODE_OK) > + continue; > + > + ret = drm_mode_validate_pipeline(mode, connector, ctx, > + &mode->status); > + if (ret) { > + drm_dbg_kms(dev, > + "drm_mode_validate_pipeline failed: %d\n", > + ret); > + > + if (drm_WARN_ON_ONCE(dev, ret != -EDEADLK)) > + mode->status = MODE_ERROR; > + else > + return true; > + } > + > + if (mode->status != MODE_OK) > + continue; > + mode->status = drm_mode_validate_ycbcr420(mode, connector); > + } > + > + return false; > +} > + > /** > * drm_helper_probe_single_connector_modes - get complete set of display modes > * @connector: connector to probe > @@ -421,7 +476,6 @@ int drm_helper_probe_single_connector_modes(struct drm_connector *connector, > const struct drm_connector_helper_funcs *connector_funcs = > connector->helper_private; > int count = 0, ret; > - int mode_flags = 0; > bool verbose_prune = true; > enum drm_connector_status old_status; > struct drm_modeset_acquire_ctx ctx; > @@ -519,52 +573,11 @@ int drm_helper_probe_single_connector_modes(struct drm_connector *connector, > connector->status == connector_status_unknown)) > count = drm_add_modes_noedid(connector, 1024, 768); > count += drm_helper_probe_add_cmdline_mode(connector); > - if (count == 0) > - goto prune; > - > - drm_connector_list_update(connector); > - > - if (connector->interlace_allowed) > - mode_flags |= DRM_MODE_FLAG_INTERLACE; > - if (connector->doublescan_allowed) > - mode_flags |= DRM_MODE_FLAG_DBLSCAN; > - if (connector->stereo_allowed) > - mode_flags |= DRM_MODE_FLAG_3D_MASK; > - > - list_for_each_entry(mode, &connector->modes, head) { > - if (mode->status != MODE_OK) > - continue; > - > - mode->status = drm_mode_validate_driver(dev, mode); > - if (mode->status != MODE_OK) > - continue; > - > - mode->status = drm_mode_validate_size(mode, maxX, maxY); > - if (mode->status != MODE_OK) > - continue; > - > - mode->status = drm_mode_validate_flag(mode, mode_flags); > - if (mode->status != MODE_OK) > - continue; > - > - ret = drm_mode_validate_pipeline(mode, connector, &ctx, > - &mode->status); > - if (ret) { > - drm_dbg_kms(dev, > - "drm_mode_validate_pipeline failed: %d\n", > - ret); > - > - if (drm_WARN_ON_ONCE(dev, ret != -EDEADLK)) { > - mode->status = MODE_ERROR; > - } else { > - drm_modeset_backoff(&ctx); > - goto retry; > - } > + if (count != 0) { > + if (_drm_helper_update_and_validate(connector, maxX, maxY, &ctx)) { > + drm_modeset_backoff(&ctx); > + goto retry; > } > - > - if (mode->status != MODE_OK) > - continue; > - mode->status = drm_mode_validate_ycbcr420(mode, connector); > } > > prune: