Received: by 2002:a25:5b86:0:0:0:0:0 with SMTP id p128csp987470ybb; Thu, 28 Mar 2019 16:48:23 -0700 (PDT) X-Google-Smtp-Source: APXvYqx5ZxA/6Gb5lD4xkhVdhBmcltkt7S8ectX5D8vVIOkkKZX2HIB4AHxHop+J4U4oUB+OWeci X-Received: by 2002:a63:7808:: with SMTP id t8mr9662651pgc.127.1553816903469; Thu, 28 Mar 2019 16:48:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553816903; cv=none; d=google.com; s=arc-20160816; b=UWYZTMqU9WGi2rwec99w+BzUKhmk7/iHG0eoe4q7BYOPq3Q/ip77KtFdRboAZf06+3 AoYgnEHPabt9bQ+OoZVniBBipnwhjpeRgSFc2WZFaTrj7Ht81EPOQL7kZoFYpzEHm7j0 0yS4+PJensBqGF7GfI6W7Uq1LhvFpFMTdLUKySEc3vVRphLwYNWkGtACaOLI8+fQT+R5 DrrLPofS1vJ03qSCjjMN1OrMVLUFHRZEe9aCXRNMhD6YedWzhywYC5BS7tSwEvdo5CE8 zLFsnWDc7WjyXJd+Wc1soiPFmceSmojPzMV04s0bsTqIxBnObfVVvLNc2K8GynBRmlI9 yqJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=YKhHIoTYyJM/435yIx1s2AWNgwh6kvVxpU1hFFuHow4=; b=matFUXY4ur2qAZqdUediB1v4eBwpeE0XbmDBdXonlJS/fer4OFxNbBDdTOVEsHjNPz fmnzN2m7fDDjEVGySfK9e6hBDuEBid99a0MyQn3F/79ARv3KSZxvYz5EwHLJVpbXgKRn MDaTkD2kzLBGG3ZmbwR1nnM6XmgVkZ91LUzs7KBdNkQIVuEgrJetfnfsl9fJNXgywDLU F7g9xsX6zvSvp7D7O53w05aP0JQX788d3RTqFD5k7EFLYHFF4kZEeVUhEW5m7oufWvbA 2+PL5C4mzpRtgdI2mBuFZYOfpqN8wOC+/hP+Tt/DAxHdRcHx7R0AJSvAKDa40RRmxk1X +NRQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b=RunNMqM5; 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=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x18si441816plr.76.2019.03.28.16.48.07; Thu, 28 Mar 2019 16:48:23 -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=@oracle.com header.s=corp-2018-07-02 header.b=RunNMqM5; 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=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728655AbfC1Xra (ORCPT + 99 others); Thu, 28 Mar 2019 19:47:30 -0400 Received: from userp2120.oracle.com ([156.151.31.85]:42480 "EHLO userp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728591AbfC1Xra (ORCPT ); Thu, 28 Mar 2019 19:47:30 -0400 Received: from pps.filterd (userp2120.oracle.com [127.0.0.1]) by userp2120.oracle.com (8.16.0.27/8.16.0.27) with SMTP id x2SNiccZ133406; Thu, 28 Mar 2019 23:47:20 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=from : to : cc : subject : date : message-id : mime-version : content-transfer-encoding; s=corp-2018-07-02; bh=YKhHIoTYyJM/435yIx1s2AWNgwh6kvVxpU1hFFuHow4=; b=RunNMqM53f2PTc1aTaL863HSzFU5Y20yO6WA/b5ENbcYKGy6uL/Mk11FCpzOzmQbBkRz UHsoR0QGvMuLX1VdKwBoGleRvWf9U2++d0SDNEn6HXQsPBMVaI5sZeowoST/a0P38ZwT nhE0iL9guZ0GLI+6UztwknnSg4NAou4PcEDTOCTi9KF7NCOaoUDLTjl1wsB2A+g9EIDU SWi2yPpYdU+SjWeB01HY8PY/9jsboYWxeHQgOS9JNGaeJlLnN44kLR0b9wzWLaByA8B7 LgvWo48KbhGmEMTUNPBocd2uxXB+1NqgXEmAVHXFzFpvLSP17iotEADPRLJ9i2+WA+yd jg== Received: from aserv0022.oracle.com (aserv0022.oracle.com [141.146.126.234]) by userp2120.oracle.com with ESMTP id 2re6djsmec-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 28 Mar 2019 23:47:20 +0000 Received: from userv0122.oracle.com (userv0122.oracle.com [156.151.31.75]) by aserv0022.oracle.com (8.14.4/8.14.4) with ESMTP id x2SNlIZL015595 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 28 Mar 2019 23:47:18 GMT Received: from abhmp0011.oracle.com (abhmp0011.oracle.com [141.146.116.17]) by userv0122.oracle.com (8.14.4/8.14.4) with ESMTP id x2SNlEpm015975; Thu, 28 Mar 2019 23:47:15 GMT Received: from monkey.oracle.com (/50.38.38.67) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Thu, 28 Mar 2019 16:47:14 -0700 From: Mike Kravetz To: linux-kernel@vger.kernel.org, linux-mm@kvack.org, Davidlohr Bueso Cc: Joonsoo Kim , Michal Hocko , Naoya Horiguchi , "Kirill A . Shutemov" , Andrew Morton , Mike Kravetz Subject: [PATCH v2 0/2] A couple hugetlbfs fixes Date: Thu, 28 Mar 2019 16:47:02 -0700 Message-Id: <20190328234704.27083-1-mike.kravetz@oracle.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=9209 signatures=668685 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 priorityscore=1501 malwarescore=0 suspectscore=2 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=747 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1810050000 definitions=main-1903280154 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org I stumbled on these two hugetlbfs issues while looking at other things: - The 'restore reserve' functionality at page free time should not be adjusting subpool counts. - A BUG can be triggered (not easily) due to temporarily mapping a page before doing a COW. Both are described in detail in the commit message of the patches. I would appreciate comments from Davidlohr Bueso as one patch is directly related to code he added in commit 8382d914ebf7. I did not cc stable as the first problem has been around since reserves were added to hugetlbfs and nobody has noticed. The second is very hard to hit/reproduce. v2 - Update definition and all callers of hugetlb_fault_mutex_hash as the arguments mm and vma are no longer used or necessary. Mike Kravetz (2): huegtlbfs: on restore reserve error path retain subpool reservation hugetlb: use same fault hash key for shared and private mappings fs/hugetlbfs/inode.c | 7 ++----- include/linux/hugetlb.h | 4 +--- mm/hugetlb.c | 43 +++++++++++++++++++++-------------------- mm/userfaultfd.c | 3 +-- 4 files changed, 26 insertions(+), 31 deletions(-) -- 2.20.1