Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3082433imm; Tue, 29 May 2018 00:12:13 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoRW3BwyAkPX33f47k4MPWq62jLHbMnoDKI1GVcjduOH2NLPLDSqZ8l8lVKP3Bnmezzcdrj X-Received: by 2002:a17:902:9344:: with SMTP id g4-v6mr16701604plp.10.1527577933366; Tue, 29 May 2018 00:12:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527577933; cv=none; d=google.com; s=arc-20160816; b=aouxYTOzCegy3ruWnSUi4GqTmr5tw7C/q4YNuYvvaOzOz64gFR+si3FL/fnCG2kD4G y8n5aqqRCBizLEdSHxFN1sb/VnjG7tdgiy1QitmgTcn9WXstlmPAUDSr9uFvdy4HDJlL 8zHnejkFfc+4vUQwkuiKnJ5lK5PoZ3KrrtMu/lSPTHxZXxyjugzNmgD1W5NT5Ju9Av0K YAm+csPo5cr45mIRQ4/PqCP9NxFY37/FlmQuhZE5nHPaFX98LKxsHwoWFbVhLYp8pU1k UWxsU7B5IGeDkAGhiQsy3Qkm8u9HTnvmRGK5AiROxENWIJjRKPKOj8LCUrJTz0Gb0O+g cIUw== 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:to:subject:dkim-signature :arc-authentication-results; bh=0RGNbkdOrx2rjh7T4lKl93WPVRjBbfC9krwecIpjkVo=; b=fnrfVJLHqQhBiBpZPXphAUj9VUitsTZH0GiM3v7+KB5GW2VlL4+LfYdLHsB3fdBr/x Th1FamnFZvWwgHIpeCMTZphNwT4XM3c2my9y7T2Sc7lG4VkLg003VkPrLNJIztg2s5Vu zgVIK14LBCuKPrWeNdA+Q2JFrcRxlZ/39it4JowAUr8z5+EO1szm0afQX/38JkKMYWpz oDDrhc/AF2iZWqr+RPLKwydmtuRpdV4l5WCQEkzAoKJ0ILnj/a7BpuYZb8UtIbmsphgG iMyorSA3ACzwUs7rrKtAfAld9aTnAO6u/ePRairNFmre2o6IreT4g7oME5ee2mZkSx+c m0Sg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=LeELgsfF; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q137-v6si32992862pfc.68.2018.05.29.00.11.59; Tue, 29 May 2018 00:12:13 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=LeELgsfF; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932317AbeE2HKC (ORCPT + 99 others); Tue, 29 May 2018 03:10:02 -0400 Received: from mail-wm0-f67.google.com ([74.125.82.67]:35426 "EHLO mail-wm0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932081AbeE2HKA (ORCPT ); Tue, 29 May 2018 03:10:00 -0400 Received: by mail-wm0-f67.google.com with SMTP id o78-v6so37608458wmg.0 for ; Tue, 29 May 2018 00:10:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:references:from:message-id:date:user-agent:mime-version :in-reply-to:content-transfer-encoding:content-language; bh=0RGNbkdOrx2rjh7T4lKl93WPVRjBbfC9krwecIpjkVo=; b=LeELgsfFsWHwlcwuyUxb4SqC7nrectKma9RZYQQZXDDncwZ8KcjFyhfJrGPHBRTZad k0LSqwDnuUkDYGB9kHtbiLY1T2N1cT17fxUhFx7CabkPc2aGMlLE2pUMOrbM2hyOx2QH SVLtT5frI/yK2n1gkKDoeXekkYv4KohiE9ciABGFEkxuc/oCnS55QialLtaDH7pamwJC GyrLM0GvYzx1cHMy30kEBfl/NwhDZItm+2X/Unnw5LutBuJyrVjMDUbG+QiIQUyReSpK ghX82Xu0m3jGh0V8g0kxB+LF5LQSjyfVuCkifQqEpTM8E8HQN4rrJEkqB/50uHcm+zcl GEYg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=0RGNbkdOrx2rjh7T4lKl93WPVRjBbfC9krwecIpjkVo=; b=goDGcHvAd61gKJuiUcEDTynEKFol5sAW9pf5newUCWOVyChI1w2vtUXBWj77XObNIi Mk2WcnpGr/X8fbyt7Tm7KWOOr7lYEPM6NxggBpEf75M5yVtTJDLXti+Ut9xaveoMzrnW vMy5LQ9wmjB/6LXLHEcb1n++Bh/lhewYQeRhcnVvj9uP53L+yk8LO8UaJuQV3FRJCdH3 s86iO7weViIEEUVl9wIYjsOlvVDwFaj/AjW7shOFu6AIKegIE6YzuPer7fBujqeJ4Y+s HUkbNP3vQA2aai7P72Uq9LdIyDya6jr6dxNhXWLu/XPVn4kGNYNawWvYmpzu1w7hsoWf NxPQ== X-Gm-Message-State: ALKqPwdZLvrRC+pcmTiXqnGSfzDb5ud729yNEuns0Py4RWH8YmMPirBu +roqVaAofHVpZ9SNzvYhyrY= X-Received: by 2002:a2e:9218:: with SMTP id k24-v6mr1133292ljg.70.1527577799364; Tue, 29 May 2018 00:09:59 -0700 (PDT) Received: from [10.17.182.9] (ll-52.209.223.85.sovam.net.ua. [85.223.209.52]) by smtp.gmail.com with ESMTPSA id h23-v6sm7165519lfj.94.2018.05.29.00.09.58 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 29 May 2018 00:09:58 -0700 (PDT) Subject: Re: [PATCH] drm: Fix possible race conditions while unplugging DRM device To: "Oleksandr_Andrushchenko@epam.com" , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, airlied@linux.ie, daniel.vetter@intel.com, seanpaul@chromium.org, gustavo@padovan.org, =?UTF-8?Q?Noralf_Tr=c3=b8nnes?= References: <20180522141304.18646-1-andr2000@gmail.com> <20180529070200.GW3438@phenom.ffwll.local> From: Oleksandr Andrushchenko Message-ID: <3427121e-ddd9-d2ba-b684-61338f0207ce@gmail.com> Date: Tue, 29 May 2018 10:09:57 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180529070200.GW3438@phenom.ffwll.local> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/29/2018 10:02 AM, Daniel Vetter wrote: > On Tue, May 22, 2018 at 05:13:04PM +0300, Oleksandr Andrushchenko wrote: >> From: Oleksandr Andrushchenko >> >> When unplugging a hotpluggable DRM device we first unregister it >> with drm_dev_unregister and then set drm_device.unplugged flag which >> is used to mark device critical sections with drm_dev_enter()/ >> drm_dev_exit() preventing access to device resources that are not >> available after the device is gone. >> But drm_dev_unregister may lead to hotplug uevent(s) fired to >> user-space on card and/or connector removal, thus making it possible >> for user-space to try accessing a disconnected device. >> >> Fix this by first making sure device is properly marked as >> disconnected and only then unregister it. >> >> Fixes: bee330f3d672 ("drm: Use srcu to protect drm_device.unplugged") >> >> Signed-off-by: Oleksandr Andrushchenko >> Reported-by: Andrii Chepurnyi >> Cc: "Noralf Trønnes" > Nice catch. > > Reviewed-by: Daniel Vetter > > I think you need to push this to drm-misc-next-fixes to make sure it's on > the 4.17 train. Sure, after I have r-b from Noralf > -Daniel > >> --- >> drivers/gpu/drm/drm_drv.c | 14 +++++++------- >> 1 file changed, 7 insertions(+), 7 deletions(-) >> >> diff --git a/drivers/gpu/drm/drm_drv.c b/drivers/gpu/drm/drm_drv.c >> index b553a6f2ff0e..7af748ed1c58 100644 >> --- a/drivers/gpu/drm/drm_drv.c >> +++ b/drivers/gpu/drm/drm_drv.c >> @@ -369,13 +369,6 @@ EXPORT_SYMBOL(drm_dev_exit); >> */ >> void drm_dev_unplug(struct drm_device *dev) >> { >> - drm_dev_unregister(dev); >> - >> - mutex_lock(&drm_global_mutex); >> - if (dev->open_count == 0) >> - drm_dev_put(dev); >> - mutex_unlock(&drm_global_mutex); >> - >> /* >> * After synchronizing any critical read section is guaranteed to see >> * the new value of ->unplugged, and any critical section which might >> @@ -384,6 +377,13 @@ void drm_dev_unplug(struct drm_device *dev) >> */ >> dev->unplugged = true; >> synchronize_srcu(&drm_unplug_srcu); >> + >> + drm_dev_unregister(dev); >> + >> + mutex_lock(&drm_global_mutex); >> + if (dev->open_count == 0) >> + drm_dev_put(dev); >> + mutex_unlock(&drm_global_mutex); >> } >> EXPORT_SYMBOL(drm_dev_unplug); >> >> -- >> 2.17.0 >> >> _______________________________________________ >> dri-devel mailing list >> dri-devel@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/dri-devel