Re: DMA mapping on SCSI device?
From: Luben Tuikov
Date: Tue Jan 29 2008 - 17:24:31 EST
--- On Mon, 1/28/08, Andi Kleen <ak@xxxxxxx> wrote:
> > The ideal solution would be to do mapping against a
> different struct
> > device for each port, so that we could maintain the
> proper DMA mask for
> > each of them at all times. However I'm not sure if
> that's possible.
>
> I cannot imagine why it should be that difficult. The PCI
> subsystem
> could over a pci_clone_device() or similar function. For
> all complicated
> purposes (sysfs etc) the original device could be used, so
> it would
> be hopefully not that difficult.
>
> The alternative would be to add a new family of PCI mapping
> functions that take an explicit mask. Disadvantage would be
> changing
> all architectures, but on the other hand the interface
> could be phase
> in one by one (and nF4 primarily only works on x86 anyways)
>
> I suspect the later would be a little cleaner, although
> they don't
> make much difference.
Yes, I guess, that's certainly doable.
The current PCI abstraction is clean: HW DMA engine(s) implementation
is a property of the PCI function.
Marrying different behaviour of the HW DMA engine of the ASIC
depending on the SCSI end device at the PCI device abstraction doesn't
sound good. (An extreme design is a single DMA engine servicing
the ASIC.)
Although, the effect that Rob wants could be cleanly implemented
at a higher level, pci_map_sg() and such, or fixing
blk_queue_bounce_limit() in x86_64 to that effect.
Luben
--
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/