Re: [SUGGESTION]: drop virtual merge accounting in I/O requests

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 10 Jul 2008 17:56:08 -0400 (EDT)
Mikulas Patocka <mpatocka@xxxxxxxxxx> wrote:

> When I thought about it more, I realized that this accounting of virtual 
> segments in I/O layer can't work correctly at all. If an architecture 
> defines symbols BIOVEC_VIRT_MERGEABLE and BIOVEC_VIRT_OVERSIZE, it 
> declares that it's IOMMU must merge any two regions satisfying these 
> conditions. But in an IOMMU, it is impossible to guarantee, because:

Yeah, IOMMUs can't guarantee that. The majority of architectures set
BIO_VMERGE_BOUNDARY to 0 so they don't hit this, I think.


> * the bus address is allocated basiclly randomly, so we can hit 
> dev->dma_parms->segment_boundary_mask any time. This will prevent virtual 
> merging from happenning. I/O layer doesn't know the bus address at the 
> time it merges requests, so it can't predict when this happens.
> 
> * the IOMMU isn't guaranteed to find a continuous space in it's bus 
> address space. If it skips over already mapped regions, it can't perform 
> virtual merging.
> 
> * when creating the mapping, we can hit per-device limit 
> "dev->dma_parms->max_segment_size" --- but the I/O layer checks only 
> against global limit BIOVEC_VIRT_OVERSIZE. (this last issue is fixable, 
> the previous two are not).

I think that the block layer can handle this properly via
q->max_segment_size. We have the same value at two different
places. Yeah, it's not good...


BTW, inia100_template sets sg_tablesize to SG_ALL. If the controller
has at most 32 SG entries per request, we need to fix that.
--
To unsubscribe from this list: send the line "unsubscribe sparclinux" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Development]     [DCCP]     [Linux ARM Development]     [Linux]     [Photo]     [Yosemite Help]     [Linux ARM Kernel]     [Linux SCSI]     [Linux x86_64]     [Linux Hams]

  Powered by Linux