Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp799681ybz; Wed, 22 Apr 2020 08:12:59 -0700 (PDT) X-Google-Smtp-Source: APiQypJ29o/KQBEJcOIozQbdftEKFoEvmvcXyEsEnWM/YHwTabLHHYv+4O1khzurOVv76FvHnjWP X-Received: by 2002:a17:906:9494:: with SMTP id t20mr25487176ejx.51.1587568379239; Wed, 22 Apr 2020 08:12:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587568379; cv=none; d=google.com; s=arc-20160816; b=ZFIjl6Ty9XSARiyAdc3XXdVo0Zj7KP7o1uPQkQobQQgIkmpFAX8QjqvMUOMf1YzYI0 ioEmRV7O/+KdqqFJJoEKL8YhDpZpiFVIKMm1kGUuo4YMoRiF0Zs5mkCjkefy5AdIgbky 3yyLIACxedhJoMPSHokDtyzHkCTqCczvu8eM9xyMg6vUxnW/sqOdI4jrirhnk0BfCwyJ jLUVxiJx7+naopQFFBo09HSc7J3B5wSYMnejVErt2OtzH+ZJr+jK/hcVkd5jWTWZKAUR 1ynjTIQzvn8Ao5qlkc7CLVM+Rbz4/63D1koKCXmrWmowuGgQOC/czorNSkwLTlLaGqb2 zIYg== 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=F8qz1fKBH6EleLbv7MjFT79a6MUTQcGLEdwrJcI67S8=; b=J5y8eKE9+lqtmxj1Qdg5NPAHF67IxIePIbTCNuhyryWpfCgzxTmmFxqOBvfVJENuWK N2tg9FAHcOpbLnNsYi4IMOkFJf6XbgSf1Nx3Ufp7cq4Z5yi1JriAT1CVTX/ItbBvKCh3 gZtpBXe8fHGqHBjg1DqIuU1pM+yvkmzzKLI5j1bZIMz4tC3uw+bJidWILjfl6zIfLOqH eOqca7M36DKzkaZB0tipTTFcg/x5YPZzLQ67ReQ2VwTDUoxiKu1ZsF47jQ1GKlhOor7U 8UWnY2/Ok58i1HCUcT0T+YCT8+5ksHHc8pvsUUhC3nPgmr+nfHEir3zTURp1YHTDF8Ny MsQg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dx23si3674228ejb.181.2020.04.22.08.12.19; Wed, 22 Apr 2020 08:12:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728303AbgDVPDu (ORCPT + 99 others); Wed, 22 Apr 2020 11:03:50 -0400 Received: from mx2.suse.de ([195.135.220.15]:58096 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728122AbgDVPDI (ORCPT ); Wed, 22 Apr 2020 11:03:08 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id 9AC64AEE1; Wed, 22 Apr 2020 15:03:03 +0000 (UTC) Received: by quack2.suse.cz (Postfix, from userid 1000) id B14CB1E0E83; Wed, 22 Apr 2020 17:03:03 +0200 (CEST) From: Jan Kara To: Matthew Wilcox Cc: , LKML , Jan Kara Subject: [PATCH 21/23] testing: Introduce xa_erase_order() and use it Date: Wed, 22 Apr 2020 17:02:54 +0200 Message-Id: <20200422150256.23473-22-jack@suse.cz> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20200422150256.23473-1-jack@suse.cz> References: <20200422150256.23473-1-jack@suse.cz> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Introduce helper xa_erase_order() and call it from places that want to erase entries from xarray instead of using xa_store_order(). This also explicitely takes care of clearing possibly existing xarray marks (although no current test seems to need it). Signed-off-by: Jan Kara --- lib/test_xarray.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/lib/test_xarray.c b/lib/test_xarray.c index 2cf3ef5d5014..fc16eac1cbb9 100644 --- a/lib/test_xarray.c +++ b/lib/test_xarray.c @@ -83,6 +83,16 @@ static void *xa_store_order(struct xarray *xa, unsigned long index, return curr; } +static void xa_erase_order(struct xarray *xa, unsigned long index, + unsigned order) +{ + XA_STATE_ORDER(xas, xa, index, order); + + xas_lock(&xas); + xas_erase(&xas); + xas_unlock(&xas); +} + static noinline void check_xa_err(struct xarray *xa) { XA_BUG_ON(xa, xa_err(xa_store_index(xa, 0, GFP_NOWAIT)) != 0); @@ -608,13 +618,13 @@ static noinline void check_multi_store(struct xarray *xa) rcu_read_unlock(); /* We can erase multiple values with a single store */ - xa_store_order(xa, 0, BITS_PER_LONG - 1, NULL, GFP_KERNEL); + xa_erase_order(xa, 0, BITS_PER_LONG - 1); XA_BUG_ON(xa, !xa_empty(xa)); /* Even when the first slot is empty but the others aren't */ xa_store_index(xa, 1, GFP_KERNEL); xa_store_index(xa, 2, GFP_KERNEL); - xa_store_order(xa, 0, 2, NULL, GFP_KERNEL); + xa_erase_order(xa, 0, 2); XA_BUG_ON(xa, !xa_empty(xa)); for (i = 0; i < max_order; i++) { -- 2.16.4