freebsd with flexible iflib nic queues
Go to file
Paul Saab c61314601b Add support for the HP Modular Smart Array 20 & 500 storage arrays.
Logical volumes on these devices show up as LUNs behind another
controller (also known as proxy controller).  In order to issue
firmware commands for a volume on a proxy controller, they must be
targeted at the address of the proxy controller it is attached to,
not the Host/PCI controller.

A proxy controller is defined as a device listed in the INQUIRY
PHYSICAL LUNS command who's L2 and L3 SCSI addresses are zero.  The
corresponding address returned defines which "bus" the controller
lives on and we use this to create a virtual CAM bus.

A logical volume's addresses first byte defines the logical drive
number.  The second byte defines the bus that it is attached to
which corresponds to the BUS of the proxy controller's found or the
Host/PCI controller.

Change event notification to be handled in its own kernel thread.
This is needed since some events may require the driver to sleep
on some operations and this cannot be done during interrupt context.
With this change, it is now possible to create and destroy logical
volumes from FreeBSD, but it requires a native application to
construct the proper firmware commands which is not publicly
available.

Special thanks to John Cagle @ HP for providing remote access to
all the hardware and beating on the storage engineers at HP to
answer my questions.
2004-04-16 23:00:01 +00:00
bin Document the "return" built-in better: it will exit . (sources) and 2004-04-14 15:58:50 +00:00
contrib Pull up latest mdoc(7) changes: 2004-04-16 07:08:33 +00:00
crypto This commit was generated by cvs2svn to compensate for changes in r127904, 2004-04-05 19:01:57 +00:00
etc Remove bogus checks on the value of ${entropy_file} and hardcode out 2004-04-15 18:23:14 +00:00
games Add an observation by Dijkstra software engineering. 2004-03-22 05:02:01 +00:00
gnu Removed local bits that are now part of the standard mdoc(7) package. 2004-04-16 07:19:13 +00:00
include Parenthesize function names in masking macros for getc() etc. for the 2004-03-20 11:45:52 +00:00
kerberos5 Update version strings for Heimdal: 0.6 -> 0.6.1 2004-04-13 16:41:00 +00:00
lib Bring describtion of a sysctl in line with the source: 2004-04-16 22:53:51 +00:00
libexec Cast the terminating NULL to char * in the execl() call. 2004-04-04 20:53:23 +00:00
release New release note: 2004-04-16 18:38:04 +00:00
rescue Remove dangling raidctl reference 2004-03-16 13:42:23 +00:00
sbin use %zu instead of %zd 2004-04-15 16:12:12 +00:00
secure Turn on the amd64-specific bignum code in openssl. This is actually 2004-04-14 23:26:26 +00:00
share Add support for the HP Modular Smart Array 20 & 500 storage arrays. 2004-04-16 23:00:01 +00:00
sys Add support for the HP Modular Smart Array 20 & 500 storage arrays. 2004-04-16 23:00:01 +00:00
tools Teach the script where libssl actually lives. 2004-04-13 11:06:20 +00:00
usr.bin --help is only supported if you have getopt_long(). 2004-04-16 03:50:04 +00:00
usr.sbin o split a sentence to make it more understandable 2004-04-16 09:31:17 +00:00
COPYRIGHT Update the COPYRIGHT file to include FreeBSD's compilation copyright 2003-12-31 22:35:22 +00:00
installworld_newk Commit the first set of files for changing time_t on freebsd/sparc64 2004-03-03 19:36:20 +00:00
installworld_oldk Commit the first set of files for changing time_t on freebsd/sparc64 2004-03-03 19:36:20 +00:00
MAINTAINERS Adding Vinod Kashyap (vkashyap) as the maintainer for twa. 2004-04-08 01:43:34 +00:00
Makefile Add a kernel-toolchain target which only builds the bits required to build 2004-04-13 13:42:01 +00:00
Makefile.inc1 Move the SNMP MIBs and tree definitions from /usr/share/bsnmp to 2004-04-14 16:06:19 +00:00
README
UPDATING I added preseedrandom yesterday, not last month. 2004-04-16 18:36:52 +00:00
UPDATING.64BTT Add a tip for people who are using database-related ports on a sparc64 2004-03-17 01:59:47 +00:00

This is the top level of the FreeBSD source directory.  This file
was last revised on:
$FreeBSD$

For copyright information, please see the file COPYRIGHT in this
directory (additional copyright information also exists for some
sources in this tree - please see the specific source directories for
more information).

The Makefile in this directory supports a number of targets for
building components (or all) of the FreeBSD source tree, the most
commonly used one being ``world'', which rebuilds and installs
everything in the FreeBSD system from the source tree except the
kernel, the kernel-modules and the contents of /etc.  The
``buildkernel'' and ``installkernel'' targets build and install
the kernel and the modules (see below).  Please see the top of
the Makefile in this directory for more information on the
standard build targets and compile-time flags.

Building a kernel is a somewhat more involved process, documentation
for which can be found at:
   http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html
And in the config(8) man page.
Note: If you want to build and install the kernel with the
``buildkernel'' and ``installkernel'' targets, you might need to build
world before.  More information is available in the handbook.

The sample kernel configuration files reside in the sys/<arch>/conf
sub-directory (assuming that you've installed the kernel sources), the
file named GENERIC being the one used to build your initial installation
kernel.  The file NOTES contains entries and documentation for all possible
devices, not just those commonly used.  It is the successor of the ancient
LINT file, but in contrast to LINT, it is not buildable as a kernel but a
pure reference and documentation file.


Source Roadmap:
---------------
bin		System/user commands.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

games		Amusements.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

sys		Kernel sources.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.


For information on synchronizing your source tree with one or more of
the FreeBSD Project's development branches, please see:

  http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/synching.html