kernel_optimize_test/drivers
Jon Mason fce8a7bb5b PCI-Express Non-Transparent Bridge Support
A PCI-Express non-transparent bridge (NTB) is a point-to-point PCIe bus
connecting 2 systems, providing electrical isolation between the two subsystems.
A non-transparent bridge is functionally similar to a transparent bridge except
that both sides of the bridge have their own independent address domains.  The
host on one side of the bridge will not have the visibility of the complete
memory or I/O space on the other side of the bridge.  To communicate across the
non-transparent bridge, each NTB endpoint has one (or more) apertures exposed to
the local system.  Writes to these apertures are mirrored to memory on the
remote system.  Communications can also occur through the use of doorbell
registers that initiate interrupts to the alternate domain, and scratch-pad
registers accessible from both sides.

The NTB device driver is needed to configure these memory windows, doorbell, and
scratch-pad registers as well as use them in such a way as they can be turned
into a viable communication channel to the remote system.  ntb_hw.[ch]
determines the usage model (NTB to NTB or NTB to Root Port) and abstracts away
the underlying hardware to provide access and a common interface to the doorbell
registers, scratch pads, and memory windows.  These hardware interfaces are
exported so that other, non-mainlined kernel drivers can access these.
ntb_transport.[ch] also uses the exported interfaces in ntb_hw.[ch] to setup a
communication channel(s) and provide a reliable way of transferring data from
one side to the other, which it then exports so that "client" drivers can access
them.  These client drivers are used to provide a standard kernel interface
(i.e., Ethernet device) to NTB, such that Linux can transfer data from one
system to the other in a standard way.

Signed-off-by: Jon Mason <jon.mason@intel.com>
Reviewed-by: Nicholas Bellinger <nab@linux-iscsi.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2013-01-17 19:11:14 -08:00
..
accessibility
acpi
amba
ata
atm
auxdisplay
base
bcma
block
bluetooth
bus
cdrom
char
clk
clocksource
connector
cpufreq
cpuidle
crypto
dca
devfreq
dio
dma
edac
eisa
extcon extcon: arizona: Support direct microphone measurement via HPDET 2013-01-15 15:42:18 +09:00
firewire
firmware
gpio
gpu
hid
hsi
hv Drivers: hv: remove unused variable in vmbus_recvpacket_raw() 2013-01-17 11:46:09 -08:00
hwmon
hwspinlock
i2c
ide
idle
iio
infiniband
input
iommu
ipack ipack/devices/ipoctal: added shutdown callback 2013-01-15 18:24:39 -08:00
irqchip
isdn
leds
lguest
macintosh
md
media
memory
memstick
message
mfd mfd: wm5102: Add microphone clamp control registers 2013-01-15 15:42:18 +09:00
misc VMCI: include slab.h into files using kmalloc/kfree 2013-01-17 12:07:39 -08:00
mmc
mtd
net xen/netfront: improve truesize tracking 2013-01-07 19:51:19 -08:00
nfc
ntb PCI-Express Non-Transparent Bridge Support 2013-01-17 19:11:14 -08:00
nubus
of
oprofile
parisc
parport
pci
pcmcia pcmcia/vrc4171: Add missing spinlock init 2013-01-17 12:07:34 -08:00
pinctrl
platform
pnp
power
pps
ps3
ptp
pwm
rapidio
regulator
remoteproc
rpmsg
rtc
s390
sbus
scsi
sfi
sh
sn
spi
ssb
staging
target
tc
thermal
tty
uio
usb
uwb
vfio
vhost
video
virt
virtio
vlynq
vme
w1 w1_therm: Retries: remove old code add CRC 2013-01-15 23:43:05 -08:00
watchdog
xen
zorro
Kconfig PCI-Express Non-Transparent Bridge Support 2013-01-17 19:11:14 -08:00
Makefile PCI-Express Non-Transparent Bridge Support 2013-01-17 19:11:14 -08:00