Received: by 2002:a05:6a10:c7d3:0:0:0:0 with SMTP id h19csp233064pxy; Sat, 14 Aug 2021 05:38:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJykJ93oKt1sScPwQdeVncpQvV/5QXe9ZnqnhWjkK9437ZwPj9Au0ro7aY5VFyXxNecqoPyT X-Received: by 2002:a92:3610:: with SMTP id d16mr4944849ila.16.1628944707138; Sat, 14 Aug 2021 05:38:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628944707; cv=none; d=google.com; s=arc-20160816; b=N2RE8F2Q3r+aB/pdt7JtEnGT6SbtDoql394SZOhZL+rp4vI1T6enbOSNWw0OP+Nkf5 91P+3xTZTACFZCA7ngHrC+8wFR9vMYXDmtQNnk8uSjQBCnQNoOINEFr2L9eG8GLVy1Cv hg/3PL/jSBwOrs82QOGHep0Usb1YoNQUq4xbWEoyFjAMIXkopf7105uWyPliGcoKkoPx Z/vWdTKGvOWj2cdsMvMjhyuIfnKGTQzYoBLzvzoY5uLAWOiffbR5EK/aI8EsXBcfL0nA yF/e02xE0nhnhGo0j5DWH6V7CzPdRzZ0S9oNe7lYLKmVRwJk1P6kxzHi4AuYnrIHq9lg Vzvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=Zi9rp4A/ofXDkM+2FBhAwSRraea93QLDveGmuBcx8js=; b=vYf2lX1yrGJZ+WNQ6BVQz486wXe4xawv1EMwW/G3SX6RrKvvjCXRXcWJ9DpnGwWsGb 7z8+8/UXsopzYYXSUEzogTl6K26dFut65QMWGYy46QXtOBMO+q3nuuuV6fyNvKkfsGgH Uppi8FrvmjM62QNABy9+DN+uLkNgcU3/Hvc5LaWKnGRMkCPUDDLUtCxmio3sDFeZvDwD RdOoPCilem6PFQ9NqKpAvjzVK4Cr3uzn590j71rv1T6Dh2D8hvG+4KewaETfIK/QzJSK ZwvAsxP+4WNL7p0d6xyHKq8B9K0jIGgsjFxxpFaGuWS+x0PJm/yuHwALE0UD/ctHhk7g quSQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=R9JuWxmG; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g8si4957356jal.26.2021.08.14.05.37.48; Sat, 14 Aug 2021 05:38:27 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=R9JuWxmG; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229549AbhHNMgV (ORCPT + 99 others); Sat, 14 Aug 2021 08:36:21 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:22009 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234030AbhHNMgV (ORCPT ); Sat, 14 Aug 2021 08:36:21 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1628944550; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=Zi9rp4A/ofXDkM+2FBhAwSRraea93QLDveGmuBcx8js=; b=R9JuWxmGhRqMwEn8i3vQgsGVObuc+q58M/CKhzeF0irdFnhO/HQRlV0gCn6dK6Dswaa6za 72r/46I4fdT4pYg4HoUXN9xvNwQGQWNvQCeWXrO9JuSScKkH48nqx8x6CXJzhzOyz9i0Ag h6GR9dx4e0n3GDhYulAqO9BQN2scPtU= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-385-a7BetHQTNHW64izu1qUtqg-1; Sat, 14 Aug 2021 08:35:46 -0400 X-MC-Unique: a7BetHQTNHW64izu1qUtqg-1 Received: from smtp.corp.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 916B894DE1; Sat, 14 Aug 2021 12:35:44 +0000 (UTC) Received: from localhost (ovpn-8-25.pek2.redhat.com [10.72.8.25]) by smtp.corp.redhat.com (Postfix) with ESMTP id CC6B960C9F; Sat, 14 Aug 2021 12:35:38 +0000 (UTC) From: Ming Lei To: Thomas Gleixner , Jens Axboe Cc: linux-kernel@vger.kernel.org, linux-block@vger.kernel.org, Christoph Hellwig , Ming Lei Subject: [PATCH 0/7] genirq/affinity: abstract new API from managed irq affinity spread Date: Sat, 14 Aug 2021 20:35:25 +0800 Message-Id: <20210814123532.229494-1-ming.lei@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.12 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello, irq_build_affinity_masks() actually grouping CPUs evenly into each managed irq vector according to NUMA and CPU locality, and it is reasonable to abstract one generic API for grouping CPUs evenly, the idea is suggested by Thomas Gleixner. group_cpus_evenly() is abstracted and put into lib/, so blk-mq can re-use it to build default queue mapping. Please comments! Since RFC: - remove RFC - rebase on -next tree Ming Lei (7): genirq/affinity: remove the 'firstvec' parameter from irq_build_affinity_masks genirq/affinity: pass affinity managed mask array to irq_build_affinity_masks genirq/affinity: don't pass irq_affinity_desc array to irq_build_affinity_masks genirq/affinity: rename irq_build_affinity_masks as group_cpus_evenly genirq/affinity: move group_cpus_evenly() into lib/ lib/group_cpus: allow to group cpus in case of !CONFIG_SMP blk-mq: build default queue map via group_cpus_evenly() block/blk-mq-cpumap.c | 64 ++---- include/linux/group_cpus.h | 28 +++ kernel/irq/affinity.c | 404 +----------------------------------- lib/Makefile | 2 + lib/group_cpus.c | 413 +++++++++++++++++++++++++++++++++++++ 5 files changed, 465 insertions(+), 446 deletions(-) create mode 100644 include/linux/group_cpus.h create mode 100644 lib/group_cpus.c -- 2.31.1