Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp4790428imd; Tue, 30 Oct 2018 07:29:03 -0700 (PDT) X-Google-Smtp-Source: AJdET5eX7fVpXoMY9nTJdcut6dNyF51f6MaLGevP+yUY5en3lcFmlkXxQw8+BsLe1fn2/Gn6zysa X-Received: by 2002:a17:902:1a7:: with SMTP id b36-v6mr18815467plb.240.1540909743943; Tue, 30 Oct 2018 07:29:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540909743; cv=none; d=google.com; s=arc-20160816; b=0zHVPMCjZSDRgGMmZIPjlpetRaLtrXOVYjxR8kV36RMpy/zlBfYamHlJtjghaOlM2O pRVCnPdm8ixEmgiU1EpWMrNvY0GiwhqE88ZZhf4r9I2uvitQbVff2FqFz0fi2bPVxFSU GkWwDQQD2XGQIKRt4ISGvonfmnoWiQwKhJ2302DFVY2PchXemfYhMxMC8kU9uWmyAvmc L6mqVmh26+fzblyPvVqMdbrlsqSVMGLcVGn3UsU2h6UTu+4m2ou4IBQUXV2jKwhJVI5v paN1AY3vEqJF6XPySWp93ZyjLXnK+M9W5JAQ9mJGH8zE8bE6CV9WPPvk/+Uhv5XQPfWD Ijwg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=PDkk8Uze9GbS7hz20Am+to4QMxjOHLmYc/aZe/TjtlM=; b=AvZLrpUFc/NtoL29ZuMdqyjcfjSwe3AtgGmQ/DeWY9apEYzrTAao6ZSV+Ks975GKnJ aipyKadQpBeab2pRoU1R725qCL6ZTXYTd875JdOL4cYE63IXM01txHeF43mOuxdO4vC4 KGwOA6HLgtMncKtg+S48HsjTP5H1/DZx7AQmdcbKmw03R7qHCpjHcInsbdFkRz2Ndtyh AiBls0iXpsZLD3AxkcrPp7Mvzu3anateQrY5g2Tqgpkm55JIRao1jjsqs3PtwP9TNmTf Oo3gKG+0KG4KSO3He+jXG6/4KIfwLW3Md3vj9eYs9e5xXImvdXQCeCJTS+lrbClHN2V5 oHig== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h17-v6si22479709pfi.84.2018.10.30.07.28.47; Tue, 30 Oct 2018 07:29:03 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728221AbeJ3XWG (ORCPT + 99 others); Tue, 30 Oct 2018 19:22:06 -0400 Received: from mga07.intel.com ([134.134.136.100]:51282 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728117AbeJ3XWF (ORCPT ); Tue, 30 Oct 2018 19:22:05 -0400 X-Amp-Result: UNSCANNABLE X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga105.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 30 Oct 2018 07:28:23 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.54,444,1534834800"; d="scan'208";a="103790212" Received: from unknown (HELO localhost.localdomain) ([10.232.112.69]) by fmsmga001.fm.intel.com with ESMTP; 30 Oct 2018 07:28:22 -0700 Date: Tue, 30 Oct 2018 08:26:01 -0600 From: Keith Busch To: Jens Axboe Cc: linux-block@vger.kernel.org, linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org, Thomas Gleixner Subject: Re: [PATCH 11/14] irq: add support for allocating (and affinitizing) sets of IRQs Message-ID: <20181030142601.GA18906@localhost.localdomain> References: <20181029163738.10172-1-axboe@kernel.dk> <20181029163738.10172-12-axboe@kernel.dk> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20181029163738.10172-12-axboe@kernel.dk> User-Agent: Mutt/1.9.1 (2017-09-22) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Oct 29, 2018 at 10:37:35AM -0600, Jens Axboe wrote: > diff --git a/kernel/irq/affinity.c b/kernel/irq/affinity.c > index f4f29b9d90ee..2046a0f0f0f1 100644 > --- a/kernel/irq/affinity.c > +++ b/kernel/irq/affinity.c > @@ -180,6 +180,7 @@ irq_create_affinity_masks(int nvecs, const struct irq_affinity *affd) > int curvec, usedvecs; > cpumask_var_t nmsk, npresmsk, *node_to_cpumask; > struct cpumask *masks = NULL; > + int i, nr_sets; > > /* > * If there aren't any vectors left after applying the pre/post > @@ -210,10 +211,23 @@ irq_create_affinity_masks(int nvecs, const struct irq_affinity *affd) > get_online_cpus(); > build_node_to_cpumask(node_to_cpumask); > > - /* Spread on present CPUs starting from affd->pre_vectors */ > - usedvecs = irq_build_affinity_masks(affd, curvec, affvecs, > - node_to_cpumask, cpu_present_mask, > - nmsk, masks); > + /* > + * Spread on present CPUs starting from affd->pre_vectors. If we > + * have multiple sets, build each sets affinity mask separately. > + */ > + nr_sets = affd->nr_sets; > + if (!nr_sets) > + nr_sets = 1; > + > + for (i = 0, usedvecs = 0; i < nr_sets; i++) { > + int this_vecs = affd->sets ? affd->sets[i] : affvecs; > + int nr; > + > + nr = irq_build_affinity_masks(affd, curvec, this_vecs, > + node_to_cpumask, cpu_present_mask, > + nmsk, masks + usedvecs); > + usedvecs += nr; > + } While the code below returns the appropriate number of possible vectors when a set requested too many, the above code is still using the value from the set, which may exceed 'nvecs' used to kcalloc 'masks', so 'masks + usedvecs' may go out of bounds. > /* > * Spread on non present CPUs starting from the next vector to be > @@ -258,13 +272,21 @@ int irq_calc_affinity_vectors(int minvec, int maxvec, const struct irq_affinity > { > int resv = affd->pre_vectors + affd->post_vectors; > int vecs = maxvec - resv; > - int ret; > + int set_vecs; > > if (resv > minvec) > return 0; > > - get_online_cpus(); > - ret = min_t(int, cpumask_weight(cpu_possible_mask), vecs) + resv; > - put_online_cpus(); > - return ret; > + if (affd->nr_sets) { > + int i; > + > + for (i = 0, set_vecs = 0; i < affd->nr_sets; i++) > + set_vecs += affd->sets[i]; > + } else { > + get_online_cpus(); > + set_vecs = cpumask_weight(cpu_possible_mask); > + put_online_cpus(); > + } > + > + return resv + min(set_vecs, vecs); > }