Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1530057imu; Thu, 13 Dec 2018 17:30:13 -0800 (PST) X-Google-Smtp-Source: AFSGD/UBUGRWU9RbF5R71G4qBVgsmThaOO2tdea5cr0V4hKqRfC/3DvxMCm6imRl3HVXeU09Uw9o X-Received: by 2002:a63:4c5:: with SMTP id 188mr945602pge.391.1544751013118; Thu, 13 Dec 2018 17:30:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544751013; cv=none; d=google.com; s=arc-20160816; b=tT15zGCdKnbAQ++g2yorgVfcXHOOZTeHfcDzbVGGV71j8zHapLMKDv8/mXaRslUhTO rPE+sampgavLD2jep5JIhlVSShiDs6SGc/wEPAn4XW1zHA28V0lFscsjqSaOtgfSLIAn uBP9dAP7f3Psqh9kMEQO8PGrYOzszAnQmqD2o/I1SxFMjdNh726JTEa1pW8DjWonii/t dgm6eFg3QqMgealrJyzXU7e1FobJkeT8RkpLh7TcK6cDOrzh32cV/1dvsKPr+FnNpzT5 Q/GxjEv9qBlDflrqeWCCa2Xkou3sjzcbs4VbNzDkwDyOEn37jXqUxZ4nkLi2Qr3ljQ27 /V2w== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=8BFza9GM8aPDwQrUbgUUTpR+SXVf5I2QFe9sAe8JYgY=; b=FIVmSuYllque37+PObXQioUt54v0JN3KSJLlRc/GmFv1or3r1PExpWAaT8QHjFs+qR GZbdWMpdBTYghI77ih7637f42OW9mpOUaoJjlWUO3RN1/QS6aFT3GqbxJJqmQqYaZSx3 /xfrkDPm3br0lQZlpEn1ElJ6/4RdTx/Gh/fy9WHQXLb8r7uG23C2/WA4s1dVkHATcsfx /wnafL4yE52ufJEtCjl5VZtE1Ws5CYj5BJRrxfD/BRmu/bQfH4fAOswRSpUxnWU4OkPL WlZ8C0LbVj8wrlgnhKvs7NWqKh3BYW+I9Buj1ZU9iNZfn/Ky1gY3wJHanOmIjfNIbZ4p EoHQ== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a16si2704208pls.146.2018.12.13.17.29.58; Thu, 13 Dec 2018 17:30:13 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729604AbeLNB1H (ORCPT + 99 others); Thu, 13 Dec 2018 20:27:07 -0500 Received: from mx1.redhat.com ([209.132.183.28]:58614 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729014AbeLNB1E (ORCPT ); Thu, 13 Dec 2018 20:27:04 -0500 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id D8013307EAA5; Fri, 14 Dec 2018 01:27:03 +0000 (UTC) Received: from malachite.bss.redhat.com (dhcp-10-20-1-11.bss.redhat.com [10.20.1.11]) by smtp.corp.redhat.com (Postfix) with ESMTP id 571386012B; Fri, 14 Dec 2018 01:27:02 +0000 (UTC) From: Lyude Paul To: dri-devel@lists.freedesktop.org, nouveau@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, amd-gfx@lists.freedesktop.org Cc: Daniel Vetter , Dave Airlie , Harry Wentland , Jerry Zuo , Ben Skeggs , David Airlie , Ilia Mirkin , Sean Paul , linux-kernel@vger.kernel.org Subject: [WIP PATCH 10/15] drm/nouveau: Stop unsetting mstc->port, use malloc refs Date: Thu, 13 Dec 2018 20:25:39 -0500 Message-Id: <20181214012604.13746-11-lyude@redhat.com> In-Reply-To: <20181214012604.13746-1-lyude@redhat.com> References: <20181214012604.13746-1-lyude@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.44]); Fri, 14 Dec 2018 01:27:04 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Same as we did for i915, but for nouveau this time. Additionally, we grab a malloc reference to the port that lasts for the entire lifetime of nv50_mstc, which gives us the guarantee that mstc->port will always point to valid memory for as long as the mstc stays around. Signed-off-by: Lyude Paul --- drivers/gpu/drm/nouveau/dispnv50/disp.c | 18 +++++------------- 1 file changed, 5 insertions(+), 13 deletions(-) diff --git a/drivers/gpu/drm/nouveau/dispnv50/disp.c b/drivers/gpu/drm/nouveau/dispnv50/disp.c index 982054bbcc8b..157d208d37b5 100644 --- a/drivers/gpu/drm/nouveau/dispnv50/disp.c +++ b/drivers/gpu/drm/nouveau/dispnv50/disp.c @@ -709,8 +709,7 @@ nv50_msto_cleanup(struct nv50_msto *msto) NV_ATOMIC(drm, "%s: msto cleanup\n", msto->encoder.name); - if (mstc->port) - drm_dp_mst_deallocate_vcpi(&mstm->mgr, mstc->port); + drm_dp_mst_deallocate_vcpi(&mstm->mgr, mstc->port); msto->mstc = NULL; msto->head = NULL; @@ -735,7 +734,7 @@ nv50_msto_prepare(struct nv50_msto *msto) }; NV_ATOMIC(drm, "%s: msto prepare\n", msto->encoder.name); - if (mstc->port && mstc->port->vcpi.vcpi > 0) { + if (mstc->port->vcpi.vcpi > 0) { struct drm_dp_payload *payload = nv50_msto_payload(msto); if (payload) { args.vcpi.start_slot = payload->start_slot; @@ -832,8 +831,7 @@ nv50_msto_disable(struct drm_encoder *encoder) struct nv50_mstc *mstc = msto->mstc; struct nv50_mstm *mstm = mstc->mstm; - if (mstc->port) - drm_dp_mst_reset_vcpi_slots(&mstm->mgr, mstc->port); + drm_dp_mst_reset_vcpi_slots(&mstm->mgr, mstc->port); mstm->outp->update(mstm->outp, msto->head->base.index, NULL, 0, 0); mstm->modified = true; @@ -945,7 +943,7 @@ nv50_mstc_detect(struct drm_connector *connector, bool force) enum drm_connector_status conn_status; int ret; - if (!mstc->port) + if (drm_connector_is_unregistered(connector)) return connector_status_disconnected; ret = pm_runtime_get_sync(connector->dev->dev); @@ -966,8 +964,7 @@ nv50_mstc_destroy(struct drm_connector *connector) struct nv50_mstc *mstc = nv50_mstc(connector); drm_connector_cleanup(&mstc->connector); - if (mstc->port) - drm_dp_mst_put_port_malloc(mstc->port); + drm_dp_mst_put_port_malloc(mstc->port); kfree(mstc); } @@ -1081,11 +1078,6 @@ nv50_mstm_destroy_connector(struct drm_dp_mst_topology_mgr *mgr, drm_fb_helper_remove_one_connector(&drm->fbcon->helper, &mstc->connector); - drm_modeset_lock(&drm->dev->mode_config.connection_mutex, NULL); - drm_dp_mst_put_port_malloc(mstc->port); - mstc->port = NULL; - drm_modeset_unlock(&drm->dev->mode_config.connection_mutex); - drm_connector_put(&mstc->connector); } -- 2.19.2