Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp271958ybp; Thu, 3 Oct 2019 13:21:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqz83l+c0jHgN1xYJ26zBv7hJ86wwlLgWGa7SXAVStXOOdeqP7vzfbB3GymuSIRGUmhQHdN4 X-Received: by 2002:a50:99da:: with SMTP id n26mr11507964edb.293.1570134086411; Thu, 03 Oct 2019 13:21:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570134086; cv=none; d=google.com; s=arc-20160816; b=eHS+G+wembv1XFS7cAR/nbDOg0ygSzhzGhiytyY6LRuu2ymQvhgdh35oCJso7BjKnb ibpI+VlZ31t1iE5w6Fgw2pWx2hL55kFN5khtZxl5aRXmy7dTbC4fpfFGU8B123ER+O36 L7Bq+rQ5fYfJYwvyApoMAxfJwytIw6HNAH0Dcfa9//ruiiZ+ZmgVWobNheiIwHyu8VkB i8yfBqGtmkcLXB4IaeKYGZO2Bykwdima785N+q6GxB+svMYE0W664jiGSh3rJKCumntx 9U5X25NNtx0qUEZaQ+drh6mnsyuM//Pxt6e1OGHEvk74CsRKdZwyRDkksDpzsxQ3Lucy O2Jg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=/IXgKEORcxEQksXsLghF0rEwpLidLQ8jD5VXrUOmUJQ=; b=c5uKa77zSCVAH84WgZL7Oh7pZkx6uAUO22dAUmGHv5hOkcGOz1GSL38Z+bg6c+tPJU QHwAvXb0Q5lpCebg+kuf5y76S+t3qY/X9vGdbHxnRlJfb51gGPJqWiGdAij+l3y+ksbG jmbEj1GIjxisSCBNwEkTJOU/Myva6h05AVs7VM8eY9ulN/ABfO6w87kIg44PrwkSn+vr m5tmSfBeAr12MKzRS5sWfnBDMsD3ve/gJO8d692xX2ZUqfWW1f4arRctkbxWcpKmXGaN gwB9yJxklOwgwmGL9Lf6oXRtXieAzvGgcxlOAelJCyI8fCW0kn27YYBL4W6PI+OTfO2J fIeg== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id jr6si1770471ejb.307.2019.10.03.13.21.02; Thu, 03 Oct 2019 13:21:26 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389020AbfJCUUe (ORCPT + 99 others); Thu, 3 Oct 2019 16:20:34 -0400 Received: from mx2.suse.de ([195.135.220.15]:46708 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2388890AbfJCUUa (ORCPT ); Thu, 3 Oct 2019 16:20:30 -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 BBEC5B04F; Thu, 3 Oct 2019 20:20:27 +0000 (UTC) From: Davidlohr Bueso To: akpm@linux-foundation.org Cc: walken@google.com, peterz@infradead.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, dri-devel@lists.freedesktop.org, linux-rdma@vger.kernel.org, dave@stgolabs.net, Michael@vger.kernel.org, Jason Wang , virtualization@lists.linux-foundation.org, Davidlohr Bueso Subject: [PATCH 07/11] vhost: convert vhost_umem_interval_tree to half closed intervals Date: Thu, 3 Oct 2019 13:18:54 -0700 Message-Id: <20191003201858.11666-8-dave@stgolabs.net> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20191003201858.11666-1-dave@stgolabs.net> References: <20191003201858.11666-1-dave@stgolabs.net> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The vhost_umem interval tree really wants [a, b) intervals, not fully closed as currently. As such convert it to use the new interval_tree_gen.h, and also rename the 'last' endpoint in the node to 'end', which both a more suitable name for the half closed interval and also reduces the chances of some caller being missed. Cc: Michael S. Tsirkin" Cc: Jason Wang Cc: virtualization@lists.linux-foundation.org Signed-off-by: Davidlohr Bueso --- drivers/vhost/vhost.c | 19 +++++++++---------- drivers/vhost/vhost.h | 4 ++-- 2 files changed, 11 insertions(+), 12 deletions(-) diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c index 36ca2cf419bf..80c3cca24dc7 100644 --- a/drivers/vhost/vhost.c +++ b/drivers/vhost/vhost.c @@ -28,7 +28,7 @@ #include #include #include -#include +#include #include #include "vhost.h" @@ -51,7 +51,7 @@ enum { INTERVAL_TREE_DEFINE(struct vhost_umem_node, rb, __u64, __subtree_last, - START, LAST, static inline, vhost_umem_interval_tree); + START, END, static inline, vhost_umem_interval_tree); #ifdef CONFIG_VHOST_CROSS_ENDIAN_LEGACY static void vhost_disable_cross_endian(struct vhost_virtqueue *vq) @@ -1034,7 +1034,7 @@ static int vhost_new_umem_range(struct vhost_umem *umem, node->start = start; node->size = size; - node->last = end; + node->end = end; node->userspace_addr = userspace_addr; node->perm = perm; INIT_LIST_HEAD(&node->link); @@ -1112,7 +1112,7 @@ static int vhost_process_iotlb_msg(struct vhost_dev *dev, } vhost_vq_meta_reset(dev); if (vhost_new_umem_range(dev->iotlb, msg->iova, msg->size, - msg->iova + msg->size - 1, + msg->iova + msg->size, msg->uaddr, msg->perm)) { ret = -ENOMEM; break; @@ -1126,7 +1126,7 @@ static int vhost_process_iotlb_msg(struct vhost_dev *dev, } vhost_vq_meta_reset(dev); vhost_del_umem_range(dev->iotlb, msg->iova, - msg->iova + msg->size - 1); + msg->iova + msg->size); break; default: ret = -EINVAL; @@ -1320,15 +1320,14 @@ static bool iotlb_access_ok(struct vhost_virtqueue *vq, { const struct vhost_umem_node *node; struct vhost_umem *umem = vq->iotlb; - u64 s = 0, size, orig_addr = addr, last = addr + len - 1; + u64 s = 0, size, orig_addr = addr, last = addr + len; if (vhost_vq_meta_fetch(vq, addr, len, type)) return true; while (len > s) { node = vhost_umem_interval_tree_iter_first(&umem->umem_tree, - addr, - last); + addr, last); if (node == NULL || node->start > addr) { vhost_iotlb_miss(vq, addr, access); return false; @@ -1455,7 +1454,7 @@ static long vhost_set_memory(struct vhost_dev *d, struct vhost_memory __user *m) region->guest_phys_addr, region->memory_size, region->guest_phys_addr + - region->memory_size - 1, + region->memory_size, region->userspace_addr, VHOST_ACCESS_RW)) goto err; @@ -2055,7 +2054,7 @@ static int translate_desc(struct vhost_virtqueue *vq, u64 addr, u32 len, } node = vhost_umem_interval_tree_iter_first(&umem->umem_tree, - addr, addr + len - 1); + addr, addr + len); if (node == NULL || node->start > addr) { if (umem != dev->iotlb) { ret = -EFAULT; diff --git a/drivers/vhost/vhost.h b/drivers/vhost/vhost.h index e9ed2722b633..bb36cb9ed5ec 100644 --- a/drivers/vhost/vhost.h +++ b/drivers/vhost/vhost.h @@ -53,13 +53,13 @@ struct vhost_log { }; #define START(node) ((node)->start) -#define LAST(node) ((node)->last) +#define END(node) ((node)->end) struct vhost_umem_node { struct rb_node rb; struct list_head link; __u64 start; - __u64 last; + __u64 end; __u64 size; __u64 userspace_addr; __u32 perm; -- 2.16.4