Received: by 10.213.65.68 with SMTP id h4csp1004504imn; Wed, 28 Mar 2018 18:01:59 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/BkhRXjutTvlsk4b6KmLe9CFdps7sWB7SLdplS1AKxar+//Ow07pP+4V/V3dHGM6Ja1eOJ X-Received: by 10.101.82.69 with SMTP id q5mr4044264pgp.358.1522285319845; Wed, 28 Mar 2018 18:01:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522285319; cv=none; d=google.com; s=arc-20160816; b=nrlL+mAxfrrbBPwfhe9pw3ZVO3otQ/MQHzHwf8xhp+GJYPg8g2l5Cugy2vtwoCepxe AcS0ejAnwNYog1b8L3gZRM9AVySR0mhVnHELzrL4La/DLubycMyVACTD1+GRhjxKMOQl FGPmynzzAPQ83G4InLaHXt716GFadgbkKzz7f7ulSU2Zyl7GsO0B2ohNGpsmkqjBp9oZ 1JS6+AzANXxsbZ4laA2g2lQgCae8ZmePnA2YcZvJHPg6jMJj5m2LBYN1/9uxQvDxjltd bKNyANGJ4WhfB2i1gbbxefVYNIWNxynv6xz5jp5pAWHgU0IHW3VuWUMPbQjg55mep0v0 zgnw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=N2aURBRe0w1n4wUc4M3WZykN/13gESjGQGoIxDvr3y0=; b=x/zJb2S57NxWac5eOtmKiNZU5HhVTf3bjCrwMFVzaGviumIShpvIRc09zBDfAj56q7 u+G3+pEMFfnth+mgNRbBPexEIURYtBzCodrgM+G1G1MDTzEnhK0vht5a8eEfBXn7WAQd ZLbRze/zEaAkB1EhRe2i5JieGuLeXmwMZap+8Mho9RoeICpSOWs0YVbHyDPizSdHxGyQ j5vsfncD8bZ9J8TstaPM3NmEa9Ysxjnrhaq+A7zczzdml3z9pFUJboxBeHRAYta+8B8k 62Dle1BR3/abbFdLT2XYLxiJ2vlwRaJXQ5LzSQltLNx+YUoT89g6/T4d/echVniustDn 4J+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=OBB42fjx; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x6si3267184pgq.260.2018.03.28.18.01.45; Wed, 28 Mar 2018 18:01:59 -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=fail header.i=@gmail.com header.s=20161025 header.b=OBB42fjx; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751935AbeC2BAw (ORCPT + 99 others); Wed, 28 Mar 2018 21:00:52 -0400 Received: from mail-pf0-f195.google.com ([209.85.192.195]:33336 "EHLO mail-pf0-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751146AbeC2BAu (ORCPT ); Wed, 28 Mar 2018 21:00:50 -0400 Received: by mail-pf0-f195.google.com with SMTP id f15so2055284pfn.0 for ; Wed, 28 Mar 2018 18:00:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id; bh=N2aURBRe0w1n4wUc4M3WZykN/13gESjGQGoIxDvr3y0=; b=OBB42fjxWo0rbm27FVw83ZNfV4CPAGCKYEllBtnq49VbppddHXCKPzLMKull2Kuglk u0tPF6OTm47exS/JCWzgAokMe5uV7oBHxj9xT6T8jF3jaMdyo5YMVedHRrUDbL3qTdZM 6oJxXEZVfOjc7bkkvVv42nSOf55Xoh9DaZQP0+mBlrZN9tPdVwsXYd5tMDGK1UvUmdQe ZIMtY/njKkM7TIPnVgBzy9hc1o9BOmxbyg2mSH2gBWWONuywVYDTi4z2ESEYMFJV/e4Y f7YPBVEMHAn9cPTUPz362K0Epkf/D6L2NckdWZt6tWKIulq79nVVZdDg9eRSRyJtNdI6 CFIw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id; bh=N2aURBRe0w1n4wUc4M3WZykN/13gESjGQGoIxDvr3y0=; b=YQSD9Q7IBl5YcFQfhkl1wqYq9QL/kgDdBxkQRSwz7uQqW5r7pqxb3tcqLi6HsRfRDA Zp+wBAgjIbcVV0WTNe+j2QL10a383uSV4VjfyJtn8z4/A2n7KuyUB3SmwyRQcjspD7Fe O+hYopaApWg9A7tePSSRW0Ply5UNa00qWfc/Riy06eIJGJXfwtSFkABHa+T5w9x4bIwH 7DNRf0JMtwmoumW7b7twNNWiuk5BfrtoRO29IZJMHxFEpRD8ORyH0sSRrE7Htp/fSSg9 e0otAPFvT61wUT8W/ds+HPM//JYgCNPYC8DEPi3Tuju3ZY186g9v8DfCXEguHHkz80vM Tm/A== X-Gm-Message-State: AElRT7HbqIye+TB1ILnpesm2PtVBeRq3L9P39WyUNXi0X1TBa0s4kdkf Rb0Fo5xCgzMyLuXA5Py17SeF6nA+ X-Received: by 10.98.156.152 with SMTP id u24mr4643772pfk.74.1522285249525; Wed, 28 Mar 2018 18:00:49 -0700 (PDT) Received: from bbox-2.seo.corp.google.com ([2401:fa00:d:0:7630:de9:f6f2:276f]) by smtp.gmail.com with ESMTPSA id s7sm8705947pgq.48.2018.03.28.18.00.46 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 28 Mar 2018 18:00:48 -0700 (PDT) From: Minchan Kim To: LKML Cc: Minchan Kim , Todd Kjos , Greg Kroah-Hartman , Martijn Coenen Subject: [PATCH v2] ANDROID: binder: change down_write to down_read Date: Thu, 29 Mar 2018 10:00:40 +0900 Message-Id: <20180329010040.96760-1-minchan@kernel.org> X-Mailer: git-send-email 2.17.0.rc1.321.gba9d0f2565-goog Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org binder_update_page_range needs down_write of mmap_sem because vm_insert_page need to change vma->vm_flags to VM_MIXEDMAP unless it is set. However, when I profile binder working, it seems every binder buffers should be mapped in advance by binder_mmap. It means we could set VM_MIXEDMAP in bider_mmap time which is already hold a mmap_sem as down_write so binder_update_page_range doesn't need to hold a mmap_sem as down_write. Android suffers from mmap_sem contention so let's reduce mmap_sem down_write. Cc: Todd Kjos Cc: Greg Kroah-Hartman Reviewed-by: Martijn Coenen Signed-off-by: Minchan Kim --- From v1: * remove WARN_ON_ONCE - Greg * add reviewed-by - Martijn Martijn, I took your LGTM of v1 as Reviewed-by. If you don't like it or want to change it to acked-by, please, tell me. drivers/android/binder.c | 2 +- drivers/android/binder_alloc.c | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/android/binder.c b/drivers/android/binder.c index 764b63a5aade..9a14c6dd60c4 100644 --- a/drivers/android/binder.c +++ b/drivers/android/binder.c @@ -4722,7 +4722,7 @@ static int binder_mmap(struct file *filp, struct vm_area_struct *vma) failure_string = "bad vm_flags"; goto err_bad_arg; } - vma->vm_flags = (vma->vm_flags | VM_DONTCOPY) & ~VM_MAYWRITE; + vma->vm_flags |= (VM_DONTCOPY | VM_MIXEDMAP) & ~VM_MAYWRITE; vma->vm_ops = &binder_vm_ops; vma->vm_private_data = proc; diff --git a/drivers/android/binder_alloc.c b/drivers/android/binder_alloc.c index 5a426c877dfb..4f382d51def1 100644 --- a/drivers/android/binder_alloc.c +++ b/drivers/android/binder_alloc.c @@ -219,7 +219,7 @@ static int binder_update_page_range(struct binder_alloc *alloc, int allocate, mm = alloc->vma_vm_mm; if (mm) { - down_write(&mm->mmap_sem); + down_read(&mm->mmap_sem); vma = alloc->vma; } @@ -288,7 +288,7 @@ static int binder_update_page_range(struct binder_alloc *alloc, int allocate, /* vm_insert_page does not seem to increment the refcount */ } if (mm) { - up_write(&mm->mmap_sem); + up_read(&mm->mmap_sem); mmput(mm); } return 0; @@ -321,7 +321,7 @@ static int binder_update_page_range(struct binder_alloc *alloc, int allocate, } err_no_vma: if (mm) { - up_write(&mm->mmap_sem); + up_read(&mm->mmap_sem); mmput(mm); } return vma ? -ENOMEM : -ESRCH; -- 2.17.0.rc1.321.gba9d0f2565-goog