Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp594755ybz; Wed, 15 Apr 2020 14:47:02 -0700 (PDT) X-Google-Smtp-Source: APiQypLI0yEW/r8bjj3vQCAYIn5jrNMBig4AlbHjF+EwBjiwPF9I39EFEL2HIKLq+ytjZxZd/Xli X-Received: by 2002:a17:906:52c2:: with SMTP id w2mr6827631ejn.117.1586987222680; Wed, 15 Apr 2020 14:47:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586987222; cv=none; d=google.com; s=arc-20160816; b=jMcVCocw0CqfY4jNw6KRd06FRL7yRUvD7+Ne6oDhqRLq9gSKlUiTrn1LRGjpY7TpwG 1niD3TLpeM60cRx0IdUwwnOSwPUENsg7K2QCagPn/ILHBK3G6NUhJsLUfC40PJ/ZVXks pwxt88ae0ZI4HRidbwfgBdk6UW66vln1QwODWUR6gz8zmtSD3YnS6dX9PLzymzrfWcB8 vsRmf8O0VOdEJC8mCxNvSxTgV5na+RShPAmN887cds/0OFmMeTw2/3PaFPVxYLTSq0Ri lSVfmcs1Pk/z2aA53yjnIUH88UTVnER58Hs4rkluec35rvMfkZuZJU8haMOSO7++MXTH ufzg== 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 :references:in-reply-to:message-id:subject:cc:to:from:date; bh=1hx2F5Atwu8XBSvlv/ovSC6CgxjwyCeeeGunX9Ws0Ps=; b=D+awvYizIUOOnQF5TAcjb7nHD5gQwoZZynGr3zoA20aPAZRUN95douD+iMbBGybY0w yx9HK5tA8mMTKqEGthy5p33BgN8+A0RWrr+8pGEuQmQNduZy3ikH/gdFwmZz0V+pV3Na DSbiCb4p6geCDfkwyULJVEGiFY4hH/mIEXGvvmhbLi6WKg26G7ngyzm+rXBsJtyVcj2W zRu0etp8+yNvvmpa86JNjwwDA/cJVwZRjMejm+zcVPmJ6vkmB9is7dkkfFJepDIX1Kg9 teQ9IxhfipD9yeFkFwh7j4zYyP4P2rh7/4+yGjO2ITixs+1ACQ5M7QEF5+Er+aJO/Mu1 X9ow== 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 y71si12163466ede.301.2020.04.15.14.46.39; Wed, 15 Apr 2020 14:47:02 -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 S2391588AbgDNQ2R (ORCPT + 99 others); Tue, 14 Apr 2020 12:28:17 -0400 Received: from mail.kernel.org ([198.145.29.99]:41086 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2391585AbgDNQ2P (ORCPT ); Tue, 14 Apr 2020 12:28:15 -0400 Received: from gandalf.local.home (cpe-66-24-58-225.stny.res.rr.com [66.24.58.225]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 18F182075E; Tue, 14 Apr 2020 16:28:12 +0000 (UTC) Date: Tue, 14 Apr 2020 12:28:10 -0400 From: Steven Rostedt To: Qais Yousef Cc: Ingo Molnar , Peter Zijlstra , Juri Lelli , Vincent Guittot , Dietmar Eggemann , Ben Segall , Mel Gorman , Andrew Morton , Thomas Gleixner , Yury Norov , Paul Turner , Alexey Dobriyan , Josh Don , Pavan Kondeti , linux-kernel@vger.kernel.org Subject: Re: [PATCH 3/4] cpumask: Convert cpumask_any_but() to the new random function Message-ID: <20200414122810.4b83ddd2@gandalf.local.home> In-Reply-To: <20200414150556.10920-4-qais.yousef@arm.com> References: <20200414150556.10920-1-qais.yousef@arm.com> <20200414150556.10920-4-qais.yousef@arm.com> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 14 Apr 2020 16:05:55 +0100 Qais Yousef wrote: > +int cpumask_any_but(const struct cpumask *srcp, unsigned int cpu) > +{ > + unsigned int i; > + > + cpumask_check(cpu); > + > + for_each_cpu(i, srcp) { > + i = cpumask_any(srcp); Hmm, if the current CPU is the last CPU in the mask, and cpumask_any() happens to return it, what happens? > + if (i != cpu) > + return i; We loop again, and wouldn't i being the last CPU in the mask cause this loop to exit, and return nr_cpu_ids? -- Steve > + } > + > + return nr_cpu_ids; > +}