Received: by 10.192.165.148 with SMTP id m20csp3137027imm; Mon, 7 May 2018 07:16:49 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrA2Qd1G4rjKRbO4445JOESpJZxGrlXR+E1C+zY5J/LLh02isWwX9iOSyoTYR/DQJeNk5dX X-Received: by 2002:a63:7b14:: with SMTP id w20-v6mr30565827pgc.124.1525702609568; Mon, 07 May 2018 07:16:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525702609; cv=none; d=google.com; s=arc-20160816; b=xmSFvs5e2Pw9P7w9NUex/2Ip1FmD+YF57TkUMV+Ri6k9CNI9J+GjtGuelhwIiTzRKP XaD7/TfWc/CfAZW7IqdBGf2eyMF44bsX+1n0i+O2vMT3R6JS88C7mO2tMyYkdSO/9clJ NerTVNS88D0f1yXXvL0OyoUkm7H/tfQcygCDP7HKlJqx9wyrtsRMEAamJJvI9jJrddz2 c9NccJ724Yo7UHRBRlPFnodqGmhSE3Cc388oJc0f+vwpeu64iUVhuEe2U/2e8ZiFsm/f ilxHZZsYdvRO94GuFvBPzSQq7fI3TQzdWjdsgFVMZxS3iuulvYF9r6/puPLr9Nq7ofb7 oy/w== 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 :arc-authentication-results; bh=A8za/HAl2IiLicvYE/2KOWhqmHyqEzVAnVWz7lYvwto=; b=eA+qWhj9unqS7LRyIpeJj5gkT/k3VrdtrGdglQ0loX0wtyBFq3KK/P739WhScbfSA+ 2pNS22fsS1HDl78tRrYD34Oe4fcSPmsQ6XxPe1ul8Siwx0rvj1vIC5EYlVPgq+yFhSSN evmAf1TCwpS6Fj04wiDHHYi7vRg33fN7azjtFqig3z8RRoUpQBCKLD2gEBdUclIAe7uV +J2QtCSlQDUIIZ4iKGg8IjsXwG4FswvEpz3nGckEqnEKDsQ9z7B82rmC5IyiHcspkXfH R/OOs5PNc5MCuIFGO1kZlOE+mC9cOoKENDpqr0fnFIe8ua71/KE3xx5t1b4HHX5OX//N oCCg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=bhB/NEn8; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d1-v6si23256473plr.410.2018.05.07.07.16.35; Mon, 07 May 2018 07:16:49 -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=bhB/NEn8; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752681AbeEGOPt (ORCPT + 99 others); Mon, 7 May 2018 10:15:49 -0400 Received: from mail-it0-f67.google.com ([209.85.214.67]:33107 "EHLO mail-it0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752256AbeEGOPr (ORCPT ); Mon, 7 May 2018 10:15:47 -0400 Received: by mail-it0-f67.google.com with SMTP id t7-v6so11217170itf.0 for ; Mon, 07 May 2018 07:15:47 -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:mime-version :content-transfer-encoding; bh=A8za/HAl2IiLicvYE/2KOWhqmHyqEzVAnVWz7lYvwto=; b=bhB/NEn8Gg0p1WJkhlb1NeA5p3NR3s4LZQrKQ7H8jRTxERzds9y6HKme9dMDk34bOl M4C7j0OgVikHO/vJs1ij4sd5euHTQ18GgOTGnsv/1CF2gmdaabGf/j9IzAGRGnnhksXJ ku0yqfndc9qDatD/OMtKeJqs7qPp7M9fcdV5YZgL+OposgohapDhax/8T3pGs+qwbBsx hUCmMgRnOEdR5ZH04S1eqxG0YE9uGjzqOQHv2Gj0ybyqhGNDKbMFqihnE9xuhZRh9fWV XdpMGHDEGm+8VO+myMoGnCowx93W5CyDMJ2kQQODsUa1unxoP9FLnhaC5fJPA7L/KA/+ 45Yw== 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 :mime-version:content-transfer-encoding; bh=A8za/HAl2IiLicvYE/2KOWhqmHyqEzVAnVWz7lYvwto=; b=iIxjXuqiUzoTIqgbZhI/y1seCOiGO7qWCUnNCHVcxARO8jZPhSg49I7V/utGBsAj7W pUPxR1iVvL5mStmCeCpYxDZMa2MTUHzQnariJmPLBkY3Qqv8BBZNBb8lSp7iIIA50AoN uHn2fZhqaO4XolBm3xPyR8qxSzRuSmJhDY+XmQQsbgELBnaursbJ+4TaiZjgzaQhRFfR D4fIvLVrZJOTmSH7B1sb8vaqx24T7Ol15nURvKumoFDQbwGzI5mI//etpyfljQVB0iIO /AnsMhYcqKerpUPrbcTwD0UyB+EMb3BxcveOxHBNHePjvc7hZcAssfBc3vBWQIL7YGnr FhNg== X-Gm-Message-State: ALQs6tDfdXi5YRu8PfC46vbUC3BG36yvoJsg0wg/u2S2HOMnamgyhpAv pSGyjrGmI/Ch5/+c6pyqOkGIn2ZP X-Received: by 2002:a17:902:5481:: with SMTP id e1-v6mr37648192pli.137.1525702546314; Mon, 07 May 2018 07:15:46 -0700 (PDT) Received: from bbox-2.seo.corp.google.com ([2401:fa00:d:10:affa:813f:5380:6613]) by smtp.gmail.com with ESMTPSA id y7-v6sm36498843pgr.26.2018.05.07.07.15.42 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 07 May 2018 07:15:45 -0700 (PDT) From: Minchan Kim To: LKML Cc: Minchan Kim , Ganesh Mahendran , Joe Perches , =?UTF-8?q?Arve=20Hj=C3=B8nnev=C3=A5g?= , Todd Kjos , Greg Kroah-Hartman , Martijn Coenen Subject: [PATCH v6] ANDROID: binder: change down_write to down_read Date: Mon, 7 May 2018 23:15:37 +0900 Message-Id: <20180507141537.4855-1-minchan@kernel.org> X-Mailer: git-send-email 2.17.0.441.gb46fe60e1d-goog MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 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 binder_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. Please use proper API down_read. It would help mmap_sem contention problem as well as fixing down_write abuse. Ganesh Mahendran tested app launching and binder throughput test and he said he couldn't find any problem and I did binder latency test per Greg KH request(Thanks Martijn to teach me how I can do) I cannot find any problem, too. Cc: Ganesh Mahendran Cc: Joe Perches Cc: Arve Hjønnevåg Cc: Todd Kjos Cc: Greg Kroah-Hartman Reviewed-by: Martijn Coenen Signed-off-by: Minchan Kim --- drivers/android/binder.c | 4 +++- drivers/android/binder_alloc.c | 6 +++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/drivers/android/binder.c b/drivers/android/binder.c index 4eab5be3d00f..7b8e96f60719 100644 --- a/drivers/android/binder.c +++ b/drivers/android/binder.c @@ -4730,7 +4730,9 @@ 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; + vma->vm_flags &= ~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.441.gb46fe60e1d-goog