From mboxrd@z Thu Jan 1 00:00:00 1970 From: agordeev@redhat.com (Alexander Gordeev) Date: Mon, 4 Jul 2016 10:15:41 +0200 Subject: [PATCH 11/13] blk-mq: allow the driver to pass in an affinity mask In-Reply-To: <1465934346-20648-12-git-send-email-hch@lst.de> References: <1465934346-20648-1-git-send-email-hch@lst.de> <1465934346-20648-12-git-send-email-hch@lst.de> Message-ID: <20160704081540.GA2783@agordeev.lab.eng.brq.redhat.com> On Tue, Jun 14, 2016@09:59:04PM +0200, Christoph Hellwig wrote: > +static int blk_mq_create_mq_map(struct blk_mq_tag_set *set, > + const struct cpumask *affinity_mask) > +{ > + int queue = -1, cpu = 0; > + > + set->mq_map = kzalloc_node(sizeof(*set->mq_map) * nr_cpu_ids, > + GFP_KERNEL, set->numa_node); > + if (!set->mq_map) > + return -ENOMEM; > + > + if (!affinity_mask) > + return 0; /* map all cpus to queue 0 */ > + > + /* If cpus are offline, map them to first hctx */ > + for_each_online_cpu(cpu) { > + if (cpumask_test_cpu(cpu, affinity_mask)) > + queue++; CPUs missing in an affinity mask are mapped to hctxs. Is that intended? > + if (queue > 0) Why this check? > + set->mq_map[cpu] = queue; > + } > + > + return 0; > +} > +