Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3668432imm; Mon, 30 Jul 2018 01:01:37 -0700 (PDT) X-Google-Smtp-Source: AAOMgpczhQt4GUUiqgFhtRrJiytHtsqm+kgITx7i/e1MD4r+0sb7jlR/u4KQVrjXtfKwhHmY2dqf X-Received: by 2002:a17:902:5617:: with SMTP id h23-v6mr15391411pli.324.1532937697624; Mon, 30 Jul 2018 01:01:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532937697; cv=none; d=google.com; s=arc-20160816; b=Jf4iVQnyJ2f8i7C+jUCHfBsjxkElBntym2++dZGcCAV5mbVDsmrkFS5i+uUDwxDpAh +ZdBbSnAc3ITaw0y67BaFP935QYN3WNB6isFOnaNR7OaGzqCiqWNBBZkKwSZj8bfUNuh Wa/a+7cJr3bSEFcv19T9TaXroh5haXa9ZE1DzdV96e64FRq2FyEF7t73K/fXawiZ9axz 0RfYdU5x2tQPVz7Nu5AgaK9rxEembopMTc4FWlR4ZDH3pWt5jlKsfTA8A9eFEqm9jWy3 iNCczlRx/nib03mfnCka0pOsCnqnDcOUbQ22XVImvOz/So4cTKkqM67LYaDnY2Ygnny5 033A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=zopT0Rk/q653bg8leMTEl3OM6JVyP4+Lm/mP6mOiovM=; b=T7kIsan7RAXei+MEfDX6mgLm99xFgcPVxi8KTDJL/ashfoVxbXk8uvVfLvLdFIiNjZ 2fdzOuyNbHvQ7jzmhClUbme+zljHQFFS0H+kB5UzaUbTPNyhiDBxF2Wxnhkyb1rAh2Lj 3FgtpwifnjoznM+ptsKUW425xlLY6CoLZ6G7+/eL073zmKcpI6cBPSXx5bp4tyG2foGn K+z0S5a5ucZzFl4mdeL06g+gELqkYXbO3HupPoDvUkXpPRxyJnfnFyz5iJoHn1WMF/qf r+GcjD5nPJaeU5L6dZ6YgxjFt8Bu65xrEfMhbtlNp/Igi4K9Xkb42T4vGvA9sQi08WA4 B0hg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 28-v6si10868902pgk.111.2018.07.30.01.01.15; Mon, 30 Jul 2018 01:01:37 -0700 (PDT) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726695AbeG3JeC (ORCPT + 99 others); Mon, 30 Jul 2018 05:34:02 -0400 Received: from mga14.intel.com ([192.55.52.115]:35346 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726401AbeG3JeB (ORCPT ); Mon, 30 Jul 2018 05:34:01 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 30 Jul 2018 01:00:16 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.51,422,1526367600"; d="scan'208";a="68566893" Received: from chanse1-mobl.ger.corp.intel.com (HELO [10.252.51.109]) ([10.252.51.109]) by FMSMGA003.fm.intel.com with ESMTP; 30 Jul 2018 01:00:12 -0700 Subject: Re: [PATCH] drm/kms/atomic: Improved the func drm_atomic_set_crtc_for_connector To: Satendra Singh Thakur , Gustavo Padovan , Sean Paul , David Airlie , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Cc: vineet.j@samsung.com, hemanshu.s@samsung.com, sst2005@gmail.com References: <20180730061450epcas5p137fd022ec7fda83eeadea2102a62ae4f~GEOMmSYCD1391313913epcas5p1G@epcas5p1.samsung.com> From: Maarten Lankhorst Message-ID: <4fd92ffb-2518-1e9a-881e-5f4b0e4d4922@linux.intel.com> Date: Mon, 30 Jul 2018 10:00:08 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20180730061450epcas5p137fd022ec7fda83eeadea2102a62ae4f~GEOMmSYCD1391313913epcas5p1G@epcas5p1.samsung.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Op 30-07-18 om 08:14 schreef Satendra Singh Thakur: > a. Used drm_atomic_get_crtc_state instead of drm_atomic_get_new_crtc_state. > Anyway new_state and state are same, this should make no difference. > This change will make the code of this func and the func > drm_atomic_set_crtc_for_plane similar. > b. Added error checking after this func call > c. Currently conn_state->crtc is getting assigned a value at two places > We can just reduce this assignment to one > > Signed-off-by: Satendra Singh Thakur > --- > drivers/gpu/drm/drm_atomic.c | 9 ++++----- > 1 file changed, 4 insertions(+), 5 deletions(-) > > diff --git a/drivers/gpu/drm/drm_atomic.c b/drivers/gpu/drm/drm_atomic.c > index 895741e..907fb2d 100644 > --- a/drivers/gpu/drm/drm_atomic.c > +++ b/drivers/gpu/drm/drm_atomic.c > @@ -1552,16 +1552,16 @@ drm_atomic_set_crtc_for_connector(struct drm_connector_state *conn_state, > return 0; > > if (conn_state->crtc) { > - crtc_state = drm_atomic_get_new_crtc_state(conn_state->state, > + crtc_state = drm_atomic_get_crtc_state(conn_state->state, > conn_state->crtc); > + if (IS_ERR(crtc_state)) > + return PTR_ERR(crtc_state); The error checking is not required when using drm_atomic_get_new_crtc_state, because the end of drm_atomic_get_connector_state() will fetch it for us. The other place where conn_state->crtc is assigned is in drm_atomic_set_crtc_for_connector(), which also makes sure we have the crtc_state part of the commit. It would be a bug if we would have a conn_state without conn_state->crtc's state. Did you hit a crash here? > crtc_state->connector_mask &= > ~(1 << drm_connector_index(conn_state->connector)); > > drm_connector_put(conn_state->connector); > - conn_state->crtc = NULL; > } > - > if (crtc) { > crtc_state = drm_atomic_get_crtc_state(conn_state->state, crtc); > if (IS_ERR(crtc_state)) > @@ -1571,7 +1571,6 @@ drm_atomic_set_crtc_for_connector(struct drm_connector_state *conn_state, > 1 << drm_connector_index(conn_state->connector); > > drm_connector_get(conn_state->connector); > - conn_state->crtc = crtc; > > DRM_DEBUG_ATOMIC("Link connector state %p to [CRTC:%d:%s]\n", > conn_state, crtc->base.id, crtc->name); > @@ -1579,7 +1578,7 @@ drm_atomic_set_crtc_for_connector(struct drm_connector_state *conn_state, > DRM_DEBUG_ATOMIC("Link connector state %p to [NOCRTC]\n", > conn_state); > } > - > + conn_state->crtc = crtc; > return 0; > } > EXPORT_SYMBOL(drm_atomic_set_crtc_for_connector); ~Maarten