Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp1989049imm; Thu, 23 Aug 2018 12:11:10 -0700 (PDT) X-Google-Smtp-Source: AA+uWPwf9fyFd4CkThEkHMs5vhjHFD5XvFvQYXYn2SWsNqlCtiVt5k8ZHq76GzurbKyuhs8H50Ja X-Received: by 2002:a17:902:6b89:: with SMTP id p9-v6mr59215842plk.272.1535051470473; Thu, 23 Aug 2018 12:11:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535051470; cv=none; d=google.com; s=arc-20160816; b=XcSo04zad7J0F8jPd2+cVarXN9zhselJm6+sdBZ3Bg02v5iUWgoM6zjvhtV5r+eQu1 4BMLQi1WqOy8zUu1dXAhXBPj21fLjJmouJhxKS3Ffx1GXj+Ghng3CXvu9UU2oqv6tyS5 wvqIx34YAHvz3rM8nnmj3Z3yo4ZD+PEpp954FCqeRlNDYAPkHvzW62eCZT5j6cf3mK3I oKuO9vbKbl0sgihpuc62nKEoN64BH3KFBm/HSmdR/eCCT/9Gba4QBuuaborAyTsNjHoC EdrdURViPKNZOADlshuZZo4MWNLuHWugJKY2l+/MjngD45C44NRCPyWsxdx2ik+54fqT J4DQ== 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-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=ocyT0FsJ3NUHTaiZ7m5T3BREZsyPOtr+oXSGvOelcfc=; b=F5UiUDu9Vtn19f2rNFEKRPx7PM0+BVP5NXy7V5oFaa/3+HEWCUemSW5UtWpVhnxZCD kjj1abfFeX+FQL/LyjzpD91EHEbuHhPYtnjkWndYR5piyySqFJ2Xapx1z6KEHGrBJoob ucoYsF3HLp2Xhv4r7EJcJZ1Wc5URSfnS07DPiLkE6nrHV81DNzDzzzPBogRzMYHxyRWI iPuwZj7tUoZB9zjmeRS8yhR+X80ixqsZGXVFjR7Lqkm/MHqbWVnCYCIVW5Lurix0CitY sh0CdgbUpK8vjev9SuXNg/bLnRejxC3rRYS4co9Cu7O4e2NJEmD3peoP5sTzbjr+UkmJ gbFA== ARC-Authentication-Results: i=1; mx.google.com; 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 k1-v6si4732416pld.424.2018.08.23.12.10.54; Thu, 23 Aug 2018 12:11:10 -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; 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 S1726324AbeHWWkm (ORCPT + 99 others); Thu, 23 Aug 2018 18:40:42 -0400 Received: from mx2.suse.de ([195.135.220.15]:57578 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726085AbeHWWkm (ORCPT ); Thu, 23 Aug 2018 18:40:42 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id ED497B03A; Thu, 23 Aug 2018 19:09:35 +0000 (UTC) Date: Thu, 23 Aug 2018 21:09:33 +0200 From: Michal Hocko To: Boris Ostrovsky Cc: Tetsuo Handa , Andrew Morton , linux-mm@kvack.org, xen-devel@lists.xenproject.org, LKML , Juergen Gross Subject: Re: [PATCH] xen/gntdev: fix up blockable calls to mn_invl_range_start Message-ID: <20180823190933.GP29735@dhcp22.suse.cz> References: <20180823120707.10998-1-mhocko@kernel.org> <07c7ead4-334d-9b25-f588-25e9b46bbea0@i-love.sakura.ne.jp> <20180823135151.GM29735@dhcp22.suse.cz> <9d2d11eb-7fe1-b836-056c-7886d6fc56e5@oracle.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <9d2d11eb-7fe1-b836-056c-7886d6fc56e5@oracle.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu 23-08-18 10:06:53, Boris Ostrovsky wrote: > On 08/23/2018 09:51 AM, Michal Hocko wrote: > > On Thu 23-08-18 22:44:07, Tetsuo Handa wrote: > >> On 2018/08/23 21:07, Michal Hocko wrote: > >>> diff --git a/drivers/xen/gntdev.c b/drivers/xen/gntdev.c > >>> index 57390c7666e5..e7d8bb1bee2a 100644 > >>> --- a/drivers/xen/gntdev.c > >>> +++ b/drivers/xen/gntdev.c > >>> @@ -519,21 +519,20 @@ static int mn_invl_range_start(struct mmu_notifier *mn, > >>> struct gntdev_grant_map *map; > >>> int ret = 0; > >>> > >>> - /* TODO do we really need a mutex here? */ > >>> if (blockable) > >>> mutex_lock(&priv->lock); > >>> else if (!mutex_trylock(&priv->lock)) > >>> return -EAGAIN; > >>> > >>> list_for_each_entry(map, &priv->maps, next) { > >>> - if (in_range(map, start, end)) { > >>> + if (!blockable && in_range(map, start, end)) { > >> This still looks strange. Prior to 93065ac753e4, in_range() test was > >> inside unmap_if_in_range(). But this patch removes in_range() test > >> if blockable == true. That is, unmap_if_in_range() will unconditionally > >> unmap if blockable == true, which seems to be an unexpected change. > > You are right. I completely forgot I've removed in_range there. Does > > this look any better? > > > > diff --git a/drivers/xen/gntdev.c b/drivers/xen/gntdev.c > > index e7d8bb1bee2a..30f81004ea63 100644 > > --- a/drivers/xen/gntdev.c > > +++ b/drivers/xen/gntdev.c > > @@ -525,14 +525,20 @@ static int mn_invl_range_start(struct mmu_notifier *mn, > > return -EAGAIN; > > > > list_for_each_entry(map, &priv->maps, next) { > > - if (!blockable && in_range(map, start, end)) { > > + if (in_range(map, start, end)) { > > + if (blockable) > > + continue; > > + > > ret = -EAGAIN; > > goto out_unlock; > > } > > unmap_if_in_range(map, start, end); > > > (I obviously missed that too with my R-b). > > This will never get anything done either. How about Yeah. I was half way out and posted a complete garbage. Sorry about that! Michal repeat after me Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! Never post patches when in hurry! What I really meant was this diff --git a/drivers/xen/gntdev.c b/drivers/xen/gntdev.c index e7d8bb1bee2a..6fcc5a44f29d 100644 --- a/drivers/xen/gntdev.c +++ b/drivers/xen/gntdev.c @@ -525,17 +525,25 @@ static int mn_invl_range_start(struct mmu_notifier *mn, return -EAGAIN; list_for_each_entry(map, &priv->maps, next) { - if (!blockable && in_range(map, start, end)) { + if (!in_range(map, start, end)) + continue; + + if (!blockable) { ret = -EAGAIN; goto out_unlock; } + unmap_if_in_range(map, start, end); } list_for_each_entry(map, &priv->freeable_maps, next) { - if (!blockable && in_range(map, start, end)) { + if (!in_range(map, start, end)) + continue; + + if (!blockable) { ret = -EAGAIN; goto out_unlock; } + unmap_if_in_range(map, start, end); } -- Michal Hocko SUSE Labs