DCA: Add Direct Cache Access driver
authorShannon Nelson <shannon.nelson@intel.com>
Tue, 16 Oct 2007 08:27:41 +0000 (01:27 -0700)
committerLinus Torvalds <torvalds@woody.linux-foundation.org>
Tue, 16 Oct 2007 16:43:09 +0000 (09:43 -0700)
commit7589670f37736bcc119ebfbd69aafea6d585d1d4
tree471f90dda6bcbcd59cc857b4f0130922bba88fc4
parent3e037454bcfa4b187e8293d2121bd8c0f5a5c31c
DCA: Add Direct Cache Access driver

Direct Cache Access (DCA) is a method for warming the CPU cache before data
is used, with the intent of lessening the impact of cache misses.  This
patch adds a manager and interface for matching up client requests for DCA
services with devices that offer DCA services.

In order to use DCA, a module must do bus writes with the appropriate tag
bits set to trigger a cache read for a specific CPU.  However, different
CPUs and chipsets can require different sets of tag bits, and the methods
for determining the correct bits may be simple hardcoding or may be a
hardware specific magic incantation.  This interface is a way for DCA
clients to find the correct tag bits for the targeted CPU without needing
to know the specifics.

    [Dave Miller] use DEFINE_SPINLOCK()

Signed-off-by: Shannon Nelson <shannon.nelson@intel.com>
Acked-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
drivers/Kconfig
drivers/Makefile
drivers/dca/Kconfig [new file with mode: 0644]
drivers/dca/Makefile [new file with mode: 0644]
drivers/dca/dca-core.c [new file with mode: 0644]
drivers/dca/dca-sysfs.c [new file with mode: 0644]
include/linux/dca.h [new file with mode: 0644]