Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp328429imm; Thu, 31 May 2018 00:49:56 -0700 (PDT) X-Google-Smtp-Source: ADUXVKI9I9r8zleC6eCkARQPWz3MuN0n2QqTkGEEruK4LCCj2UZGMADMK2KRVMw0kaM8qpDScM0g X-Received: by 2002:a62:9099:: with SMTP id q25-v6mr5893384pfk.66.1527752995988; Thu, 31 May 2018 00:49:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527752995; cv=none; d=google.com; s=arc-20160816; b=AcF/r511dr2mDe/3vYj9V4eRI3m2hRbkI9pYOM3VsNXVHsuMVF1gAg3xsICFXUirBW oKUMX1nyoHT5HzjYB/KJTvFaT19nARsFAb/F1c/5j+NXzeoEUtsRj4I2xiFBWm0e54xo nghDDU62HXxm9Fc03D4mLUDnLPxFtyDen5Nrios0pxu9tE05wDOfU0Hau3M46wS/SodL H96jxRIBvl8S27VkOioyUcRHipirMAw50UdLtZSnBrzEt3yM2GnRcliXjXBRW/pUJSWt /jJQA5wwC0Z5dVG88P+7aABRSe4uleW1NjGM2Xnr49lTe8AN/pzUlkuR9h3izQRIdmar H7GA== 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=udUlesf+bb7nDaK1bS4z5PAYjSQas6uM6v6AcVTCJ8U=; b=P11Tb23sJKk7tcxDawr+c5eOsJhRXCYSD3CHeofDghAU3QFoDT7lpo0Ecp/ado/Z6E QkG2Fu9TYtm85M9Zwxr0IXUmOfYFPwqizEz5DgRdL4KKdb+e2yPDBL4RZrZWYncHxOF6 nCVp4Mw0H/ceuxu3y5ZXTMmxguoX0u9We6a2iViMcjbk9F0jg5osb6rQeRXdjDnxyU2x BpWQtnhvMpBOlTS7ZmKyRIEWYmjJpU3zLdaJwD/GC0en78wF4WXzseOcPv/tCmA72Ix7 4X6a++ntOfCWHLTjFouIor4TXYrJuFm7eglRSKx8xZ6U7TGJOty5K2U2Mm2VjVXXq4LD ujDg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=KuD0OaMt; 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 q2-v6si36491210plh.136.2018.05.31.00.49.42; Thu, 31 May 2018 00:49:55 -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=KuD0OaMt; 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 S1754074AbeEaHsX (ORCPT + 99 others); Thu, 31 May 2018 03:48:23 -0400 Received: from mail-lf0-f67.google.com ([209.85.215.67]:45242 "EHLO mail-lf0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753957AbeEaHsT (ORCPT ); Thu, 31 May 2018 03:48:19 -0400 Received: by mail-lf0-f67.google.com with SMTP id n3-v6so8301677lfe.12 for ; Thu, 31 May 2018 00:48:19 -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=udUlesf+bb7nDaK1bS4z5PAYjSQas6uM6v6AcVTCJ8U=; b=KuD0OaMtzWkgoimKnAsZ+4JuOdNjQUbMkkcAipwncsaek2DObVV9LU/IcYPNcYKSN8 B/SagRXy3mqPHkewcAsnD0sE74wQ+xIlnYpak7GXe7IO0+skYvXXz0dwzXu447MK8h80 tAK9vXhStGXcaJqEDwB1gVA+MkvRLst2vppZL4fc6CBnoRYs/oL/l3/LmRrIGfdF0rsu g5aCpZuJVTDSkWVYQ8kvamywieoZuoP5y/oWybKvcueAJDc6euWxPt1B6TDn1/3jUlUd DkOa0mqzihM+IpftvdNRpGTPksL7TehDZqgZoEaOOVqVGw3D8LdDm5bJdSoml61VgLW7 j5OA== 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=udUlesf+bb7nDaK1bS4z5PAYjSQas6uM6v6AcVTCJ8U=; b=k7Q7hG1Wm/+Wyvg/HL0a0aP+9j23Zkqgnj4iWeHOPxOi4BNudRStVgHjrA9wVVcQOv Lw/6AHyWrMGhZmj9XB15SMXMiG4QjxA/JN/o3i8yLoq7E2DyRdTLZM8F2yU+4CqTd8Xe JdEDOR6WysTVHgjpvHOcZoDe1wM8v1gJpJcH7h0d6TA6CVcbAySvo762dOD+lzSdZLTr t8KOQDX6tw63C1TWMmma5FSbc5HskIfeOXiuUq5fILua+eJM+Y81vMn6mo156DHMkmhT GxnK73iFqEzZDqFbdczguCPp2yCDK0dyzBsRd1cUOrDTrpiwknCxlQL8cCyKyOy7rUJu jMjg== X-Gm-Message-State: ALKqPwdXY8XmtmQi98DWrH0evBgMpqraD2hU/hz9tpoCKQCHHgxWEbp4 RCnEfLGH+wTzD2pNYkVyyzc= X-Received: by 2002:a2e:9ed7:: with SMTP id h23-v6mr4358423ljk.88.1527752898318; Thu, 31 May 2018 00:48:18 -0700 (PDT) Received: from [10.17.182.9] (ll-51.209.223.85.sovam.net.ua. [85.223.209.51]) by smtp.gmail.com with ESMTPSA id t133-v6sm8210128lfe.60.2018.05.31.00.48.16 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 31 May 2018 00:48:17 -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> <3427121e-ddd9-d2ba-b684-61338f0207ce@gmail.com> <20180529074933.GY3438@phenom.ffwll.local> From: Oleksandr Andrushchenko Message-ID: <4a2652b8-30d7-36f5-af3a-2053267cfa40@gmail.com> Date: Thu, 31 May 2018 10:48:16 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <20180529074933.GY3438@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:49 AM, Daniel Vetter wrote: > On Tue, May 29, 2018 at 10:09:57AM +0300, Oleksandr Andrushchenko wrote: >> 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 > Noralf's occasionally occupied with other things and doesn't have time to > look at patches. I think it's ok to just push after a few more days, even > if he doesn't respond. Same holds for other people really. > -Daniel > Applied to drm-misc-next-fixes >>> -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 >> _______________________________________________ >> dri-devel mailing list >> dri-devel@lists.freedesktop.org >> https://lists.freedesktop.org/mailman/listinfo/dri-devel