Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp421808imm; Tue, 5 Jun 2018 23:12:10 -0700 (PDT) X-Google-Smtp-Source: ADUXVKIGRvn4D6KhgEidiJTGn8fFhgBSoxShtCBGNdubOo3v2UhXi+RLroYSUrFheK9kmsmKhbLz X-Received: by 2002:a63:8a4a:: with SMTP id y71-v6mr1446895pgd.291.1528265530472; Tue, 05 Jun 2018 23:12:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528265530; cv=none; d=google.com; s=arc-20160816; b=i/nwKRp/HSXGS7ts7g5a0LhtIlnyL7mc70EHCl5peSdoeJRAgZevreGXBKXMxFoPVE e8bjwUpJfFfYZdJsUB6cYhM06R/UEfZq0GJb8PSw+WR7PX8fVnoAzOnASbJtZNxsICQO tUj2W6qnt271T3ZTvLPH6+9mnQ2b5qIzurCjHQc5ld+xKBrbASezjSRXYDMLcseXBgt6 UtaTB04vBVMBixEVa4Zs9hAKYxfm3h2obblB3B08Z0o00axzNHHvSRv8Ji7Ydvzj/0xL Fe6U/0+O+zcuAI13CLsJgjmiVmYpJyC2uOlYjt1RTaUIUAGXP3wq7+YV+NfeaMGSAM7x DfmQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:cc:subject:date:to :from:arc-authentication-results; bh=6YC05FWJiVR0cEo4OQ0oxSQJ1Sso1wCGpW5ZEHaFRiE=; b=07ZdyWw+rF4F97A6Dbs+45CHV8Kk1emygkblAQHzwboNmQ0/aCNXjEAvlUY52uM8Ir cuyqG1WZBXQKRM2sBB4OZD7vp3wnN2vDRBzrg5d0YNczYMy9v7DQh60LHZLAClbxW+gV nx2L93t7+ye3FYWceZX2/6slZawFg2VifS/H8IKawWot6lgcBWUR1nu5sOWIfS+GGmM5 A55r2nPhj/JHfHka+yvTvrSCKixL0n6oOKDR1gHDuZ3x5uRNiiHq3XMSGezp/+s8DqVI bqQlAzqrDCWsMQoupeHay3xNcmCWysWANf71FmkC6/ajI1vkbKsbv8N+3oqtjd0ovPCn ERtg== 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 127-v6si51111017pfe.49.2018.06.05.23.11.55; Tue, 05 Jun 2018 23:12: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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932195AbeFFGLX (ORCPT + 99 others); Wed, 6 Jun 2018 02:11:23 -0400 Received: from mx2.suse.de ([195.135.220.15]:52273 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932150AbeFFGLW (ORCPT ); Wed, 6 Jun 2018 02:11:22 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay1.suse.de (charybdis-ext-too.suse.de [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id BF690AF55; Wed, 6 Jun 2018 06:11:20 +0000 (UTC) From: NeilBrown To: Oleg Drokin , Greg Kroah-Hartman , James Simmons , Andreas Dilger Date: Wed, 06 Jun 2018 16:05:18 +1000 Subject: [PATCH 02/11] staging: lustre: change lock_matches() to return bool. Cc: Linux Kernel Mailing List , Lustre Development List Message-ID: <152826511895.16761.11859115039331359491.stgit@noble> In-Reply-To: <152826510267.16761.14361003167157833896.stgit@noble> References: <152826510267.16761.14361003167157833896.stgit@noble> User-Agent: StGit/0.17.1-dirty MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The name of the function lock_matches() sounds like it performs a test (it does) and so should return a bool. Returning a bool gives a slight code simplification (in search_queue) and more simplification in future patches. Signed-off-by: NeilBrown --- drivers/staging/lustre/lustre/ldlm/ldlm_lock.c | 37 ++++++++++++------------ 1 file changed, 18 insertions(+), 19 deletions(-) diff --git a/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c b/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c index 13b1b5fdada9..034935e06393 100644 --- a/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c +++ b/drivers/staging/lustre/lustre/ldlm/ldlm_lock.c @@ -1053,20 +1053,20 @@ struct lock_match_data { * \param lock test-against this lock * \param data parameters */ -static int lock_matches(struct ldlm_lock *lock, struct lock_match_data *data) +static bool lock_matches(struct ldlm_lock *lock, struct lock_match_data *data) { union ldlm_policy_data *lpol = &lock->l_policy_data; enum ldlm_mode match; if (lock == data->lmd_old) - return INTERVAL_ITER_STOP; + return true; /* * Check if this lock can be matched. * Used by LU-2919(exclusive open) for open lease lock */ if (ldlm_is_excl(lock)) - return INTERVAL_ITER_CONT; + return false; /* * llite sometimes wants to match locks that will be @@ -1078,26 +1078,26 @@ static int lock_matches(struct ldlm_lock *lock, struct lock_match_data *data) */ if (ldlm_is_cbpending(lock) && !(data->lmd_flags & LDLM_FL_CBPENDING)) - return INTERVAL_ITER_CONT; + return false; if (!data->lmd_unref && ldlm_is_cbpending(lock) && !lock->l_readers && !lock->l_writers) - return INTERVAL_ITER_CONT; + return false; if (!(lock->l_req_mode & *data->lmd_mode)) - return INTERVAL_ITER_CONT; + return false; match = lock->l_req_mode; switch (lock->l_resource->lr_type) { case LDLM_EXTENT: if (lpol->l_extent.start > data->lmd_policy->l_extent.start || lpol->l_extent.end < data->lmd_policy->l_extent.end) - return INTERVAL_ITER_CONT; + return false; if (unlikely(match == LCK_GROUP) && data->lmd_policy->l_extent.gid != LDLM_GID_ANY && lpol->l_extent.gid != data->lmd_policy->l_extent.gid) - return INTERVAL_ITER_CONT; + return false; break; case LDLM_IBITS: /* @@ -1107,7 +1107,7 @@ static int lock_matches(struct ldlm_lock *lock, struct lock_match_data *data) if ((lpol->l_inodebits.bits & data->lmd_policy->l_inodebits.bits) != data->lmd_policy->l_inodebits.bits) - return INTERVAL_ITER_CONT; + return false; break; default: break; @@ -1117,10 +1117,10 @@ static int lock_matches(struct ldlm_lock *lock, struct lock_match_data *data) * of bits. */ if (!data->lmd_unref && LDLM_HAVE_MASK(lock, GONE)) - return INTERVAL_ITER_CONT; + return false; if (!equi(data->lmd_flags & LDLM_FL_LOCAL_ONLY, ldlm_is_local(lock))) - return INTERVAL_ITER_CONT; + return false; if (data->lmd_flags & LDLM_FL_TEST_LOCK) { LDLM_LOCK_GET(lock); @@ -1132,15 +1132,17 @@ static int lock_matches(struct ldlm_lock *lock, struct lock_match_data *data) *data->lmd_mode = match; data->lmd_lock = lock; - return INTERVAL_ITER_STOP; + return true; } static enum interval_iter itree_overlap_cb(struct interval_node *in, void *args) { struct lock_match_data *data = args; - struct ldlm_lock *lock = container_of(in, struct ldlm_lock, l_tree_node); + struct ldlm_lock *lock = container_of(in, struct ldlm_lock, + l_tree_node); - return lock_matches(lock, data); + return lock_matches(lock, data) ? + INTERVAL_ITER_STOP : INTERVAL_ITER_CONT; } /** @@ -1187,13 +1189,10 @@ static struct ldlm_lock *search_queue(struct list_head *queue, struct lock_match_data *data) { struct ldlm_lock *lock; - int rc; - list_for_each_entry(lock, queue, l_res_link) { - rc = lock_matches(lock, data); - if (rc == INTERVAL_ITER_STOP) + list_for_each_entry(lock, queue, l_res_link) + if (lock_matches(lock, data)) return data->lmd_lock; - } return NULL; }