aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi
Commit message (Collapse)AuthorAgeFilesLines
...
| * isci: move stp request info to scic_sds_requestDan Williams2011-07-035-435/+313
| | | | | | | | | | | | | | In preparation for unifying allocation of all request information make stp data available in all requests. Incidentally collapse indentation. Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify port data structuresDan Williams2011-07-0312-113/+67
| | | | | | | | | | | | | | | | | | Make scic_sds_port a member of isci_port and merge their lifetimes which means removing the port table from scic_sds_controller in favor of the one at the isci_host level. Merge ihost->sas_ports into ihost->ports. _ Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify phy data structuresDan Williams2011-07-0310-313/+187
| | | | | | | | | | | | | | | | | | Make scic_sds_phy a member of isci_phy and merge their lifetimes which means removing the phy table from scic_sds_controller in favor of the one at that isci_host level. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: rnc state machine table c99 conversionJacek Danecki2011-07-032-71/+58
| | | | | | | | | | | | | | | | This makes the subsequent patches to delete rnc->state_handler more clear. Signed-off-by: Jacek Danecki <Jacek.Danecki@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: remove scic_sds_port_increment_request_countEdmund Nadolski2011-07-032-7/+1
| | | | | | | | | | | | | | Removes excessive encapsulation function. Signed-off-by: Edmund Nadolski <edmund.nadolski@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: kill scic_controller_get_port_handle functionEdmund Nadolski2011-07-034-78/+25
| | | | | | | | | | | | | | | | This function is just overkill and its usage is inconsistent. Replace with inlined code. Signed-off-by: Edmund Nadolski <edmund.nadolski@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Removing unnecessary functions in request.cDave Jiang2011-07-033-71/+12
| | | | | | | | | | | | | | No need for wrappers, just access sas_task directly. Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify isci_host data structuresArtur Wojcik2011-07-0318-163/+83
| | | | | | | | | | | | | | | | | | Make it explicit that isci_host and scic_sds_controller are one in the same object. Signed-off-by: Artur Wojcik <artur.wojcik@intel.com> [removed ->ihost back pointer] Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: implement I_T_nexus_resetDan Williams2011-07-033-64/+76
| | | | | | | | | | | | | | | | | | | | | | | | | | This is a requirement for 2.6.39's new libata eh. Still some questions about lldd_dev_gone racing against dev->lldd_dev lookups, but we are at least no more broken than mvsas in this regard. We also short-circuit I_T_nexus_reset invocations from the device discovery path (IDEV_EH similar to MVS_DEV_EH) to filter out the resulting domain rediscoveries triggered by the reset. Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: fix ata lockingDan Williams2011-07-031-13/+13
| | | | | | | | | | | | | | | | Upstream commit a29b5dad "libata: fix locking for sas paths" switched libsas ata locking to the ata_host lock. We need to do the same when returning ata tasks from the execute path. Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: removing intel_*.h headersDave Jiang2011-07-0318-676/+17
| | | | | | | | | | Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Using Linux SSP frame headerDave Jiang2011-07-035-68/+22
| | | | | | | | | | | | | | Removing of struct sci_ssp_frame_header and migrate to struct ssp_frame_hdr. Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Remove SCIC_SWAP_DWORD()Dave Jiang2011-07-035-91/+60
| | | | | | | | | | | | | | | | | | | | | | Use Linux native swab32() call instead of SCIC_SWAP_DWORD(). We need to swab() because the hardware munges the data into a "big-endian dword" stream which is byte-swapped from the sas definition regardless of host endian. Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: fixup SAS iaf protocols data structureDave Jiang2011-07-037-138/+59
| | | | | | | | | | | | | | | | | | Moved the actual data structure that's read from the phy register to phy header. Removed the parsing of identify address frame protocol bits as that seemed not necessary and we can use existing information. Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: remove redundant copies of IAFDave Jiang2011-07-035-136/+11
| | | | | | | | | | | | | | | | | | We need to remove the extra copies of identify address frame that's being kept around. We only need the one copy that libsas is using. Signed-off-by: Dave Jiang <dave.jiang@intel.com> [further cleanups] Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Converting smp_response to Linux native smp_respDave Jiang2011-07-033-223/+34
| | | | | | | | | | Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Fixup of smp requestDave Jiang2011-07-035-260/+196
| | | | | | | | | | | | | | | | The struct smp_request data structure has be fixed up for Linux consumption. This probably should go to scsi/sas.h eventually. Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Convert of sci_ssp_response_iu to ssp_response_iuDave Jiang2011-07-036-252/+141
| | | | | | | | | | | | | | | | | | | | | | Converting to Linux native format. However the isci driver does a lot of the calculation based on the max size of this data structure and the Linux data structure only has a pointer to the response data. Thus the sizeof(struct ssp_response_iu) will be incorrect and we need to define the max size. Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Fixup SSP command IU and task IUDave Jiang2011-07-035-285/+74
| | | | | | | | | | | | | | Fixup of SSP command IU and SSP task IU to something that looks like Linux Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: renaming sas_capabilities to scic_phy_capDave Jiang2011-07-033-55/+50
| | | | | | | | | | | | | | | | | | This seems to be a data structure that represents the phy capabilities register from the hardware and has nothing to do with SAS data structs. Moving and fixup Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Collapsing of phy_type data structureDave Jiang2011-07-032-16/+8
| | | | | | | | | | | | | | Collapsing of struct scic_sds_phy phy_type data structure Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Convert SAS identify address frame to Linux Native formatDave Jiang2011-07-036-106/+27
| | | | | | | | | | | | | | Convert struct sci_sas_identify_address_frame to struct sas_identify_frame Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Convert ATA defines to Linux native definesDave Jiang2011-07-0313-1180/+280
| | | | | | | | | | | | | | | | | | | | | | * Removing all intel_sata and intel_ata defines * Removing the usage of SAT_PROTOCOL_*. We can get everything from sas_task * Moved SATA FIS types to local sas.h. These defines will have to go into include/scsi/sas.h eventually. * Added offsets for SATA FIS header in order to grab the values Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Convert SATA fis data structures to Linux nativeDave Jiang2011-07-0312-102/+35
| | | | | | | | | | | | | | | | Converting of sata_fis_reg_d2h to dev_to_host_fis Converting of sata_fis_reg_h2d to host_to_dev_fis Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: remove compile-time (Kconfig) silicon configurationDan Williams2011-07-032-25/+1
| | | | | | | | | | | | | | Pre-production silicon support is deprecated, and will be removed completely in the future. Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Removing unused define SCIC_SDS_4_ENABLEDDave Jiang2011-07-033-15/+0
| | | | | | | | | | Signed-off-by: Dave Jiang <dave.jiang@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: kill scic_sds_remote_device.state_handlersDan Williams2011-07-032-187/+5
| | | | | | | | | | | | | | Remove the now unused state_handler infrastructure for remote_devices. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device frame_handlersDan Williams2011-07-032-177/+89
| | | | | | | | | | | | | | | | Implement all states in scic_sds_remote_device_frame() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device event_handlersDan Williams2011-07-032-160/+82
| | | | | | | | | | | | | | | | Implement all states in scic_sds_remote_device_event() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: kill remote_device resume_handlerDan Williams2011-07-032-32/+0
| | | | | | | | | | | | | | This is unused infrastructure. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device suspend_handlersDan Williams2011-07-032-44/+13
| | | | | | | | | | | | | | | | Implement all states in scic_sds_remote_device_suspend() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: kill remote_device complete_task_handlerDan Williams2011-07-032-159/+0
| | | | | | | | | | | | | | This is unused infrastructure. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device start_task_handlersDan Williams2011-07-032-152/+90
| | | | | | | | | | | | | | | | Implement all states in scic_sds_remote_device_start_task() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: kill remote_device continue_io_handlerDan Williams2011-07-032-28/+0
| | | | | | | | | | | | | | This is unused infrastructure. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device complete_io_handlersDan Williams2011-07-032-89/+85
| | | | | | | | | | | | | | | | Implement all states in scic_sds_remote_device_complete_io() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device start_io_handlersDan Williams2011-07-032-215/+125
| | | | | | | | | | | | | | | | Implement all states in scic_sds_remote_device_start_io() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device reset_complete_handlersDan Williams2011-07-032-43/+12
| | | | | | | | | | | | | | | | Implement all states in scic_remote_device_reset_complete() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device reset_handlersDan Williams2011-07-032-48/+27
| | | | | | | | | | | | | | | | Implement all states in scic_remote_device_reset() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device destruct_handlersDan Williams2011-07-032-55/+17
| | | | | | | | | | | | | | | | Implement all states in scic_remote_device_destruct() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: kill remote_device fail_handlerDan Williams2011-07-032-28/+0
| | | | | | | | | | | | | | This is just unused infrastructure. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device stop_handlersDan Williams2011-07-032-177/+83
| | | | | | | | | | | | | | | | Implement all states in scic_remote_device_stop() and delete the state handlers. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: unify remote_device start_handlersDan Williams2011-07-032-62/+21
| | | | | | | | | | | | | | | | Implement all states in scic_remote_device_start() and delete the state handler. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: fix remote_device start_io regressionsDan Williams2011-07-031-6/+5
| | | | | | | | | | | | | | | | | | | | While reducing indentation commits 7ab92c9e "isci: make a remote_node_context a proper member of a remote_device", 0879e6a6 "isci: merge remote_device substates into a single state machine" broke handling of situations where i/o's successfully started at the port level need to terminated when the remote_node declines to start the i/o. Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: kill scic_remote_device_get_connection_rateDan Williams2011-07-035-32/+3
| | | | | | | | | | | | A function call to dereference a pointer is a tad much. Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: merge remote_device substates into a single state machineDan Williams2011-07-035-1396/+800
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A substate is just a state, so uplevel the smp and stp device substates. Three tricks at work here: 1/ scic_sds_remote_device_ready_state_enter: needs to know the the device type so it can immediately transition to a stp or smp ready substate. 2/ scic_sds_remote_device_ready_state_exit: needs to know the device type. In the ssp case the device is no longer ready, in the stp, and smp case we have simply exited to a ready "substate". 3/ scic_sds_remote_device_resume_complete_handler: The one location where we directly check the current state against SCI_BASE_REMOTE_DEVICE_STATE_READY needed to comprehend the possible ready substates. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Removed sci_object.h from project.Maciej Patelczyk2011-07-035-109/+4
| | | | | | | | | | | | | | | | | | The sci_object.h file was removed. No sci_base_object is now in the code. Reported-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Maciej Patelczyk <maciej.patelczyk@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Removed sci_base_object from scic_sds_request.Maciej Patelczyk2011-07-039-62/+48
| | | | | | | | | | | | | | | | | | The 'struct sci_base_object' was removed from the struct scic_sds_request and was replaced by a pointer to struct isci_request. Signed-off-by: Maciej Patelczyk <maciej.patelczyk@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Removed sci_base_object from scic_sds_remote_node_context.Maciej Patelczyk2011-07-033-31/+9
| | | | | | | | | | | | | | | | The 'struct sci_base_object' was removed from the struct scic_sds_remote_node_context. Signed-off-by: Maciej Patelczyk <maciej.patelczyk@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Removed sci_base_object from scic_sds_remote_device.Maciej Patelczyk2011-07-035-59/+42
| | | | | | | | | | | | | | | | | | The 'struct sci_base_object' was removed from the struct scic_sds_remote_device. Signed-off-by: Maciej Patelczyk <maciej.patelczyk@intel.com> [cleaned up sci_dev_to_idev] Signed-off-by: Dan Williams <dan.j.williams@intel.com>
| * isci: Removed sci_base_object from scic_sds_port.Maciej Patelczyk2011-07-034-44/+29
| | | | | | | | | | | | | | | | | | The 'struct sci_base_object' was removed from the struct scic_sds_port and was replaced by a pointer to struct isci_port. Signed-off-by: Maciej Patelczyk <maciej.patelczyk@intel.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>