Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759438AbYGQN2o (ORCPT ); Thu, 17 Jul 2008 09:28:44 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1756331AbYGQN2f (ORCPT ); Thu, 17 Jul 2008 09:28:35 -0400 Received: from gw-colo-pa.panasas.com ([66.238.117.130]:14773 "EHLO natasha.panasas.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1755492AbYGQN2e (ORCPT ); Thu, 17 Jul 2008 09:28:34 -0400 Message-ID: <487F48B7.3010807@panasas.com> Date: Thu, 17 Jul 2008 16:27:19 +0300 From: Boaz Harrosh User-Agent: Thunderbird 2.0.0.14 (X11/20080501) MIME-Version: 1.0 To: FUJITA Tomonori CC: mpatocka@redhat.com, jens.axboe@oracle.com, linux-kernel@vger.kernel.org, linux-scsi@vger.kernel.org, davem@davemloft.net, linux-parisc@vger.kernel.org Subject: Re: [PATCH] block: fix q->max_segment_size checking in blk_recalc_rq_segments about VMERGE References: <20080717131444K.fujita.tomonori@lab.ntt.co.jp> <20080717221908D.fujita.tomonori@lab.ntt.co.jp> In-Reply-To: <20080717221908D.fujita.tomonori@lab.ntt.co.jp> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-OriginalArrivalTime: 17 Jul 2008 13:26:49.0889 (UTC) FILETIME=[C4CC1910:01C8E810] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2268 Lines: 56 FUJITA Tomonori wrote: > On Thu, 17 Jul 2008 07:50:24 -0400 (EDT) > Mikulas Patocka wrote: > >>>>> Please give me an example how the boundary restriction of a device can >>>>> break the VMERGE accounting and an IOMMU if you aren't still sure. >>>> You have dma_get_seg_boundary and dma_get_max_seg_size. On sparc64, adding >>>> one of these broken VMERGE accounting (the VMERGE didn't happen past 64-kb >>>> boundary and bio layer thought that VMERGE would be possible). >>> If the device has 64KB boundary restriction, the device also has >>> max_seg_size restriction of 64KB or under. So the vmerge acounting >>> works (though we need to fix it to handle max_seg_size, as discussed). >>> >>>> And if you fix this case, someone will break it again, sooner or later, by >>>> adding new restriction. >>> All restrictions that IOMMUs need to know are dma_get_seg_boundary and >>> dma_get_max_seg_size. >>> >>> What is your new restriction? >> We don't know what happens in the future. > > It's very unlikely to add new restrictions. > > >> And that is the problem that we >> don't know --- but we have two pieces of code (blk-merge and iommu) that >> try to calculate the same number (number of hw segments) and if they get >> different result, it will crash. If the calculations were done at one >> place, there would be no problem with that. > > I don't think that your argument, 'the problem that we don't know', is > true. > > With the vmerge accounting, we calculate at two places. So if we add > a new restriction, we need to handle it at two places. It's a logical > result. > > Of course, it's easier to calculate at one place rather than two > places. But 'we don't know what restriction we will need' isn't a > problem. > > > BTW, as I've already said, I'm not against removing the vmerge > accounting from the block layer. I have a question. Does the block layer know of the IOMMU in use for the device? can it call into the IOMMU to calculate the restriction? Thanks Boaz -- 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/