Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp1480945rwb; Tue, 27 Sep 2022 13:51:38 -0700 (PDT) X-Google-Smtp-Source: AMsMyM6FJhuyYiCQuYASBC7M0LIMOKtbuiO16E10Okq017EbNuj8IcReCSh7y7Gk++SqpMP4xU4R X-Received: by 2002:a17:907:984:b0:77f:4d95:9e2f with SMTP id bf4-20020a170907098400b0077f4d959e2fmr25097760ejc.176.1664311898077; Tue, 27 Sep 2022 13:51:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664311898; cv=none; d=google.com; s=arc-20160816; b=CC2WYT6k5WsI4n2dIghg+IBOEW/oc40AylsJbhaAHRpeJYqEMIUgvZQBniFo/ZCsew W5dleMzYcCLgRO1f7CyAt9nWiqR7kdnH+4gpLA9hqeOE/DNxQV/tv7WcrzCXtH/fvZdp HfJQOSuyXg9KsFOaDkF0WE1CB++hrH+4qbCZo9vPAOEhSKh+9MYKsG5ppGyYltmAdBIm J7yuv/+hdsHzJJKD90d3FB1G8ed0HWY9XjPNkkqsgwaPs195RvtaYPdxiB5kSTO7Hz5Q jrWoR5NeEoZGMdDutzukFqbN0kpWhgibn3O+GzSAY/2+ZfNAfTujQky/4/WrG0qA9qTy fPIA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=YIZ0y9UAHomtacUaehn8ypReGgtyIec2adv7THfzCiU=; b=Ap6awCmtAFKgn3WB3+JDCvOTYZ9ckJWEb3o4tZxH0CbRv/2gG32J9C4L/JUGc5dJDg Y8KnDl9G3cU6nIfCBk6WEWFB66KhHyjRzAJY3i4V9LGBPPciid1mcy8lXa9uWqP2ED0C e+TWroL0U+mcX7AcBZ9/OR5miTeWdLtMn5LvKY+UVsHhnHxJbnTNhglbYz+t6Qxm4juH sqI9AmyA2dlxmpqX3jvw7T93d6ziLOylF/UFJSAERICrQeghOlWrG7bNYzi37gX3SIhP Yx/+vzPm+YOFQYTvLRZwS4DaA7lCVnOQRRbqiY6Nz9gAjhgcYs5QDVeBHqRSHgjOzCfj BZ/A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="h3/wRzqu"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id bo5-20020a0564020b2500b00457d66f2813si1029527edb.596.2022.09.27.13.51.09; Tue, 27 Sep 2022 13:51:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="h3/wRzqu"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232844AbiI0UGQ (ORCPT + 99 others); Tue, 27 Sep 2022 16:06:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45534 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232418AbiI0UF3 (ORCPT ); Tue, 27 Sep 2022 16:05:29 -0400 Received: from mail-oi1-x22f.google.com (mail-oi1-x22f.google.com [IPv6:2607:f8b0:4864:20::22f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C55D46F272; Tue, 27 Sep 2022 13:04:42 -0700 (PDT) Received: by mail-oi1-x22f.google.com with SMTP id d64so13084751oia.9; Tue, 27 Sep 2022 13:04:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date; bh=YIZ0y9UAHomtacUaehn8ypReGgtyIec2adv7THfzCiU=; b=h3/wRzqut0XN1ennxNst2ojt2POvBIvpDNQ/JTvplRqETdDfw4AOgwrevVMwzz0SAE SqE4oJHK4+OL5zm68mNceaJMr3bW/yUWFKlbwVnqjYFdKVmN/sFWr38cyNf0ltyr9XCR JQjDi0GxXNbj8610R7V5JPKD9dFC5m5LBQATLGT0lRusPIyJpmZFvkxEf3VyiqWH98V3 giiM+AX/8hCjseKySytiXfmBkk9Qiefl7wAMJgt0fCOEW7Jjw4pKtsn4396w1moTiZY5 8pjTsAyRf38U+cwYRHiJc3XkrWx9JneGx/8KVdowOFdTUHK+bCXsIyGS8lKRLABHhMpr PKag== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date; bh=YIZ0y9UAHomtacUaehn8ypReGgtyIec2adv7THfzCiU=; b=z4eEVVly4SlBErXW0k+stj3hjDzYNRTszXwda4LzGSAcl533fZCmneBzH/kxuizPP7 zBV4VYODNuk5Lfe8wIR9wK0zS+w9yA7uY9IIn7+aefzlnXNCsOh2NEEdywPwK3B0Pm3W BwL1VH6FT7sa1cois6ft2Eye6QsA7f5AFTbwLmy0OoJF11cwDXXiQjIXQjsQgDeB0uFf VSUe7hj84/Ex7ZY87acGsi73H6STu6Yl+7Xyzd9+q7hXM4OtiBBZVlkNcCaP45kkf1F5 WMNl+qQZjb45OkBvtBBlonYx9sSMZjuMPW0wuYqBVyqQh3WNz/gdxl72p8LDSZi9oMyG 8OiA== X-Gm-Message-State: ACrzQf1xeOACiha07WqE6HyEGskMDlLmG7f+VmcK/n0jh5EwqYxnMWYu f/cSbLc7c1xCLJZiL0y0X6TIuSB3COQ= X-Received: by 2002:a05:6808:1247:b0:351:4a04:8058 with SMTP id o7-20020a056808124700b003514a048058mr2560760oiv.12.1664309081885; Tue, 27 Sep 2022 13:04:41 -0700 (PDT) Received: from localhost ([12.97.180.36]) by smtp.gmail.com with ESMTPSA id 94-20020a9d0f67000000b00657daa70c37sm1120336ott.25.2022.09.27.13.04.40 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 27 Sep 2022 13:04:41 -0700 (PDT) Date: Tue, 27 Sep 2022 13:02:30 -0700 From: Yury Norov To: Valentin Schneider Cc: netdev@vger.kernel.org, linux-rdma@vger.kernel.org, linux-kernel@vger.kernel.org, Saeed Mahameed , Leon Romanovsky , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Andy Shevchenko , Rasmus Villemoes , Ingo Molnar , Peter Zijlstra , Vincent Guittot , Dietmar Eggemann , Steven Rostedt , Mel Gorman , Greg Kroah-Hartman , Heiko Carstens , Tony Luck , Jonathan Cameron , Gal Pressman , Tariq Toukan , Jesse Brandeburg Subject: Re: [PATCH v4 2/7] cpumask: Introduce for_each_cpu_andnot() Message-ID: References: <20220923132527.1001870-1-vschneid@redhat.com> <20220923155542.1212814-1-vschneid@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Sep 27, 2022 at 05:45:04PM +0100, Valentin Schneider wrote: > On 25/09/22 08:23, Yury Norov wrote: > > On Fri, Sep 23, 2022 at 04:55:37PM +0100, Valentin Schneider wrote: > >> +/** > >> + * for_each_cpu_andnot - iterate over every cpu present in one mask, excluding > >> + * those present in another. > >> + * @cpu: the (optionally unsigned) integer iterator > >> + * @mask1: the first cpumask pointer > >> + * @mask2: the second cpumask pointer > >> + * > >> + * This saves a temporary CPU mask in many places. It is equivalent to: > >> + * struct cpumask tmp; > >> + * cpumask_andnot(&tmp, &mask1, &mask2); > >> + * for_each_cpu(cpu, &tmp) > >> + * ... > >> + * > >> + * After the loop, cpu is >= nr_cpu_ids. > >> + */ > >> +#define for_each_cpu_andnot(cpu, mask1, mask2) \ > >> + for ((cpu) = -1; \ > >> + (cpu) = cpumask_next_andnot((cpu), (mask1), (mask2)), \ > >> + (cpu) < nr_cpu_ids;) > > > > This would raise cpumaks_check() warning at the very last iteration. > > Because cpu is initialized insize the loop, you don't need to check it > > at all. You can do it like this: > > > > #define for_each_cpu_andnot(cpu, mask1, mask2) \ > > for_each_andnot_bit(...) > > > > Check this series for details (and please review). > > https://lore.kernel.org/all/20220919210559.1509179-8-yury.norov@gmail.com/T/ > > > > Thanks, I'll have a look. Also, if you send first 4 patches as a separate series on top of bitmap-for-next, I'll be able to include them in bitmap-for-next and then in 6.1 pull-request. Thanks, Yury