Received: by 10.192.165.148 with SMTP id m20csp3337130imm; Mon, 7 May 2018 10:28:57 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoKJrGQVqO1Dqlv/OGpeoTv6nsgqEq9BWY7hx9CZxm7lkZ/Zp1PjwXy6TD+lJTvzb+G1nOD X-Received: by 2002:a24:9c1:: with SMTP id 184-v6mr698334itm.9.1525714137216; Mon, 07 May 2018 10:28:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525714137; cv=none; d=google.com; s=arc-20160816; b=iTtWh+oQ+jRnYNf8g0pslT9/doyZ2PB6qkCItb3MK9irE0jSiK2EWoPCv1Hzy/WS6q Nr4vqvEkQMceeDYo2CMs3efWOxceVKdU0EDeePWh4s7kJ6m4TKh5F1/O9ZYEJ+3FxQh8 wxJQME64FqSfBZ+wHWV89n7WTlzC/hd9kknW3/ilpqekzQdPzJP7IQ8v5/ZH6tbNKBb/ He4bytgk4Pxp7/655+yEYoFf45sWe0YvxEZP6blG2iBTnyoOA5Cke1iUloGcitLddFpo TpzIArCHVmiCjjzxDt62PL6fxKe4Ml+ZlNwzK5H5ZcLDbRJltD1tJTEvqq6TtIKMPZbk TtZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=Y41PRU7Q9HRGUiur9BnwHZ6cqOn3i+qi5Fj72ftjwFU=; b=D2/C5e/dOyBoNQ1QOO/PraVVPsfz7ZgLcNTaJnnaEGPDg37tY771QmuwyB0udE/2+9 anOC5HpW/ayLV6KVe6jP/yYkaSU9aZD2cHfpjMnG//FrSs3I1e8TycbfchO3hWoAlrhd S9LxJknRT3kUM9u3vkhllU3THipEISJj/ncecteKAGeBoSJLDyB5oN7+TTqy6XiRW7yx pvgEQfiDa/EnfYIDAzOOYMwF/i0MGcje9ZE22xfBDt8qAwCll+/FCGDHLaN1c2v2TyI0 ijDFSwnbSecCjAJRcwVEf6trG/O6DLhtlS1OeSsBb7ggBvCdmscQjy92W51rKfz+20Qh NgQg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes-org.20150623.gappssmtp.com header.s=20150623 header.b=eIj4h7l2; 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 z124-v6si7726399itd.47.2018.05.07.10.28.43; Mon, 07 May 2018 10:28:57 -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=@joelfernandes-org.20150623.gappssmtp.com header.s=20150623 header.b=eIj4h7l2; 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 S1752550AbeEGR2c (ORCPT + 99 others); Mon, 7 May 2018 13:28:32 -0400 Received: from mail-pl0-f65.google.com ([209.85.160.65]:36357 "EHLO mail-pl0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751913AbeEGR2b (ORCPT ); Mon, 7 May 2018 13:28:31 -0400 Received: by mail-pl0-f65.google.com with SMTP id v24-v6so55592plo.3 for ; Mon, 07 May 2018 10:28:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes-org.20150623.gappssmtp.com; s=20150623; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to :user-agent; bh=Y41PRU7Q9HRGUiur9BnwHZ6cqOn3i+qi5Fj72ftjwFU=; b=eIj4h7l21XuozDKHhi8PimiOo+hnVLr3UhtBuANzxjxe0CDBfZNVUdmNis29i0ZzAt 3TcMcy1+fLMYF8F1jkGwu4Trey+g+A6sLVIRQ6OCU9QtkkpWIzTs3tP3FQDmlRCZrsne DQX+QSYOdVvJwCa9jBCKTD4MmMcF6boVar/lkLzs8TVp2l+So5mqX15y83dTcRkrNtbH pnB0k/sK8yq3yEfQHje/6IkN4yRLrKamOCVBMcHurcbb/5BTdv7N8izTzwvCHvzjgYhu YPoy63Q6p+Ntcu3iy72hYiifWkJvUvHvs3kxpG6OT1PrlTDIu3b2TgN1BsfvSpXo/7ca WLbg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to:user-agent; bh=Y41PRU7Q9HRGUiur9BnwHZ6cqOn3i+qi5Fj72ftjwFU=; b=E+jdy67eVF0cXkhc9jZAJbcbBpWjvMJxCrXPtGTsFtZR1K5+q9SklYHR/PlbiaW1Iz tDUiFlbUTaZCPP3eJl64oljaGeahXbpA/cPjMwyYOSFy1aUOQ36wmn3MdmHsZT3wTRUX aX62AAabIqnjfd9+yWWfwPXhTA3FZbX8bQ8UtVqQuH/qInm5H1yc5ZuWgtkeBGoxC3mm BNZQ9gxQs7wN3cr4EStVs6u62EoswD8n5vsl2DPuTNTyORIYP+HR/XIk/IIwD9Ak0sus 6BormCVciePaxBcvlCGsHEiAknpgH07YKnLsZr3BBEwolOeAU2NWX5/3uTXftPi8KyN/ Suyg== X-Gm-Message-State: ALQs6tCUAhI8dFl/H/pzLD5amG0PLuqydzUapLOIhRlO4GQWIuEtQd3b JRvSb+AMO8c87asIL7Ajn4KXekyKXRs= X-Received: by 10.98.200.152 with SMTP id i24mr37568152pfk.35.1525714110739; Mon, 07 May 2018 10:28:30 -0700 (PDT) Received: from localhost ([2620:0:1000:1600:3122:ea9c:d178:eb]) by smtp.gmail.com with ESMTPSA id g3-v6sm26385613pgr.34.2018.05.07.10.28.30 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 07 May 2018 10:28:30 -0700 (PDT) Date: Mon, 7 May 2018 10:28:29 -0700 From: Joel Fernandes To: Minchan Kim Cc: LKML , Ganesh Mahendran , Joe Perches , Arve =?iso-8859-1?B?SGr4bm5lduVn?= , Todd Kjos , Greg Kroah-Hartman , Martijn Coenen Subject: Re: [PATCH v6] ANDROID: binder: change down_write to down_read Message-ID: <20180507172829.GA66161@joelaf.mtv.corp.google.com> References: <20180507141537.4855-1-minchan@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20180507141537.4855-1-minchan@kernel.org> User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, May 07, 2018 at 11:15:37PM +0900, Minchan Kim wrote: > 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); Nice. Is there a need to hold the reader-lock at all here? Just curious what else is it protecting (here or in vm_insert_page). Otherwise looks good to me: Reviewed-by: Joel Fernandes (Google) thanks, - Joel