mirror of
https://github.com/SCST-project/scst.git
synced 2026-05-17 18:51:27 +00:00
- "RECEIVE DIAGNOSTIC RESULTS" command handling fixed - Obtaining device queue parameters in scst_obtain_device_parameters() changed to handle NOT READY sense - Fixed possible dev_cmd_count underflow - Minor iSCSI-SCST connection closing cleanups and fixes - Semantic of other *_atomic flags changed a bit. Now they are intended only to allow SCST to optimize execution context. The corresponing functions now can *always* be called on atomic context and, if necessary, should manually determine that using scst_cmd_atomic() function and restart using corresponding *_NEED_THREAD_* return value. - scst_cmd_get_tgt_resp_flags() and SCST_TSC_FLAG_STATUS flag made obsolete and replaced by scst_cmd_get_is_send_status(). All in-tree drivers updated accordingly - Cleanup: preprocessing_done_atomic removed, now preprocessing_done() callback always called on thread context - 64-bit cleanups - Documented that iscsi-scst-adm is currently broken and explained why - In user space Makefile's added possibility to specify external linker flags - Minor performance optimizations - Other minor cleanups git-svn-id: http://svn.code.sf.net/p/scst/svn/trunk@350 d57e44dd-8a1f-0410-8b47-8ef2f437770f
Target driver for LSI/MPT XXX cards =================================== Version X.X.X, XX XXX 200X -------------------------- This driver was originally developed by Hu Gang and then is developed by Erik Habbinga <erikhabbinga@inphase-tech.com>. It is on the early stage of development. The current maintainer of this driver is Erik. Please send him all question related to it (CC: scst-devel@lists.sourceforge.net). This driver tested only on Linux kernel versions 2.6.15.x. Building from the Linux kernel tree ----------------------------------- To build from the kernel tree, you should: 1. Link drivers/message/fusion/mpt_scst to $(SCST_DIR)/mpt 2. Patch drivers/message/fusion/Makefile and drivers/message/fusion/Kconfig by diffs from $(SCST_DIR)/mpt/in-tree 3. Correct in drivers/message/fusion/Makefile SCST_INC_DIR variable so it points to correct directory with SCST include files. Building outside the Linux kernel tree -------------------------------------- Edit Makefile, comment there line obj-$(CONFIG_FUSION_SCST) += mpt_scst.o and uncomment line obj-m += mpt_scst.o Notes on implementation ----------------------- The driver takes the mptstm target driver implemented by LSI and ports it to the SCST architecture. The LSI hardware returns an error when it realizes that command status and sense data cannot be sent in the same transaction. This happens during non-packetized SCSI command handling (not FC or SAS). For SCSI implementations, the driver speculatively caches sense data. If the hardware reports that the sense data could not be sent, the driver will return the cached sense data without involving SCST if the next command is REQUEST SENSE. Cached sense data is discarded on bus reset or if the next command after sense send failure was not REQUEST SENSE. Caching sense data in this fashion probably won't work in a tagged command queuing environment. If SCSI hardware is being used, the driver inspects responses to the INQUIRY command and clears the BQUE and CMDQUE bits in the standard INQUIRY response to disable tagged command queuing.