Re: [SUGGESTION]: drop virtual merge accounting in I/O requests
From: FUJITA Tomonori
Date: Mon Jul 14 2008 - 13:46:56 EST
On Sun, 13 Jul 2008 20:20:35 -0700 (PDT)
David Miller <davem@xxxxxxxxxxxxx> wrote:
> From: FUJITA Tomonori <fujita.tomonori@xxxxxxxxxxxxx>
> Date: Mon, 14 Jul 2008 11:19:02 +0900
>
> > Now IOMMUs don't ignore the max_segment_size. We hit this problem.
>
> It seems simply that max_segment_size needs to propagate
> down into the block layer VMERGE code so that it can
> act accordingly.
Yeah, I think so. I'll take care of that.
But I think that even with the fix, SPARC64 IOMMU still hits the
problem.
With the VMERGE accounting enabled,
- an IOMMU must merge segments that the block layer expects the IOMMU
to merge.
- an IOMMU must return an error if it can't merge such segments.
But the current SPARC64 IOMMU code doesn't return an error if it can't
merge such segments (as POWER's IOMMU does, as you know).
dma_4u_map_sg() has:
if (segstart != s) {
/* We cannot merge if:
* - allocated dma_addr isn't contiguous to previous allocation
*/
if ((dma_addr != dma_next) ||
(outs->dma_length + s->length > max_seg_size) ||
(is_span_boundary(out_entry, base_shift,
/* Can't merge: create a new segment */
segstart = s;
outcount++;
outs = sg_next(outs);
So if the IOMMU allocated dma_addr isn't contiguous to previous
allocation, it might not merge segments that the block layer expected
the IOMMU to merge.
We need kinda two phase merging code such as the old SPARC64 IOMMU
code and PARISC IOMMUs though I like the new simple SPARC64 IOMMU
code.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/