Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754707Ab3JVQzr (ORCPT ); Tue, 22 Oct 2013 12:55:47 -0400 Received: from mga01.intel.com ([192.55.52.88]:59397 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754137Ab3JVQzq (ORCPT ); Tue, 22 Oct 2013 12:55:46 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.93,549,1378882800"; d="scan'208";a="420902756" Date: Tue, 22 Oct 2013 10:55:02 -0600 (MDT) From: Keith Busch X-X-Sender: vmware@localhost.localdom To: =?ISO-8859-15?Q?Matias_Bj=F8rling?= cc: Keith Busch , axboe@kernel.dk, willy@linux.intel.com, linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org Subject: Re: [PATCH 3/3] NVMe: Convert to blk-mq In-Reply-To: <526186AE.3080006@bjorling.me> Message-ID: References: <1382102062-22270-1-git-send-email-m@bjorling.me> <1382102062-22270-4-git-send-email-m@bjorling.me> <526186AE.3080006@bjorling.me> User-Agent: Alpine 2.03 (LRH 1266 2009-07-14) MIME-Version: 1.0 Content-Type: MULTIPART/MIXED; BOUNDARY="8323328-399645709-1382460921=:4763" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2244 Lines: 50 This message is in MIME format. The first part should be readable text, while the remaining parts are likely unreadable without MIME-aware tools. --8323328-399645709-1382460921=:4763 Content-Type: TEXT/PLAIN; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 8BIT On Fri, 18 Oct 2013, Matias Bj?rling wrote: > On 10/18/2013 05:13 PM, Keith Busch wrote: >> On Fri, 18 Oct 2013, Matias Bjorling wrote: >>> The nvme driver implements itself as a bio-based driver. This primarily >>> because of high lock congestion for high-performance nvm devices. To >>> remove the congestion within the traditional block layer, a multi-queue >>> block layer is being implemented. >>> - result = nvme_map_bio(nvmeq, iod, bio, dma_dir, psegs); >>> - if (result <= 0) >>> + if (nvme_map_rq(nvmeq, iod, rq, dma_dir)) >>> goto free_cmdid; >>> - length = result; >>> >>> - cmnd->rw.command_id = cmdid; >>> + length = blk_rq_bytes(rq); >>> + >>> + cmnd->rw.command_id = rq->tag; >> >> The command ids have to be unique on a submission queue. Since each >> namespace's blk-mq has its own 'tags' used as command ids here but share >> submission queues, what's stopping the tags for commands sent to namespace >> 1 from clashing with tags for namespace 2? >> >> I think this would work better if one blk-mq was created per device >> rather than namespace. It would fix the tag problem above and save a >> lot of memory potentially wasted on millions of requests allocated that >> can't be used. > > You're right. I didn't see the connection. In v3 I'll push struct > request_queue to nvme_dev and map the queues appropriately. It will also fix > the command id issues. Just anticipating a possible issue with the suggestion. Will this separate the logical block size from the request_queue? Each namespace can have a different format, so the block size and request_queue can't be tied together like it currently is for this to work. --8323328-399645709-1382460921=:4763-- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/