(unknown charset) bus dma: a flag/quirk for page zero

From: (unknown charset) Andriy Gapon <avg_at_FreeBSD.org>
Date: Tue, 10 Jan 2012 22:18:28 +0200
Some hardware interfaces may reserve a special meaning for a (physical) memory
address value of zero.  One example is the OHCI specification where a zero value
in CurrentBufferPointer doesn't mean a physical address, but has a reserved
meaning.  To be honest I don't have another example :) but don't preclude its
existence.

To deal with this peculiarity we could use a special flag/quirk that would
instruct the bus dma code to never use the page zero for communication with the
hardware.
Here's a proof of concept patch that implements the idea:
http://people.freebsd.org/~avg/usb-dma-pagezero.diff

Some concerns:
- not sure if BUS_DMA_NO_PAGEZERO is the best name for the flag
- the patch implements the flag only for x86 at the moment
- usb code uses the flag regardless of the actual controller type

What do you think?

-- 
Andriy Gapon
Received on Tue Jan 10 2012 - 19:18:33 UTC

This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:40:23 UTC