Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp2850641imm; Fri, 24 Aug 2018 06:30:19 -0700 (PDT) X-Google-Smtp-Source: ANB0VdaCkgABOPt6fteomKmDeuB5QRqTClslm9FoFmkgaZBPjkRddu5ZS09LIVa/Plm+h8BsaC1g X-Received: by 2002:a62:f909:: with SMTP id o9-v6mr2031469pfh.141.1535117419837; Fri, 24 Aug 2018 06:30:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535117419; cv=none; d=google.com; s=arc-20160816; b=LUq/N56AGOlK3BeXuHaDvJPm6v+ZtbSl3fPULmVbfCgJLwKGbLNgr0kuON9U13xVUk Jn9tEnp+1mFcGjB+KnOvUjTJ9Xp+Ct0YTD0WUS4h3I7+zfNJ/jPY+VAoaQDqqqASh0Gp culkf8SOOoncaCo9XQZJ9YEHSEdVfnWvzfD0Wun582z+hYzor8XKLcjs2QYZplQJYhuG CoEfGOqPqXrFQHNjBkFz75gYOLC5PDWGWHZW57RqkXePgvnXCQCdMAcZQzWjH1KIvTxN 13Whmy70kzGfB6atb0ERGeKzHRoELbtGIg4Qn3UcH1FRr7vd6Zyh7Kl2ckFc80sOuDZK rhsQ== 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:reply-to:dkim-signature :arc-authentication-results; bh=GC5h/f2aVbYgMn//UjkSMiRXo2c9S9A1Slswqjt5+Fg=; b=m+Y0adWGpEZx0acF02p4pPVcXOeWeW2rL/iM5PtJRCI09HWYQ98wP7xRWZqDcXevwl psMIlPS6eErbjGD/wHjwd+xYfVM7D1aAWEP8Bvmd1YgJRlbdO3/P9kGt9dahQ5I3zQmt vjxbKMwqYtpGNt2WN4GSdey8mAWnKVdt7UeL+BVnSfMm1vp9a1QOEA/1EEQoGykumCpZ CB5GtElRfvbl3yILt3n2c6Xwq7SWEZLSidmAdL+BM1SgqgNth8shCAK1S5WNdvySW7qn qJ92uM/T5hKuYxAz2YAQa7Jo36M1kEVSxD70wOtyAP35vKT0Lx+UO6Tidfy/TCQSRb4P SUNQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=BfrmM8wk; 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 f3-v6si6600412pld.366.2018.08.24.06.30.04; Fri, 24 Aug 2018 06:30:19 -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=BfrmM8wk; 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 S1727959AbeHXRDS (ORCPT + 99 others); Fri, 24 Aug 2018 13:03:18 -0400 Received: from mail-wr1-f65.google.com ([209.85.221.65]:33659 "EHLO mail-wr1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726883AbeHXRDS (ORCPT ); Fri, 24 Aug 2018 13:03:18 -0400 Received: by mail-wr1-f65.google.com with SMTP id v90-v6so7514718wrc.0; Fri, 24 Aug 2018 06:28:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=reply-to:subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=GC5h/f2aVbYgMn//UjkSMiRXo2c9S9A1Slswqjt5+Fg=; b=BfrmM8wk2XoixWjLyDDlzcmi4/74IFH5qMO9WnZUYiiSI/A+LZIr0RzmTRZG8kMhye 3vjTbCGzRBhTjBoRG4UzmNDtBeU9v0sQfmKm+DX+Byie0nY3lMJzmhrST+hW8I1tV4ds n/0umVKI3n2kZKAdo5vntl3kZe+zQx+mSVV0rbEp8E/V8T2uq/5JUNt0bO/q7GUoj/TN +6rpTdHpplDUnjf0+E5RmJ7Y8BEShZ6it9kf5OMTS63phqpvg1cjlOm1qZ3Yeoa0oCaU bVoFJR/HVYss3I5wa/YneGDzpbEOCoQMo66k3/pMecat+dw39OiXgeO+7bBH+cPd9jto MVFw== 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:cc:references:from :message-id:date:user-agent:mime-version:in-reply-to :content-transfer-encoding:content-language; bh=GC5h/f2aVbYgMn//UjkSMiRXo2c9S9A1Slswqjt5+Fg=; b=VlkXCARWFJ/l8fZ4SWacVi4jGcvgBrFnCNUv3rz4aN+RU0rCeDvQouIogQ904/8XL4 2s9dDz6ggQqT6a0xbLVD5d2h9ykw4++zLx1XpCtBHvjb4ceFCx/mdzp9/h3PI4NWVQc1 aYlR8tg1dfxAykdFNsL0UdUjk0U1yaVRq6FUYe2hUj72QHvkkPNGb7DrLRWZ71F1P0KD YOyNw2z4skJSOKXyUeFyWq+tOS4i8M3EkuE9O9eIQa8nAem1PunxWj9xgMUaY/fFJu9o IKYSJPgL0DVkYYiKomqym7xFrxAglzu3dBsPRNMlyK1BKWoihWu1ZbjPkfJIRpPvKN20 kIMw== X-Gm-Message-State: APzg51De/CuahEHMJdY7Ap1xtcYJf5J4dKbJCYhRkyDacs2Fg1lmM3jW dgrpohEFQ/hSWwC9njviKtQ= X-Received: by 2002:adf:ae01:: with SMTP id x1-v6mr1230411wrc.45.1535117315852; Fri, 24 Aug 2018 06:28:35 -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 e141-v6sm2447844wmd.32.2018.08.24.06.28.33 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 24 Aug 2018 06:28:35 -0700 (PDT) Reply-To: christian.koenig@amd.com Subject: Re: [PATCH] mm, oom: distinguish blockable mode for mmu notifiers To: Michal Hocko , christian.koenig@amd.com Cc: kvm@vger.kernel.org, =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= , Tetsuo Handa , Sudeep Dutt , dri-devel@lists.freedesktop.org, linux-mm@kvack.org, Andrea Arcangeli , Dimitri Sivanich , Jason Gunthorpe , linux-rdma@vger.kernel.org, amd-gfx@lists.freedesktop.org, David Airlie , Doug Ledford , David Rientjes , xen-devel@lists.xenproject.org, intel-gfx@lists.freedesktop.org, Leon Romanovsky , =?UTF-8?B?SsOpcsO0bWUgR2xpc3Nl?= , Rodrigo Vivi , Boris Ostrovsky , Juergen Gross , Mike Marciniszyn , Dennis Dalessandro , LKML , Ashutosh Dixit , Alex Deucher , Paolo Bonzini , Andrew Morton , Felix Kuehling References: <20180824113248.GH29735@dhcp22.suse.cz> <20180824115226.GK29735@dhcp22.suse.cz> <20180824120339.GL29735@dhcp22.suse.cz> <20180824123341.GN29735@dhcp22.suse.cz> <20180824130132.GP29735@dhcp22.suse.cz> <23d071d2-82e4-9b78-1000-be44db5f6523@gmail.com> <20180824132442.GQ29735@dhcp22.suse.cz> From: =?UTF-8?Q?Christian_K=c3=b6nig?= Message-ID: <86bd94d5-0ce8-c67f-07a5-ca9ebf399cdd@gmail.com> Date: Fri, 24 Aug 2018 15:28:33 +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: <20180824132442.GQ29735@dhcp22.suse.cz> 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 Am 24.08.2018 um 15:24 schrieb Michal Hocko: > On Fri 24-08-18 15:10:08, Christian König wrote: >> Am 24.08.2018 um 15:01 schrieb Michal Hocko: >>> On Fri 24-08-18 14:52:26, Christian König wrote: >>>> Am 24.08.2018 um 14:33 schrieb Michal Hocko: >>> [...] >>>>> Thiking about it some more, I can imagine that a notifier callback which >>>>> performs an allocation might trigger a memory reclaim and that in turn >>>>> might trigger a notifier to be invoked and recurse. But notifier >>>>> shouldn't really allocate memory. They are called from deep MM code >>>>> paths and this would be extremely deadlock prone. Maybe Jerome can come >>>>> up some more realistic scenario. If not then I would propose to simplify >>>>> the locking here. We have lockdep to catch self deadlocks and it is >>>>> always better to handle a specific issue rather than having a code >>>>> without a clear indication how it can recurse. >>>> Well I agree that we should probably fix that, but I have some concerns to >>>> remove the existing workaround. >>>> >>>> See we added that to get rid of a real problem in a customer environment and >>>> I don't want to that to show up again. >>> It would really help to know more about that case and fix it properly >>> rather than workaround it like this. Anyway, let me think how to handle >>> the non-blocking notifier invocation then. I was not able to come up >>> with anything remotely sane yet. >> With avoiding allocating memory in the write lock path I don't see an issue >> any more with that. >> >> All what the write lock path does now is adding items to a linked lists, >> arrays etc.... > Can we change it to non-sleepable lock then? No, the write side doesn't sleep any more, but the read side does. See amdgpu_mn_invalidate_node() and that is where you actually need to handle the non-blocking flag correctly. Christian.