Age | Commit message (Collapse) | Author | |
---|---|---|---|
2007-05-31 | remove the scsi task thread, and replace it with the system workq. | David Gwynne | |
"just :wq and do it" tedu@ | |||
2007-04-03 | modernise scsi_inquiry. the length field has grown and now theres pages to | David Gwynne | |
query. ok krw@ | |||
2007-03-17 | replace the VMWARE quirk that restricts the bus width to 16 targets with | David Gwynne | |
one for all SPI controllers. krw has a sun machine with a 1030 that gets the bus width wrong too, so since vmware emulates that type of hardware too, we can just limit the lot of them and forget about it. | |||
2006-11-28 | give scsi controllers a real attach args to fill in when attaching scsibus. | David Gwynne | |
ok miod@ marco@ deraadt@ | |||
2006-11-28 | unhandled ioctls return ENOTTY, not 0 | David Gwynne | |
2006-11-28 | remove dead code | David Gwynne | |
2006-11-26 | use scsi_detach_target when a device dissapears, rather than using | David Gwynne | |
config_detach and cleaning the midlayer up ourselves. | |||
2006-11-25 | remove a comment which is now untrue after i fixed it | David Gwynne | |
2006-10-22 | oops, the eventnotify stuff was accidentally enabled with the scsiconf | David Gwynne | |
changes. its not ready yet, so disable it again. | |||
2006-10-21 | rework the bus scanning code by splitting it out into separate functions | David Gwynne | |
for walking the bus and targets, and probing the luns. this removes the need to use magic numbers to wildcard each of these, which in turn makes the code a lot easier to read. as a bonus we get some more space to work in (80 chars isnt that much somtimes). note that this code wont probe high luns if lun 0 doesnt exist. ok krw@ | |||
2006-09-22 | add support for hotplugging devices on sas controllers. this is disabled | David Gwynne | |
for now until we deal more appropriately with events generated by other variants of mpi controllers. | |||
2006-09-21 | code for acking event notifications that require acks. | David Gwynne | |
2006-09-21 | deref the right rcb by using i as the index, not 1 all the time. | David Gwynne | |
2006-09-21 | start cleaning up the completion path for event notifications. | David Gwynne | |
2006-09-21 | add a debug flag type thing for event handling | David Gwynne | |
2006-09-21 | wrap the hardware replies up in a structure called mpi_rcb which is | David Gwynne | |
similair to the one used for requests. take the reply bits out of the ccb, but point it at the rcb instead. this lets us defer processing of the reply some time after we reuse or free the ccb. | |||
2006-09-21 | factor the common code out of mpi_intr and mpi_complete. they were | David Gwynne | |
basically identical apart from the conditions they looped on. | |||
2006-09-18 | macros and types for event notifications from the hardware. | David Gwynne | |
2006-09-18 | There's no need to walk the list of devices to find the SCSI bus we | Pedro Martelletto | |
should attach to, since config_found() already returns a pointer to it. Pointed out by Quentin Garnier, okay dlg@. | |||
2006-09-16 | rework the handling of the errors coming off the hardware at the bottom of | David Gwynne | |
mpi_scsi_cmd_done. this makes it more appropriate for our midlayer. ok beck@ deraadt@ | |||
2006-08-24 | dont print debug output when the scsi completion path returns with | David Gwynne | |
something other than SCSI_OK. for example, SCSI_SENSE is returned when the device has sense data. this code was left in to help debug problems in the field, but noones had any problems with mpi apart from it being too chatty when a device returns sense data... | |||
2006-08-03 | always call scsi_done at splbio. issue found by pedro@ | David Gwynne | |
while here protect submission of the scsi command with splbio as well. | |||
2006-07-15 | set the tags on the scsi command according to what the midlayer says they | David Gwynne | |
should be. | |||
2006-07-15 | have a go at configuring spi variants to only talk to the devices at the | David Gwynne | |
lowest possible speeds during inquiry and attach. some devices, like tapes and enclosures, dont like being probed at high speeds and can attach as weird things. this seems to help those devices. | |||
2006-07-09 | spacing | David Gwynne | |
2006-07-09 | enabling interrupts doesnt deserve an XXX. i think we want to do that. | David Gwynne | |
2006-07-09 | implement firmware upload. this frees up memory on some controllers so they | David Gwynne | |
can do more io at a time. tested on the onboard controllers of a dell 2850 (which can do it) and a pci controller on my home box (which doesnt). this was the last feature mpt had that mpi was behind on. | |||
2006-07-06 | fix debugging stuff | David Gwynne | |
2006-07-06 | after walking the attached devices and running ppr against them, then fetch | David Gwynne | |
the ioc page 3 for a list of all the physical disks behind any configured volumes and run ppr against them too. raid volumes on scsi mpi is fast now. | |||
2006-07-06 | do not stash pages 2 and 3 (the volume and physdisk pages respectively) | David Gwynne | |
of the ioc config in the softc. instead, we only walk page 2 when we get the raid config and mark each disks scsi_link structure with the SDEV_LOGICAL flag when we find volumes. while there we mark this instance of the driver as being capable of doing raid so later on we can conditionally hook up bio. when we walk the devices attached to mpi to do ppr, we now skip the logical disks. | |||
2006-07-06 | stash a pointer to the scsibus attached to us so we dont have to walk the | David Gwynne | |
device tree all the time. | |||
2006-07-05 | check if the requests for the config pages were completed successful, | David Gwynne | |
rather than just completed. | |||
2006-06-30 | Unbreak the tree; cast the result of sizeof() to u_int32_t before passing it | Mark Kettenis | |
to htole32(). "go for it" miod@ | |||
2006-06-30 | tabs, not spaces | David Gwynne | |
2006-06-30 | add mpi_inq. this is a custom io function that does an inquiry against | David Gwynne | |
either a normal target, or against a physical disk using the raid passthru command. it is necessary since the normal io path can only be used by the midlayer, and only against normal targets. this will be used for ppr against the disks in raid volumes on scsi controllers. tested by marco@ | |||
2006-06-29 | split some fields up in the spi port and dev config pages. makes the ppr | David Gwynne | |
code easier since we dont have to byteswap and shift stuff around so much. no functional change though. | |||
2006-06-29 | theres a ton of 32bit fields in mpi messages that have subfields that lie | David Gwynne | |
on byte boundaries. so rather than byteswappping and bitshifting the values in these subfields around we can break them up into byte fields and access them directly. this breaks up the control field in the scsi io command. | |||
2006-06-19 | Everytime one forgets an argument in a printf-like function call, God kills | Miod Vallat | |
a kitten. Commiters, please think of the kittens when working on code. | |||
2006-06-18 | Make mpi not spit out WWNN and WWPN as requested by deraadt and dlg. Do | Marco Peereboom | |
store these values in the scsi_link structure for each device. ok dlg. | |||
2006-06-18 | Don't walk memory whenever there is nothing there. I ran into this while | Marco Peereboom | |
debugging FC stuff. | |||
2006-06-18 | Print World Wide Node Name and World Wide Port Name during dmesg so that | Marco Peereboom | |
we can actually find the drives on the fabric. Requested by kettenis krw and brad. ok dlg | |||
2006-06-16 | vmware emulates mpi, but it does a half arsed job of it. half the fields | David Gwynne | |
we read off the hardware and use to configure the driver with are set to zero, so things dont really work like we want them to. one of these fields is the pci subsystem id which is something we can fetch really early in the attach process. so if the subsys is 0 then we go on and fix up some of the values we get off the "hardware". now we can attach disks on vmware. "sneaky" and ok marco@ tested by and ok brad@ | |||
2006-06-15 | Add detection of RAID volume during PPR. Doesn't fan out the ppr to individual | Marco Peereboom | |
devices yet. | |||
2006-06-15 | Add IOC page 3 support. Needed for RAID and bio. | Marco Peereboom | |
2006-06-15 | Print volume details in debug. | Marco Peereboom | |
2006-06-15 | And now without a buffer overflow. Pointed out by dlg. No cookie for me. | Marco Peereboom | |
2006-06-15 | Add structures and initial code to retrieve IOC page 2. We need this for | Marco Peereboom | |
RAID support and bio. "go at it" dlg | |||
2006-06-15 | Print some useful error information during failure. We need this to be able | Marco Peereboom | |
to diagnose field issues. Talked through with dlg. | |||
2006-06-13 | we sometimes bundle chunks that the ioc will write to in the request space | David Gwynne | |
as well as the request itself, so we need to sync the memory in both directions for dma. | |||
2006-06-12 | i stashed the dva and kva of each request space in its ccb, so why am i | David Gwynne | |
recalculating them whenever i want to use them? shorten code a bit by using the stored values. |