From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 66618FAD3F0 for ; Thu, 23 Apr 2026 03:09:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:MIME-Version:Content-Type: Content-Transfer-Encoding:References:In-Reply-To:Message-ID:Date:Subject:Cc: To:From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=SkpJV0Acr6ivunvsCeqjk4MU1/anTGgNIBbWs0F3/tY=; b=TIBLXky6eo519c3W46xhZAVl1M pJtatJq3NPEo+jnbSRb/yR2nFOWoxH6u6Aoc/Ud+UJKUZ661zNc6Ji5v9TnnuT/FVhK5aYS2bujqC MpdXQEa1+Z4oPYUSD3H91yThm4cuXpiyG0s6ycYnj+IoPKfyfEcqaw63uY9nTIv4jRXVqwnA1CkfF bpz5t8/C+cuTtTu2rAja5UHf7i4e/nwkA61zYuswhV3WECI+EGfWJjhbEe+2eoCMQvSg3lpagxMoA KzrxTR5bFZYeK3bm0GXJG12jpp+9jekq/bdbMzB06OvYYVuSIxiwYGZGKg8A2s5rG3kNxO4R8yzTf IgXxIcYg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98.2 #2 (Red Hat Linux)) id 1wFkQn-0000000AwlU-3ro2; Thu, 23 Apr 2026 03:08:45 +0000 Received: from mail-uksouthazon11021140.outbound.protection.outlook.com ([52.101.95.140] helo=LO2P265CU024.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.98.2 #2 (Red Hat Linux)) id 1wFcgp-0000000AeSN-3nOJ for linux-nvme@lists.infradead.org; Wed, 22 Apr 2026 18:52:49 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=UrHwjqYw813NXe4TF5niui011gLEaw9S+bpo0Pvn/Nuiw8Fe4A9zOrz6cU9E0y3Ub2ubvhdsEd1EHhV9fDO/UfdK0xpzKD+yNC4p6ISfYwPLktLd/fYNHuM1w4D8uIs7kXDTUYgQLme+QKzm+BFsrzoAomdLAidUGOXvhmWKllD7eAMC9V1aeI2Z4nmUtg0SLV5gL1T0R572UGv3MmmY18rS9xYCQYpuY3GrZvCUyVgV+zDHjl8nIUduQqQS8++v2PyNHZWAf1ZTkZrcMxQPrwFxcMCI4wWD+TEfnaBJPpTiSwMSeHa6fvJcSo2+9GnNSBuptoVn7mhvl6LltJ4NKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=SkpJV0Acr6ivunvsCeqjk4MU1/anTGgNIBbWs0F3/tY=; b=rzs+dUIYEtGQk8NHTAgF2mPdiX11GLOQbRyDlCDl5YUcByBy364R9RnO6wqOpbPHCjVYr6Vx6N+FuigiU+R9XtQP7b+OEDxVzOyKh2Aecd3myjR6CaxxBYKwRLRIR1tmNbN0rnJ/iEuGQoBeML9bRj2J9quKvFcbP8+F4/BvKWFd/nXKAjg9JvrT3ihxY9rJl3WCXFfvVDoAL1nx/pzn/BfIwkczU74WQfHiThN+slAiXSKA67iLYrl20zUMTgLPOMgQk84v1ZE5UjEyymS2aPTjh/Ws32PP0o0E2BTFBE5yAEDZHHSIKNi8FQ4mRkkwzqT2QQhej0ShRNy25ORyoA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=atomlin.com; dmarc=pass action=none header.from=atomlin.com; dkim=pass header.d=atomlin.com; arc=none Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=atomlin.com; Received: from CWLP123MB3523.GBRP123.PROD.OUTLOOK.COM (2603:10a6:400:70::10) by LO0P123MB7717.GBRP123.PROD.OUTLOOK.COM (2603:10a6:600:407::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9846.19; Wed, 22 Apr 2026 18:52:41 +0000 Received: from CWLP123MB3523.GBRP123.PROD.OUTLOOK.COM ([fe80::de8e:2e4f:6c6:f3bf]) by CWLP123MB3523.GBRP123.PROD.OUTLOOK.COM ([fe80::de8e:2e4f:6c6:f3bf%2]) with mapi id 15.20.9846.019; Wed, 22 Apr 2026 18:52:41 +0000 From: Aaron Tomlin To: axboe@kernel.dk, kbusch@kernel.org, hch@lst.de, sagi@grimberg.me, mst@redhat.com Cc: atomlin@atomlin.com, aacraid@microsemi.com, James.Bottomley@HansenPartnership.com, martin.petersen@oracle.com, liyihang9@h-partners.com, kashyap.desai@broadcom.com, sumit.saxena@broadcom.com, shivasharan.srikanteshwara@broadcom.com, chandrakanth.patil@broadcom.com, sathya.prakash@broadcom.com, sreekanth.reddy@broadcom.com, suganath-prabu.subramani@broadcom.com, ranjan.kumar@broadcom.com, jinpu.wang@cloud.ionos.com, tglx@kernel.org, mingo@redhat.com, peterz@infradead.org, juri.lelli@redhat.com, vincent.guittot@linaro.org, akpm@linux-foundation.org, maz@kernel.org, ruanjinjie@huawei.com, bigeasy@linutronix.de, yphbchou0911@gmail.com, wagi@kernel.org, frederic@kernel.org, longman@redhat.com, chenridong@huawei.com, hare@suse.de, kch@nvidia.com, ming.lei@redhat.com, tom.leiming@gmail.com, steve@abita.co, sean@ashe.io, chjohnst@gmail.com, neelx@suse.com, mproche@gmail.com, nick.lange@gmail.com, marco.crivellari@suse.com, linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, virtualization@lists.linux.dev, linux-nvme@lists.infradead.org, linux-scsi@vger.kernel.org, megaraidlinux.pdl@broadcom.com, mpi3mr-linuxdrv.pdl@broadcom.com, MPT-FusionLinux.pdl@broadcom.com Subject: [PATCH v12 05/13] blk-mq: add blk_mq_{online|possible}_queue_affinity Date: Wed, 22 Apr 2026 14:52:07 -0400 Message-ID: <20260422185215.100929-6-atomlin@atomlin.com> X-Mailer: git-send-email 2.51.0 In-Reply-To: <20260422185215.100929-1-atomlin@atomlin.com> References: <20260422185215.100929-1-atomlin@atomlin.com> Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: LO4P123CA0585.GBRP123.PROD.OUTLOOK.COM (2603:10a6:600:276::19) To CWLP123MB3523.GBRP123.PROD.OUTLOOK.COM (2603:10a6:400:70::10) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CWLP123MB3523:EE_|LO0P123MB7717:EE_ X-MS-Office365-Filtering-Correlation-Id: a71ccf6d-f41a-4237-3499-08dea0a05510 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|7416014|376014|1800799024|22082099003|56012099003|18002099003; X-Microsoft-Antispam-Message-Info: jikstcdpvatv+ANXVp72Xd68mGNZPiEwLmHOZ+b7hXq7kb30qYXvwY5dXyPAqQr0ce9XJ708/GhpiUET69XWRzlEagYVa6MC2ZFHt1mWlCX38EllQQG3p+HUIxYO4vYf+JxbhJsEAzO29PZXiG7nsV++lSgn+TpCPaO/g1QOY5t8C8dwhShyt/uOjigGv+nB8wGdH+1Yd8GvcGWttgb+wJUCWk4H9p88//HFHeoIXqOs/OEKrqw4ZAZT9Do7lgbcfcbQ+qzh+qGP7EKs+576hpavi8DEkxPtjS/mgTWjK/tekfiE7vefK378VZZIMoyzzT6v3Bhy7rb2fP0jGnoEAdBIp6ZyB+v4CKUWiw/NesR0c3HRXAwtraxTP9u1/lLvjDNd0B/5x8NBRnI5CJnz2ItYbtkc4sx6jkukpBRLwJUqVxYOb6O6CtVTOlPDDJcV+mgf+0eZYJGpeoMoInKtlYgawuC1fJXUepOLldBl0pI4sAj5kohR3J6tHsvZx6/W0W0ICWIlu1ENXOuv3KxcXjci0iXVDJSN5/BWoc6lhkOVHWgdadYOhHz3k6Rf5jzMO13EcWxFrIqaKVi9SrgXiRYzlTP2RyOrYatptMvluI45uRcYcONLLyg231ehTziy+v4AZ2w93nxBG1sZQo3rwqWYVWZQPcJ6Wi53nGJqVcT4lND65pF4Hld6o6HVm9uqxPjiLJr5/EaUmC2ST8DvelumO3ZtBsdRw8qZW3i08U4= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:CWLP123MB3523.GBRP123.PROD.OUTLOOK.COM;PTR:;CAT:NONE;SFS:(13230040)(366016)(7416014)(376014)(1800799024)(22082099003)(56012099003)(18002099003);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?l5cu6pB5ErwSwrUM2uUK+Tf27PT1GyaRtES8WVjh0xZHvngOTTU0RBJu2p5T?= =?us-ascii?Q?QM57q31D+z7/cZP2jO9OWL95GRCcVxGxbL+8GTiMIIc0iNgZFQyWh5+yJho4?= =?us-ascii?Q?MOtXfKA3ae41t5T8nU7TviN+qh5g35l51AUOUKjEKATjFMevmwhPGur7HS93?= =?us-ascii?Q?XG5wXY5aCYqWeZ/RCSOCxUoTWZ1m7z5lRvlwQyn1VCGQx20CpygGyqUIuJjA?= =?us-ascii?Q?yE9YVwn6jQb68NwMITU7sxgaAb+Jbzirm/LXH1TzjzN4q+PS4vOip3Dw9mkn?= =?us-ascii?Q?tq7nu8DBfeel4wnQeIfy8+0939OKjgCdb8Is6E1YAVycbkIi88VdHboSYTqb?= =?us-ascii?Q?1fowB/E3W58W1FPlx09255abNPgNdRye5l2A8ZLiyGCLE+b7tFD3cwYjnHqf?= =?us-ascii?Q?GKrAy0DbilIi++3snzARthekm8yoB4GQoSCUI+c7vZR8Q+B0e+mJVrZ7P0+0?= =?us-ascii?Q?0eGVkoBUH8qh9fdj13qhd85GBT3TGtbjLgon4NFctMFATx4XGN65dR5P34Or?= =?us-ascii?Q?aGUbE+iRYkhYSjz/K6jg5YTrwUHg9SONNyor8jhh4mtZoQ1EJm2NrlVkKXyu?= =?us-ascii?Q?fs4cpYvKtUTOnqfftBbFYgWO/oubERBONLmkGlPj6Iqkit4uq2zr2XygNLUJ?= =?us-ascii?Q?Gury5u/0b4zCpDCFTr5DyNdYSZgPD+Sa0d9dVYWcplhTWOcG9gVmD3G81I1d?= =?us-ascii?Q?62sNh5ag2WfVnEeZN3C89zUljh3QPDV7iYIZIGy2Esaq4BhGUwhmTMic4RsP?= =?us-ascii?Q?pM1Pjlv5ODeXNnbdp0Thn+FKiNXdZkh7KMfw8XCLI/eutl8c4kWHL9IPPbim?= =?us-ascii?Q?D5TGlFeoeoNYMoi3xAVUnw28z3m7ATKCTUYT853npu1RpMq4SxNFOTr3aOS2?= =?us-ascii?Q?Ap4mrOAki0D4So0hfcVbDaerMOVDo8ybZq6S7PAknI9iB0impuqkSWVKqPgk?= =?us-ascii?Q?g/q1lSD3qpgSw7SIqBH7PtTijahmll+fyEtM5x5FZ5G2vHwOsOYvK8kYBjFR?= =?us-ascii?Q?7ib/LcAABxPQjUjwNzMfG2de/kN8CVerJB4ojysJV2FX1j9S4Y4sfJrwiiEQ?= =?us-ascii?Q?DHSh7S3sm5QzSHyzrps5yesFAWo8Rq108Uu5YeOzrVEVzbc196YRlqPsIQvW?= =?us-ascii?Q?XIBye63SQGmETEncRmq1mwpjg3YldcS0qEf15aQN4xMNdFtG4DHbQ9tduJtN?= =?us-ascii?Q?gaFjIhNK9AlWTzq0x/4YmTvMW6cWXpaMbQmfxOab3oWtbfHAcEYr1muQqs+e?= =?us-ascii?Q?8fpN3CzdPXnANx/qn5YQkVvQpeRph4uGVhpslxidU4x8XruqgOONgk0ZvYER?= =?us-ascii?Q?OSCE0DhnaUycopqX1o0V8jd4552FzM1M3Y/n0XLoMXqiXQaLCeP5eii/sWhn?= =?us-ascii?Q?43Mf0yNK/uWAOf55LfEWzUiBD3x1UtJeRnzhKAQH40NQRd9FQMSq0rQpbsun?= =?us-ascii?Q?bVDlozLc7mc1p4fBt101odEarKjQtGUkGja+cDPmbMHy1LglLU1PEaJHoiu/?= =?us-ascii?Q?6JYAnFDUWRPFRtPAcC7VSajkh/n+OjWaAbOoVinpfR/Z7alCTrMFYf5QG4Bc?= =?us-ascii?Q?zog/S6Bz9tzbKxondjiVixJWU4CZf2cp3qaJVvNuUB1cuLKCgT4KBtfbYIbU?= =?us-ascii?Q?yb3UlEmiAKHeNZmMqoDvdO1uBhRBX1IdNQAf+lnCeeCD5SFDCqWdeQjfpaeR?= =?us-ascii?Q?vvKDtLGEjcLRsfQn5tKo5pmk9fnkhv6ePokLWY1rpVLLthShjMOif7XicAOT?= =?us-ascii?Q?wKwbNOfqnw=3D=3D?= X-OriginatorOrg: atomlin.com X-MS-Exchange-CrossTenant-Network-Message-Id: a71ccf6d-f41a-4237-3499-08dea0a05510 X-MS-Exchange-CrossTenant-AuthSource: CWLP123MB3523.GBRP123.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 22 Apr 2026 18:52:41.7957 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: e6a32402-7d7b-4830-9a2b-76945bbbcb57 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 6AtSFH/HwPANJ4nj6mcid0HTtBTRX54zoqZjNwQVAeF/R0MRMhSYYzY9uVvc5I48TvxLTOiu0BIi7CkbNVn/Yg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: LO0P123MB7717 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20260422_115247_944223_18D5B277 X-CRM114-Status: GOOD ( 11.05 ) X-Mailman-Approved-At: Wed, 22 Apr 2026 20:08:43 -0700 X-BeenThere: linux-nvme@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: "Linux-nvme" Errors-To: linux-nvme-bounces+linux-nvme=archiver.kernel.org@lists.infradead.org From: Daniel Wagner Introduce blk_mq_{online|possible}_queue_affinity, which returns the queue-to-CPU mapping constraints defined by the block layer. This allows other subsystems (e.g., IRQ affinity setup) to respect block layer requirements. It is necessary to provide versions for both the online and possible CPU masks because some drivers want to spread their I/O queues only across online CPUs, while others prefer to use all possible CPUs. And the mask used needs to match with the number of queues requested (see blk_num_{online|possible}_queues). Signed-off-by: Daniel Wagner Reviewed-by: Hannes Reinecke Signed-off-by: Aaron Tomlin --- block/blk-mq-cpumap.c | 24 ++++++++++++++++++++++++ include/linux/blk-mq.h | 2 ++ 2 files changed, 26 insertions(+) diff --git a/block/blk-mq-cpumap.c b/block/blk-mq-cpumap.c index 705da074ad6c..8244ecf87835 100644 --- a/block/blk-mq-cpumap.c +++ b/block/blk-mq-cpumap.c @@ -26,6 +26,30 @@ static unsigned int blk_mq_num_queues(const struct cpumask *mask, return min_not_zero(num, max_queues); } +/** + * blk_mq_possible_queue_affinity - Return block layer queue affinity + * + * Returns an affinity mask that represents the queue-to-CPU mapping + * requested by the block layer based on possible CPUs. + */ +const struct cpumask *blk_mq_possible_queue_affinity(void) +{ + return cpu_possible_mask; +} +EXPORT_SYMBOL_GPL(blk_mq_possible_queue_affinity); + +/** + * blk_mq_online_queue_affinity - Return block layer queue affinity + * + * Returns an affinity mask that represents the queue-to-CPU mapping + * requested by the block layer based on online CPUs. + */ +const struct cpumask *blk_mq_online_queue_affinity(void) +{ + return cpu_online_mask; +} +EXPORT_SYMBOL_GPL(blk_mq_online_queue_affinity); + /** * blk_mq_num_possible_queues - Calc nr of queues for multiqueue devices * @max_queues: The maximum number of queues the hardware/driver diff --git a/include/linux/blk-mq.h b/include/linux/blk-mq.h index 18a2388ba581..ebc45557aee8 100644 --- a/include/linux/blk-mq.h +++ b/include/linux/blk-mq.h @@ -969,6 +969,8 @@ int blk_mq_freeze_queue_wait_timeout(struct request_queue *q, void blk_mq_unfreeze_queue_non_owner(struct request_queue *q); void blk_freeze_queue_start_non_owner(struct request_queue *q); +const struct cpumask *blk_mq_possible_queue_affinity(void); +const struct cpumask *blk_mq_online_queue_affinity(void); unsigned int blk_mq_num_possible_queues(unsigned int max_queues); unsigned int blk_mq_num_online_queues(unsigned int max_queues); void blk_mq_map_queues(struct blk_mq_queue_map *qmap); -- 2.51.0