Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1610837imm; Mon, 3 Sep 2018 05:07:17 -0700 (PDT) X-Google-Smtp-Source: ANB0VdbJuE6Hycjwp2ddWJbRcdbbMoUcIcz3z8yM7ShiSj+mpiupSGXV0r15NSx1tBu2rxIM3fYV X-Received: by 2002:a17:902:d24:: with SMTP id 33-v6mr27528274plu.211.1535976437041; Mon, 03 Sep 2018 05:07:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535976437; cv=none; d=google.com; s=arc-20160816; b=u3DLZmWevfUUJJXbaJjW2clKRwYcCwixNOI4oFL3mr8DIIdLLjkwKTHPPEspD3P1vh Qy9Txz5SfwYDATMmKHnk1wCdiE0/C8LqjLIo0yjQLHB18DnSLM3DmtS2REaLu76PbDwY BBvsYF108BloultUfTBGCoiwvX3TOA9XoUQO10MzSKccZEK38i07jaUHPgBbNDiWZlwx dH8JxE6uUZXCc3N8Onbf7d5HMIdzCqL8uaHS7LZqof58xzS26a/VSjZgCWqsreAvEscN K43ELDRylB42SJHi5ZgrT7QV19xEd10HU9acxjZ7INu08uJ2tMDOSwaJdDbi9mUNMYnK CS9Q== 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:reply-to:dkim-signature :arc-authentication-results; bh=XmlH+vjlCUvCJegkf+onBk0FnlaHOrdJmdKR0a5enRY=; b=Vg2yI+IjqQ4gxqCgc5OgYu7GXzc5KHdfPiDEy73cQs+bFcilojwm4f0TqPV71o06eg 7p+lzco82siJyG1t9r2LRCNE4EMKK/i6TRGgRtNvxOZeExw++ziIIukOXA06n51HLRC9 YRdzNWC9gX9YuPcqcwnnpu+qTAr56QSVAe6xDCAMgovO/Hhz5fmFkhF843GiPgtTMlZ8 pO9nQGVqm8u1avHYgevZ9N2/AJU3kL8X1NjppX67Gj6926IRyNKxCzmfKxgguZJC7S6D K6h95R6qHuXnTUgISR/Rd52ZOFIiFCfOJ4xmohVBnWRjQDIXqugAJXEJhc4TpT/eUtWx Zglg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=gOBfWoZy; 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 205-v6si17456439pgd.271.2018.09.03.05.07.02; Mon, 03 Sep 2018 05:07:17 -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=gOBfWoZy; 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 S1727714AbeICQZh (ORCPT + 99 others); Mon, 3 Sep 2018 12:25:37 -0400 Received: from mail-wm0-f66.google.com ([74.125.82.66]:51262 "EHLO mail-wm0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727186AbeICQZh (ORCPT ); Mon, 3 Sep 2018 12:25:37 -0400 Received: by mail-wm0-f66.google.com with SMTP id y2-v6so954013wma.1 for ; Mon, 03 Sep 2018 05:05:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=reply-to:subject:to:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=XmlH+vjlCUvCJegkf+onBk0FnlaHOrdJmdKR0a5enRY=; b=gOBfWoZyyGPjCi4B6sjyJrKRe34qr2h2vfdSobaHSlf3PY934eFWetE8gDmoa+IZHy kG3iX7+NOuOxx4F82Fgr0/pvtlY0GTpg94m2PynMQblLhBn4/eofuTbMgR9UFKjbI4Vr 1RyhEJBCXbG8s8jXpgbGMqBjq2F0n4E//Oz8V5geJsUzb4RghZ9dT7WsWchsOhQxPfy1 mNFJLxNqVcY/IA0/+tn6i5QzAtJ/NVbwQoUauneKOu91ji6CZjeFsHOUdZHcOHH8VfTA UtX+JNIwn6P/CGKk1jCJ45DWiwo1SygVUwTYwz1aUnZwcpGKlfn05tW/AFBh1ZFKaUBP jFYA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:reply-to:subject:to:references:from:message-id :date:user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=XmlH+vjlCUvCJegkf+onBk0FnlaHOrdJmdKR0a5enRY=; b=mEoKKVF1VE8jUjYqV/IcGARN3/6NZ9sY5VGXDFs4TTcP15I0/m1q6dS8S4giDVdqaL 5BPlIEPaJaxb+HoA0cgR8869l5/wPcZAN9s4ICDoTcp4JsvWvv7rzgEo8gbIORSu5fVN V8rYJsY/2PO7hNoBAQxbh7HVMyCDthO5HK9WuExUeZzQD5wIoZoUF+Dh7eyLoWt+7jEW 97iMTaxELuvbXHSxM1oCAid+wyspt5pz2gDLRkxaTF8/i2LxHlWaPun4sgtvza4JCZV9 cgWXajy8z2ifu9zTObhcBzb+9BFQk/RH1nCG1Cqm6yU6knkrHZoeRuJSa8PLs5v98dWo zFyA== X-Gm-Message-State: APzg51Bc2p72zkXUj7RDPaM0nWrzYa4LHUbUtoYpa7EUWkjfLFy5UbXV 4I+CGY23OC+wsNDq2rJvhv8= X-Received: by 2002:a1c:4e16:: with SMTP id g22-v6mr5349693wmh.111.1535976344383; Mon, 03 Sep 2018 05:05:44 -0700 (PDT) Received: from ?IPv6:2a02:908:1257:4460:1ab8:55c1:a639:6740? ([2a02:908:1257:4460:1ab8:55c1:a639:6740]) by smtp.gmail.com with ESMTPSA id l10-v6sm18456319wre.0.2018.09.03.05.05.43 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 03 Sep 2018 05:05:43 -0700 (PDT) Reply-To: christian.koenig@amd.com Subject: Re: [PATCH] gpu: drm: drm_mm: Fix a sleep-in-atomic-context bug in show_leaks() To: Chris Wilson , Jia-Ju Bai , airlied@linux.ie, gustavo@padovan.org, maarten.lankhorst@linux.intel.com, seanpaul@chromium.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Alex Deucher , amd-gfx@lists.freedesktop.org, David Zhou , =?UTF-8?Q?Christian_K=c3=b6nig?= References: <20180901122041.2357-1-baijiaju1990@gmail.com> <153580517420.12034.2035309606925619207@skylake-alporthouse-com> <20180903075244.GE21634@phenom.ffwll.local> From: =?UTF-8?Q?Christian_K=c3=b6nig?= Message-ID: <8e811ad1-ed57-0e1c-1b52-df0dc02923dc@gmail.com> Date: Mon, 3 Sep 2018 14:05:42 +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: <20180903075244.GE21634@phenom.ffwll.local> Content-Type: text/plain; charset=utf-8; format=flowed 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 Am 03.09.2018 um 09:52 schrieb Daniel Vetter: > On Sat, Sep 01, 2018 at 01:32:54PM +0100, Chris Wilson wrote: >> Quoting Jia-Ju Bai (2018-09-01 13:20:41) >>> The driver may sleep with holding a spinlock. >>> >>> The function call paths (from bottom to top) in Linux-4.16 are: >>> >>> [FUNC] kmalloc(GFP_KERNEL) >>> drivers/gpu/drm/drm_mm.c, 130: >>> kmalloc in show_leaks >>> drivers/gpu/drm/drm_mm.c, 913: >>> show_leaks in drm_mm_takedown >>> drivers/gpu/drm/drm_vma_manager.c, 107: >>> drm_mm_takedown in drm_vma_offset_manager_destroy >>> drivers/gpu/drm/drm_vma_manager.c, 106: >>> _raw_write_lock in drm_vma_offset_manager_destroy >>> >>> [FUNC] kmalloc(GFP_KERNEL) >>> drivers/gpu/drm/drm_mm.c, 130: >>> kmalloc in show_leaks >>> drivers/gpu/drm/drm_mm.c, 913: >>> show_leaks in drm_mm_takedown >>> drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c, 71: >>> drm_mm_takedown in amdgpu_vram_mgr_fini >>> drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c, 70: >>> spin_lock in amdgpu_vram_mgr_fini >>> >>> [FUNC] kmalloc(GFP_KERNEL) >>> drivers/gpu/drm/drm_mm.c, 130: >>> kmalloc in show_leaks >>> drivers/gpu/drm/drm_mm.c, 913: >>> show_leaks in drm_mm_takedown >>> drivers/gpu/drm/ttm/ttm_bo_manager.c, 128: >>> drm_mm_takedown in ttm_bo_man_takedown >>> drivers/gpu/drm/ttm/ttm_bo_manager.c, 126: >>> spin_lock in ttm_bo_man_takedown >>> >>> To fix this bug, GFP_KERNEL is replaced with GFP_ATOMIC. >> The bug are above, since those spinlocks do not protect the data and >> imply use-after-free. > Adding amdgpu, since that's where the bug seems to be. When we have use after free we might have concurrent uses as well. I think taking the lock here is probably a good idea if you don't want to accidentally access freed memory in show_leaks. So Chris change sounds valid to me. Christian. > -Daniel