summaryrefslogtreecommitdiffstats
path: root/sys/dev/ciss/cissreg.h
Commit message (Collapse)AuthorAgeFilesLines
* Work again to fix the interrupt masking problems. We now recognizescottl2008-08-291-13/+10
| | | | | | | that there are 3 different interrupt enable bits, 2 for different families of cards, and 1 for when MSI is used. Also apply a big hammer backstop for cards that aren't recognized. This should fix all of the interrupt issues at boot.
* Correctly set the interrupt enable and disable bits. The previousscottl2008-08-021-11/+11
| | | | | | code interfered with Performant mode and legacy interrupts. Also remove a register read operation on the Simplq code that was effectively a time-wasting no-op.
* A number of significant enhancements to the ciss driver:scottl2008-07-111-0/+36
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1. The FreeBSD driver was setting an interrupt coalesce delay of 1000us for reasons that I can only speculate on. This was hurting everything from lame sequential I/O "benchmarks" to legitimate filesystem metadata operations that relied on serialized barrier writes. One of my filesystem tests went from 35s to complete down to 6s. 2. Implemented the Performant transport method. Without the fix in (1), I saw almost no difference. With it, my filesystem tests showed another 5-10% improvement in speed. It was hard to measure CPU utilization in any meaningful way, so it's not clear if there was a benefit there, though there should have been since the interrupt handler was reduced from 2 or more PCI reads down to 1. 3. Implemented MSI-X. Without any docs on this, I was just taking a guess, and it appears to only work with the Performant method. This could be a programming or understanding mistake on my part. While this by itself made almost no difference to performance since the Performant method already eliminated most of the synchronous reads over the PCI bus, it did allow the CISS hardware to stop sharing its interrupt with the USB hardware, which in turn allowed the driver to become decoupled from the Giant-locked USB driver stack. This increased performance by almost 20%. The MSI-X setup was done with 4 vectors allocated, but only 1 vector used since the performant method was told to only use 1 of 4 queues. Fiddling with this might make it work with the simpleq method, not sure. I did not implement MSI since I have no MSI-specific hardware in my test lab. 4. Improved the locking in the driver, trimmed some data structures. This didn't improve test times in any measurable way, but it does look like it gave a minor improvement to CPU usage when many processes/threads were doing I/O in parallel. Again, this was hard to accurately test.
* There's no reason to check the valence. This allows ciss to workps2005-08-091-2/+0
| | | | on the P600.
* Provide a way to soft reset a proxy controller such as an MSA20 orps2005-04-191-0/+1
| | | | | MSA500. This is useful if you need to reset one of the storage arrays on reboot.
* Clean up structure packing.ps2004-07-291-2/+2
|
* Add SCSI passthrough support to CISS. This allows devices like tape drivesscottl2004-06-211-0/+7
| | | | | | | | | | | that are on a CISS bus to be exported up to CAM and made available as normal devices. This will typically add one or two buses to CAM, which will be numbered starting at 32 to allow room for CISS proxy buses. Also, the CISS firmware usually hides disk devices, but these can also be exposed as 'pass' devices if you set the hw.ciss.expose_hidden_physical tunable. Sponsored by: Tape Laboratories, Inc. MFC After: 3 days
* Document the 64bit version of blocks_to_recover for logical drive status.ps2004-06-051-0/+2
| | | | Pad the struct to 1024 bytes as defined in the firmware spec.
* Update logical drive structureps2004-06-041-3/+5
|
* Define another HOTPLUG event.ps2004-05-281-0/+1
|
* Turn SCSI pre-fetch ON. This is mainly for 64XX and 64X basedps2004-05-171-2/+8
| | | | | | | | controllers and allows the controller to prefetch 1-2k on certain PCI memory reads to the host. The spec says this should only be used for IA32 based systems. Informed of feature by: John Cagle <first.last@hp.com>
* define some new fields in the physical drive structure and pad theps2004-04-221-0/+3
| | | | structure to 512 bytes.
* Add support for the HP Modular Smart Array 20 & 500 storage arrays.ps2004-04-161-0/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 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.
* Whitespace cleanup.ps2004-04-161-16/+16
|
* Correct the READ/WRITE CDB direction definition.ps2003-12-081-2/+2
| | | | Submitted by: John Cagle <john.cagle@hp.com>
* Define RAID 5+1 and RAID ADG fault tolerancesps2003-12-081-0/+2
|
* Properly get the drive geometry from the controller. This shouldps2003-02-051-0/+15
| | | | fix booting off of volumes > 255GB.
* use __packed.alfred2002-09-231-28/+28
|
* Add the 'ciss' driver, which supports the Compaq SmartRAID 5* family ofmsmith2001-11-271-0/+670
RAID controllers (5300, 532, 5i, etc.) Thanks to Compaq and Yahoo! for support during the development of this driver. MFC after: 1 week
OpenPOWER on IntegriCloud