Received: by 10.223.148.5 with SMTP id 5csp6359141wrq; Wed, 17 Jan 2018 12:39:32 -0800 (PST) X-Google-Smtp-Source: ACJfBovZbMvFn49fgCCa+TR5Ng8PPZeWJ7ymVoiG4IvOOOT4eqaHjnClHZULv1vm7MqY3XNaUfnD X-Received: by 10.84.217.142 with SMTP id p14mr33091979pli.289.1516221572444; Wed, 17 Jan 2018 12:39:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516221572; cv=none; d=google.com; s=arc-20160816; b=kvv0zzMJgWpxbHKeJknO48voej6yu3LQeVTe7xQ48aaJmE35gMfLs70BaR63fLFkAM zXhjh3rCkgbbaDqTvUQkP8nDuGhEobSG8vFxMtatbwDCdj/IHAAJ2B5xIKO2GQkUmE3A tcmuJJT8BjUVRJRqumoB1wI/rH5zNpc2BVDvQmS0allGte0duryI1gxQWHlSqX15QePV Aa55201je19v7XsOa0xutm0LIXDF7IQ+cmGyKCeioHYLFXWW4v3hTfGVkw9vRUtgJ8Uc EcwR38KgdUsudJPXHd+kX4LamBpnE0R5Xj1XOeUvTF8sU5/ii5tY7gR3wpwv4WsOCq36 CU9g== 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:dkim-signature:arc-authentication-results; bh=p1nKCANnj+NpenPHx5xTQWGs5IuJSDxvO05UkyJDO2c=; b=UqjU/6CQGR7jJQUPmZf+mdiZHbnvwdvle41T0dXJLJ8nd0MqBm40a9LRy2zJ11aCXd HvteHpLZXdV+hQzP7ROYOa/Z23n5mqvtMuO8GmW/t4lI1125SsPSXf6zLnWw0oPAlNtI nj5ZHUmkXZeeqYr5vk+rFYYUi1CB9JS0WAE26FvBhdvxxaYd+dsko6Yl3ZtKHreXareC cAZEe+aB963gbqYCN7EEjPr7QbJD4D72JB7z3D9bIWIrNEnkY11CY5gDf7/fsNADuI1+ a7eqsiabShAJAxw1ahrKfWoo8DQwspYT5MFzh21j5eWTL1WeZPrfjbhA5ZiBNJajgYu7 YyOQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=CWYgI2D7; 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 l26si5000804pfj.401.2018.01.17.12.39.18; Wed, 17 Jan 2018 12:39:32 -0800 (PST) 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=@infradead.org header.s=bombadil.20170209 header.b=CWYgI2D7; 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 S1754603AbeAQUiN (ORCPT + 99 others); Wed, 17 Jan 2018 15:38:13 -0500 Received: from bombadil.infradead.org ([65.50.211.133]:57541 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753822AbeAQUWz (ORCPT ); Wed, 17 Jan 2018 15:22:55 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=References:In-Reply-To:Message-Id: Date:Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=p1nKCANnj+NpenPHx5xTQWGs5IuJSDxvO05UkyJDO2c=; b=CWYgI2D7YgaBoQYajPBP7Jpgk S8B86ykiQybmpD5rPRVoJfs7zJVTRXLC1cA6zaWLMBCvg/fCXAgcUU0orhyGFu6buHAas41QK5wxJ sTEXeuQgKVR9mmmAekeI+Q+3OBTA1gvucSMym38+tTXwj+Uz7rYSJCaTnstLAJN+ZJK9H7Tjmlo9T MAUwsqyn7QZ7sCzrhpS9GDXpx/HKb0Lt6g0mklkeVN+tO6tfVe18ics8vGTrig+S3eKngQbMwWP4K ZAdrhV37f1ibaZ5Zd7picZrAvpw0GCkMKKZyixwxt0BYEpIdhwKAW7C6JRXFmCMZZU/CT5gbWhYi5 vlHy0qv1Q==; Received: from willy by bombadil.infradead.org with local (Exim 4.89 #1 (Red Hat Linux)) id 1ebuEX-00068M-Pm; Wed, 17 Jan 2018 20:22:53 +0000 From: Matthew Wilcox To: linux-kernel@vger.kernel.org Cc: Matthew Wilcox , linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, linux-f2fs-devel@lists.sourceforge.net, linux-nilfs@vger.kernel.org, linux-btrfs@vger.kernel.org, linux-xfs@vger.kernel.org, linux-usb@vger.kernel.org, Bjorn Andersson , Stefano Stabellini , iommu@lists.linux-foundation.org, linux-remoteproc@vger.kernel.org, linux-s390@vger.kernel.org, intel-gfx@lists.freedesktop.org, cgroups@vger.kernel.org, linux-sh@vger.kernel.org, David Howells Subject: [PATCH v6 68/99] vmalloc: Convert to XArray Date: Wed, 17 Jan 2018 12:21:32 -0800 Message-Id: <20180117202203.19756-69-willy@infradead.org> X-Mailer: git-send-email 2.14.3 In-Reply-To: <20180117202203.19756-1-willy@infradead.org> References: <20180117202203.19756-1-willy@infradead.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Matthew Wilcox The radix tree of vmap blocks is simpler to express as an XArray. Saves a couple of hundred bytes of text and eliminates a user of the radix tree preload API. Signed-off-by: Matthew Wilcox --- mm/vmalloc.c | 39 +++++++++++++-------------------------- 1 file changed, 13 insertions(+), 26 deletions(-) diff --git a/mm/vmalloc.c b/mm/vmalloc.c index 673942094328..b6c138633592 100644 --- a/mm/vmalloc.c +++ b/mm/vmalloc.c @@ -23,7 +23,7 @@ #include #include #include -#include +#include #include #include #include @@ -821,12 +821,11 @@ struct vmap_block { static DEFINE_PER_CPU(struct vmap_block_queue, vmap_block_queue); /* - * Radix tree of vmap blocks, indexed by address, to quickly find a vmap block + * XArray of vmap blocks, indexed by address, to quickly find a vmap block * in the free path. Could get rid of this if we change the API to return a * "cookie" from alloc, to be passed to free. But no big deal yet. */ -static DEFINE_SPINLOCK(vmap_block_tree_lock); -static RADIX_TREE(vmap_block_tree, GFP_ATOMIC); +static DEFINE_XARRAY(vmap_block_tree); /* * We should probably have a fallback mechanism to allocate virtual memory @@ -865,8 +864,8 @@ static void *new_vmap_block(unsigned int order, gfp_t gfp_mask) struct vmap_block *vb; struct vmap_area *va; unsigned long vb_idx; - int node, err; - void *vaddr; + int node; + void *ret, *vaddr; node = numa_node_id(); @@ -883,13 +882,6 @@ static void *new_vmap_block(unsigned int order, gfp_t gfp_mask) return ERR_CAST(va); } - err = radix_tree_preload(gfp_mask); - if (unlikely(err)) { - kfree(vb); - free_vmap_area(va); - return ERR_PTR(err); - } - vaddr = vmap_block_vaddr(va->va_start, 0); spin_lock_init(&vb->lock); vb->va = va; @@ -902,11 +894,12 @@ static void *new_vmap_block(unsigned int order, gfp_t gfp_mask) INIT_LIST_HEAD(&vb->free_list); vb_idx = addr_to_vb_idx(va->va_start); - spin_lock(&vmap_block_tree_lock); - err = radix_tree_insert(&vmap_block_tree, vb_idx, vb); - spin_unlock(&vmap_block_tree_lock); - BUG_ON(err); - radix_tree_preload_end(); + ret = xa_store(&vmap_block_tree, vb_idx, vb, gfp_mask); + if (xa_is_err(ret)) { + kfree(vb); + free_vmap_area(va); + return ERR_PTR(xa_err(ret)); + } vbq = &get_cpu_var(vmap_block_queue); spin_lock(&vbq->lock); @@ -923,9 +916,7 @@ static void free_vmap_block(struct vmap_block *vb) unsigned long vb_idx; vb_idx = addr_to_vb_idx(vb->va->va_start); - spin_lock(&vmap_block_tree_lock); - tmp = radix_tree_delete(&vmap_block_tree, vb_idx); - spin_unlock(&vmap_block_tree_lock); + tmp = xa_erase(&vmap_block_tree, vb_idx); BUG_ON(tmp != vb); free_vmap_area_noflush(vb->va); @@ -1031,7 +1022,6 @@ static void *vb_alloc(unsigned long size, gfp_t gfp_mask) static void vb_free(const void *addr, unsigned long size) { unsigned long offset; - unsigned long vb_idx; unsigned int order; struct vmap_block *vb; @@ -1045,10 +1035,7 @@ static void vb_free(const void *addr, unsigned long size) offset = (unsigned long)addr & (VMAP_BLOCK_SIZE - 1); offset >>= PAGE_SHIFT; - vb_idx = addr_to_vb_idx((unsigned long)addr); - rcu_read_lock(); - vb = radix_tree_lookup(&vmap_block_tree, vb_idx); - rcu_read_unlock(); + vb = xa_load(&vmap_block_tree, addr_to_vb_idx((unsigned long)addr)); BUG_ON(!vb); vunmap_page_range((unsigned long)addr, (unsigned long)addr + size); -- 2.15.1