Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp129873imm; Tue, 19 Jun 2018 17:33:55 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKCWU0iC8GBiwh6uUCz7duP4MjSMiJJLZWsdsDKtIC0tcf8OlIN8LZBlP+1fMzGetYsIY6A X-Received: by 2002:a63:9e0a:: with SMTP id s10-v6mr1023433pgd.305.1529454835699; Tue, 19 Jun 2018 17:33:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529454835; cv=none; d=google.com; s=arc-20160816; b=zbY/ENNeCIvW4QUGlkHsLXwCJEvOdCM1GUFP6zjpnZrFxMlazYI8H3yDSWSTxHIcZa LDp2TfcyLbp3aLXKHS+LXfyIbwRFVvJyW1x0X9ckLIwcn8LdPJnHNFTeObPI3SEwM6Zv GH7YBNa9TKHh+12kv0LbU05PDcM2QUwCgdhOtqbNfzysPs7LOgN7LaEWMQVL2KV/Ub/k wTERKgFozFsyQRy02Ps/c9256KSHg8iZChzgm3GyeO2KuTqJh8GQCjfblXjf2WhvxTOW e4IWa/OMBJGoUmXH2rhGNG/BzC5a3wxCLzHEzslVbj6Sqjvxj5rTdb4oLJeU5ACoKE+T Ne0g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:references:message-id :content-transfer-encoding:cc:date:in-reply-to:from:subject :mime-version:dkim-signature:arc-authentication-results; bh=3ZpeC+UKztRPWYDWnPsFG1JxhFy8L83OScTNK3MFdtw=; b=ZkNtYb09W9Nt/RtcOLDkOFcqPOVf1DMBCyzG3PVvMoyHLt4rcbRCgx5njZxzp0n1yo e9iyLMq+7uGQoaTp6xeQMRq+Q3h1RdE78HXM0y+6Y5VrnX+8O3KIujRR3J/eH6RtuqUr 8AVe02a7eLxc3Dp+FFAx018O5gG/ydcE37WrnJ13nvb4KiD+zjWOZijdGBQhLebmHHZo dMibWBnU4UKG2pA/8OTQbo4VHGVM5en7aB0NQexyaiUXhV7wCy7jJ2eim0p3frllmfYd CKKJwnkQ0wz+CFdaGlUGVmaia0Ts96vP9ek4o5PfZpjS5uaN0UJT9TeYrGbMePYrHZ7D KBCw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="CBoi/vVZ"; 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 g9-v6si911419plt.232.2018.06.19.17.33.41; Tue, 19 Jun 2018 17:33: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="CBoi/vVZ"; 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 S1753917AbeFTAbk (ORCPT + 99 others); Tue, 19 Jun 2018 20:31:40 -0400 Received: from mail-pg0-f67.google.com ([74.125.83.67]:43242 "EHLO mail-pg0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752827AbeFTAbc (ORCPT ); Tue, 19 Jun 2018 20:31:32 -0400 Received: by mail-pg0-f67.google.com with SMTP id a14-v6so617783pgw.10 for ; Tue, 19 Jun 2018 17:31:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=3ZpeC+UKztRPWYDWnPsFG1JxhFy8L83OScTNK3MFdtw=; b=CBoi/vVZqpjc2zc8Z08/9ywE3+AKseZY/kpGOPg3yhmbchrlwisKhMhqaJ3C1YdnuV JMXj80jC6vqTnECJdM6EvzXiCn4elgw94jXL1fAuHB417/MS+jlUcjA0w8R0c5nkWbrx ZT3SzK724shJi6HKqI2yS6frv4w+YysQCpsOlZHhNoDMzIsp+/w6d+F4VlWZDrIhabhj QAAADAzqMWO01dkhzKpa6QD0JY2hMfXmVerSn1zWRC++is+B9UyDv61aUGsogLw6mol9 xPO3YqegMvqyb+RzY1xSbghRgkiKJse4G+GQ2FaxDSfHaagwHpwnvLE5RdUfe3UK0Osq wBmA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=3ZpeC+UKztRPWYDWnPsFG1JxhFy8L83OScTNK3MFdtw=; b=CVyW8nwzAQ6tLjhZpWJBk7WruUERyl/+K1sHHbsd4zcr33UDDDFWL9ck6YVjmf/US3 mzf9uZHTUPnZSSGwf+pq0Y6VgnIg84+yC0qZIgMD9HQ3DbVoMHsXF8+kj05Tnnt6YV5X ntykfPjCsP9mn/lU3TGgznwvW/BWlGSSXYrlxY/R7M8/f6RHdQwuwjl4DLTAAD86mtda 76bTH/oS56hOjl+YNmJKP3nLbNH9q8OVSOks+2WVJnxxDPgU1L/6wGgxZMaJROX+J5f9 hpPgd5TpikE+f2i9/nuGWEKZHfQ1lOLfLze/dbTosrRZpyJYsq4ZSNzvP6cGA7H59O2J pO3w== X-Gm-Message-State: APt69E0aQC0r0164F5X05J3zpiv0sA3WOjwZ/Y/eRqCK562d860pqBvT PFAsdLH7tT9SSkqlJGDHZjM= X-Received: by 2002:a63:b305:: with SMTP id i5-v6mr16840142pgf.370.1529454691572; Tue, 19 Jun 2018 17:31:31 -0700 (PDT) Received: from [10.2.101.129] ([208.91.2.2]) by smtp.gmail.com with ESMTPSA id e131-v6sm117604pgc.6.2018.06.19.17.31.30 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 19 Jun 2018 17:31:31 -0700 (PDT) Content-Type: text/plain; charset=utf-8 Mime-Version: 1.0 (Mac OS X Mail 11.4 \(3445.8.2\)) Subject: Re: [RFC v2 PATCH 2/2] mm: mmap: zap pages with read mmap_sem for large mapping From: Nadav Amit In-Reply-To: <158a4e4c-d290-77c4-a595-71332ede392b@linux.alibaba.com> Date: Tue, 19 Jun 2018 17:31:27 -0700 Cc: Michal Hocko , Matthew Wilcox , ldufour@linux.vnet.ibm.com, Andrew Morton , Peter Zijlstra , Ingo Molnar , acme@kernel.org, alexander.shishkin@linux.intel.com, jolsa@redhat.com, namhyung@kernel.org, "open list:MEMORY MANAGEMENT" , linux-kernel@vger.kernel.org Content-Transfer-Encoding: quoted-printable Message-Id: References: <1529364856-49589-1-git-send-email-yang.shi@linux.alibaba.com> <1529364856-49589-3-git-send-email-yang.shi@linux.alibaba.com> <3DDF2672-FCC4-4387-9624-92F33C309CAE@gmail.com> <158a4e4c-d290-77c4-a595-71332ede392b@linux.alibaba.com> To: Yang Shi X-Mailer: Apple Mail (2.3445.8.2) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org at 4:08 PM, Yang Shi wrote: >=20 >=20 > On 6/19/18 3:17 PM, Nadav Amit wrote: >> at 4:34 PM, Yang Shi >> wrote: >>=20 >>=20 >>> When running some mmap/munmap scalability tests with large memory = (i.e. >>>=20 >>>> 300GB), the below hung task issue may happen occasionally. >>>>=20 >>> INFO: task ps:14018 blocked for more than 120 seconds. >>> Tainted: G E 4.9.79-009.ali3000.alios7.x86_64 #1 >>> "echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this >>> message. >>> ps D 0 14018 1 0x00000004 >>>=20 >>>=20 >> (snip) >>=20 >>=20 >>> Zapping pages is the most time consuming part, according to the >>> suggestion from Michal Hock [1], zapping pages can be done with = holding >>> read mmap_sem, like what MADV_DONTNEED does. Then re-acquire write >>> mmap_sem to manipulate vmas. >>>=20 >> Does munmap() =3D=3D MADV_DONTNEED + munmap() ? >=20 > Not exactly the same. So, I basically copied the page zapping used by = munmap instead of calling MADV_DONTNEED. >=20 >>=20 >> For example, what happens with userfaultfd in this case? Can you get = an >> extra #PF, which would be visible to userspace, before the munmap is >> finished? >>=20 >=20 > userfaultfd is handled by regular munmap path. So, no change to = userfaultfd part. Right. I see it now. >=20 >>=20 >> In addition, would it be ok for the user to potentially get a zeroed = page in >> the time window after the MADV_DONTNEED finished removing a PTE and = before >> the munmap() is done? >>=20 >=20 > This should be undefined behavior according to Michal. This has been = discussed in https://lwn.net/Articles/753269/. Thanks for the reference. Reading the man page I see: "All pages containing a part of the = indicated range are unmapped, and subsequent references to these pages will = generate SIGSEGV.=E2=80=9D To me it sounds pretty well-defined, and this implementation does not = follow this definition. I would expect the man page to be updated and indicate = that the behavior has changed. Regards, Nadav=