Received: by 2002:ac0:98c7:0:0:0:0:0 with SMTP id g7-v6csp3612648imd; Mon, 29 Oct 2018 09:39:24 -0700 (PDT) X-Google-Smtp-Source: AJdET5eifRhZS9D/4rduVFKdGPn6aYP9dgnOs02pZEQRhyC4/TYhwj57nGdCZ218ISQygyKp9HpY X-Received: by 2002:a62:104b:: with SMTP id y72-v6mr16011013pfi.113.1540831164114; Mon, 29 Oct 2018 09:39:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540831164; cv=none; d=google.com; s=arc-20160816; b=PGemBp+2aOZtxuh2v+OlpYqNH312TNLJpAgy3oFfko8WncKhxgOVAmY0XwdQQXy8Wz jUPkh1fiEUAaTu1XOQw1guKB7/CJ7HDHENt3eQobBOZ4cVtsB7+6HCYfCEmPLiUTVx46 01r8ebg+XcRGuqyRovRe07SPyRW/kuKAT4+Px1ty30GqBa4ts297jH+N8o2FROvC0qaB Ntj4d36PIIKgXscVe2eePoUMTGmkSPkdsiryq1Ic1orl5X5Meb8dpRzJ6ZvmMFpxtJpM oG0vWPdlK5UB78oEFFt1gm39xAtpL4ULNJJ0S+6mSZqB93IjtjW/WqaRz7p2AX8VTnjM Dxyw== 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:dkim-signature; bh=eukhLpnpSqFgkXd6fwxIBdknpGfhnAOi4PUxG7MjAPc=; b=wVl+N+/MhsU1Ba68hJa2DchoLMJnVtPXOBg99RlT+julGPoRwX+iiUlggAnvnJi5hb 1nI6kba8UoZZAOVDWPrER1qGYHqp2H3BBkjFODugUcLivwFxYjp1CNRG22dQQU8ccrzh EvQrfmoWcyoGrxrQkTZK0cn95iXf/Sn3Dyi1Sb4+qdeLAxU50xXq2ezr3EU0NvN2iaJz nUMxvkgI1Td2xVLtCb3q/9MRb5COvfmZ4h/eUvx3wx4wLYKnJa0VEKt4SIuJIB9lERvS 6tcIQ9Lj1zF903HBOlqLZLMJWvCgRFZ6Yeithh3Sau2si5XxGQRRoTWe1cfxM18SsMoc 0Dfw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=AIPNHXKu; 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 y124-v6si20687134pgy.363.2018.10.29.09.39.08; Mon, 29 Oct 2018 09:39:24 -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; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=AIPNHXKu; 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 S1728349AbeJ3B13 (ORCPT + 99 others); Mon, 29 Oct 2018 21:27:29 -0400 Received: from mail-it1-f195.google.com ([209.85.166.195]:54900 "EHLO mail-it1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727461AbeJ3B13 (ORCPT ); Mon, 29 Oct 2018 21:27:29 -0400 Received: by mail-it1-f195.google.com with SMTP id d6so4718660itl.4 for ; Mon, 29 Oct 2018 09:38:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel-dk.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=eukhLpnpSqFgkXd6fwxIBdknpGfhnAOi4PUxG7MjAPc=; b=AIPNHXKuRPpEDkKj0gOHLJv8h1wUyO1OQ649DAib/5VXwcfXfApINpexfzi/OEmyWM ByVl2GjNjeRztMNXg8Nyfy9/yUcgo6B7WCKskznq3ja+rMAiKsLtT8+g+TMxf2Wdzmre DY0XBnYmjCeq3goRB6agwt8eSaoAMvG3tbN9sCh8tKkk4woixyCzuoZjlcvT/QtQEQAy gZl2tI48OD3FxQU1SElBNX8arISa5ZFZWUQNjHJV9BtYIRZhF3hK7Ug1nmHFsSk20/Oa JOpmGFtEhvRgHRRU6Kd5uIpJandGXpTdZ6u4nVS9tcyLrM+E00tOx/lSfWerxze27lof QMPw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=eukhLpnpSqFgkXd6fwxIBdknpGfhnAOi4PUxG7MjAPc=; b=CiCzEufDcGC8bmW7k7EDQIsGIUVEh591YS2MFdkS5RWF8iPKav1mu1JASPJXLeqXee 7DX4zkXyi5nApSZZzbu7jRf1kgrd9OIAWKNxyd5dqO4e1HBvUCEXEUDuGWsoHIuCxHnk LxHG602l4hDBiSkqmRCcLRShRETzjTNvzRBh96zwFj8hsYoim8Tr9miekou3jtLjxDfl QoR7E/EivuZ29RxexLyipfpPfQjTSUmKcQBDAbQ2EO162rJ6pdk3JqxZood65UmokeTs Otg/Vw2M+ovTpMUixPyVcjFOXtHiQr3GTH1xdegdcAhjh1Tmq9SLabLItqp2LGZKKFBW KH8w== X-Gm-Message-State: AGRZ1gKrzm7BCEmDXUOGymQYUoON8XpY8S1WHwnbzdXisMDFfAOleZAc FhYKtwg461ktuj3F7B2iQyO8bA== X-Received: by 2002:a02:3b2c:: with SMTP id c44-v6mr10944100jaa.31.1540831087063; Mon, 29 Oct 2018 09:38:07 -0700 (PDT) Received: from localhost.localdomain ([216.160.245.98]) by smtp.gmail.com with ESMTPSA id q15-v6sm3367019itc.38.2018.10.29.09.38.03 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 29 Oct 2018 09:38:04 -0700 (PDT) From: Jens Axboe To: linux-block@vger.kernel.org, linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Jens Axboe , Thomas Gleixner Subject: [PATCH 11/14] irq: add support for allocating (and affinitizing) sets of IRQs Date: Mon, 29 Oct 2018 10:37:35 -0600 Message-Id: <20181029163738.10172-12-axboe@kernel.dk> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20181029163738.10172-1-axboe@kernel.dk> References: <20181029163738.10172-1-axboe@kernel.dk> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org A driver may have a need to allocate multiple sets of MSI/MSI-X interrupts, and have them appropriately affinitized. Add support for defining a number of sets in the irq_affinity structure, of varying sizes, and get each set affinitized correctly across the machine. Cc: Thomas Gleixner Cc: linux-kernel@vger.kernel.org Reviewed-by: Hannes Reinecke Signed-off-by: Jens Axboe --- include/linux/interrupt.h | 4 ++++ kernel/irq/affinity.c | 40 ++++++++++++++++++++++++++++++--------- 2 files changed, 35 insertions(+), 9 deletions(-) diff --git a/include/linux/interrupt.h b/include/linux/interrupt.h index 1d6711c28271..ca397ff40836 100644 --- a/include/linux/interrupt.h +++ b/include/linux/interrupt.h @@ -247,10 +247,14 @@ struct irq_affinity_notify { * the MSI(-X) vector space * @post_vectors: Don't apply affinity to @post_vectors at end of * the MSI(-X) vector space + * @nr_sets: Length of passed in *sets array + * @sets: Number of affinitized sets */ struct irq_affinity { int pre_vectors; int post_vectors; + int nr_sets; + int *sets; }; #if defined(CONFIG_SMP) 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; + } /* * 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); } -- 2.17.1