1. 08 3月, 2017 1 次提交
    • S
      scsi: storvsc: Workaround for virtual DVD SCSI version · f1c635b4
      Stephen Hemminger 提交于
      Hyper-V host emulation of SCSI for virtual DVD device reports SCSI
      version 0 (UNKNOWN) but is still capable of supporting REPORTLUN.
      
      Without this patch, a GEN2 Linux guest on Hyper-V will not boot 4.11
      successfully with virtual DVD ROM device. What happens is that the SCSI
      scan process falls back to doing sequential probing by INQUIRY.  But the
      storvsc driver has a previous workaround that masks/blocks all errors
      reports from INQUIRY (or MODE_SENSE) commands.  This workaround causes
      the scan to then populate a full set of bogus LUN's on the target and
      then sends kernel spinning off into a death spiral doing block reads on
      the non-existent LUNs.
      
      By setting the correct blacklist flags, the target with the DVD device
      is scanned with REPORTLUN and that works correctly.
      
      Patch needs to go in current 4.11, it is safe but not necessary in older
      kernels.
      Signed-off-by: NStephen Hemminger <sthemmin@microsoft.com>
      Reviewed-by: NK. Y. Srinivasan <kys@microsoft.com>
      Reviewed-by: NChristoph Hellwig <hch@lst.de>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      f1c635b4
  2. 07 3月, 2017 27 次提交
  3. 02 3月, 2017 3 次提交
    • B
      scsi: mpt3sas: Avoid sleeping in interrupt context · 8893cf6c
      Bart Van Assche 提交于
      Commit 669f0441 ("scsi: srp_transport: Move queuecommand() wait code
      to SCSI core") can make scsi_internal_device_block() sleep.  However,
      the mpt3sas driver can call this function from an interrupt
      handler. Hence add a second argument to scsi_internal_device_block()
      that restores the old behavior of this function for the mpt3sas handler.
      
      The call chain that triggered an "IRQ handler enabled interrupts"
      complaint is as follows:
      
      _base_interrupt()
      -> _base_async_event()
         -> mpt3sas_scsih_event_callback()
            -> _scsih_check_topo_delete_events()
               -> _scsih_block_io_to_children_attached_directly()
                  -> _scsih_block_io_device()
                     -> _scsih_internal_device_block()
                        -> scsi_internal_device_block()
      Reported-by: NOmar Sandoval <osandov@osandov.com>
      Signed-off-by: NBart Van Assche <bart.vanassche@sandisk.com>
      Cc: Omar Sandoval <osandov@osandov.com>
      Cc: Hannes Reinecke <hare@suse.com>
      Cc: Sagi Grimberg <sagi@grimberg.me>
      Cc: Christoph Hellwig <hch@lst.de>
      Cc: Sathya Prakash <sathya.prakash@broadcom.com>
      Cc: Chaitra P B <chaitra.basappa@broadcom.com>
      Cc: Suganath Prabu Subramani <suganath-prabu.subramani@broadcom.com>
      Cc: Sreekanth Reddy <Sreekanth.Reddy@broadcom.com>
      Cc: <stable@vger.kernel.org> # v4.10+
      Tested-by: NOmar Sandoval <osandov@fb.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      8893cf6c
    • D
      scsi: sd: Check for unaligned partial completion · c46f0917
      Damien Le Moal 提交于
      Commit <f2e767bb> ("mpt3sas: Force request partial completion
      alignment") was not considering the case of commands not operating on
      logical block size units (e.g. REQ_OP_ZONE_REPORT and its 64B aligned
      partial replies). In this case, forcing alignment of resid to the device
      logical block size can break the command result, e.g. in the case of
      REQ_OP_ZONE_REPORT, the exact number of zone reported by the device.
      
      Move the partial completion alignement check of mpt3sas to a generic
      implementation in sd_done(). The check is added within the default
      section of the initial req_op() switch case so that the report and reset
      zone commands are ignored. In addition, as sd_done() is not called for
      passthrough requests, resid corrections are not done as intended by the
      initial mpt3sas patch.
      
      Fixes: f2e767bb ("mpt3sas: Force request partial completion alignment")
      Cc: <stable@vger.kernel.org> # v4.10
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Acked-by: NChristoph Hellwig <hch@lst.de>
      Reviewed-by: NBart Van Assche <bart.vanassche@sandisk.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      c46f0917
    • P
      scsi: ufs: Factor out ufshcd_read_desc_param · a4b0e8a4
      Potomski, MichalX 提交于
      Since in UFS 2.1 specification some of the descriptor lengths differs
      from 2.0 specification and some devices, which are reporting spec
      version 2.0 have different descriptor lengths we can not rely on
      hardcoded values taken from 2.0 specification. This patch introduces
      reading these lengths per each device from descriptor headers at probe
      time to ensure their correctness.
      Signed-off-by: NMichal' Potomski <michalx.potomski@intel.com>
      Reviewed-by: NSubhash Jadavani <subhashj@codeaurora.org>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      a4b0e8a4
  4. 01 3月, 2017 2 次提交
  5. 28 2月, 2017 4 次提交
  6. 24 2月, 2017 3 次提交