1. 02 7月, 2017 7 次提交
    • M
      scsi: cxlflash: Update debug prints in reset handlers · 5a4d9d77
      Matthew R. Ochs 提交于
      The device and host reset handler contain debug prints to help identify
      the entities being reset. Today these reset handlers are based on a SCSI
      EH design that uses a SCSI command reference as a means of identifying
      the target entity. As such, the debug trace includes the SCSI command
      pointer and associated CDB. This is not necessary as the SCSI command is
      simply the messenger in these scenarios.
      
      Refactor the debug prints in the host and reset handlers to only present
      information that is applicable given the function scope.
      Signed-off-by: NMatthew R. Ochs <mrochs@linux.vnet.ibm.com>
      Reviewed-by: NHannes Reinecke <hare@suse.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      5a4d9d77
    • M
      scsi: cxlflash: Update send_tmf() parameters · 32abbeda
      Matthew R. Ochs 提交于
      The current send_tmf() implementation is based on the caller providing a
      SCSI command reference. In reality all that is needed is a SCSI device
      reference as the routine uses a private command.
      
      Refactor send_tmf() to pass the private adapter configuration reference
      and a SCSI device reference. As a nice side effect, this will ease the
      burden of converting caller routines to be based solely off of a SCSI
      device reference.
      Signed-off-by: NMatthew R. Ochs <mrochs@linux.vnet.ibm.com>
      Reviewed-by: NHannes Reinecke <hare@suse.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      32abbeda
    • M
      scsi: cxlflash: Avoid double free of character device · acfeb23b
      Matthew R. Ochs 提交于
      The device_unregister() service used when cleaning up the character
      device is already responsible for the internal state associated with the
      device upon successful creation. As the cxlflash driver does not obtain
      a second reference to the character device, the explicit call to
      put_device() is not required and can lead to an inconsistent sysfs among
      other issues as the reference is no longer valid after the first
      put_device() is performed.
      
      Remove the unnecessary put_device() to remedy this issue.
      
      Fixes: a834a36b ("scsi: cxlflash: Create character device to provide host management interface")
      Signed-off-by: NMatthew R. Ochs <mrochs@linux.vnet.ibm.com>
      Reviewed-by: NHannes Reinecke <hare@suse.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      acfeb23b
    • E
      scsi: Add STARGET_CREATED_REMOVE state to scsi_target_state · f9279c96
      Ewan D. Milne 提交于
      The addition of the STARGET_REMOVE state had the side effect of
      introducing a race condition that can cause a crash.
      
      scsi_target_reap_ref_release() checks the starget->state to
      see if it still in STARGET_CREATED, and if so, skips calling
      transport_remove_device() and device_del(), because the starget->state
      is only set to STARGET_RUNNING after scsi_target_add() has called
      device_add() and transport_add_device().
      
      However, if an rport loss occurs while a target is being scanned,
      it can happen that scsi_remove_target() will be called while the
      starget is still in the STARGET_CREATED state.  In this case, the
      starget->state will be set to STARGET_REMOVE, and as a result,
      scsi_target_reap_ref_release() will take the wrong path.  The end
      result is a panic:
      
      [ 1255.356653] Oops: 0000 [#1] SMP
      [ 1255.360154] Modules linked in: x86_pkg_temp_thermal kvm_intel kvm irqbypass crc32c_intel ghash_clmulni_i
      [ 1255.393234] CPU: 5 PID: 149 Comm: kworker/u96:4 Tainted: G        W       4.11.0+ #8
      [ 1255.401879] Hardware name: Dell Inc. PowerEdge R320/08VT7V, BIOS 2.0.22 11/19/2013
      [ 1255.410327] Workqueue: scsi_wq_6 fc_scsi_scan_rport [scsi_transport_fc]
      [ 1255.417720] task: ffff88060ca8c8c0 task.stack: ffffc900048a8000
      [ 1255.424331] RIP: 0010:kernfs_find_ns+0x13/0xc0
      [ 1255.429287] RSP: 0018:ffffc900048abbf0 EFLAGS: 00010246
      [ 1255.435123] RAX: 0000000000000000 RBX: 0000000000000000 RCX: 0000000000000000
      [ 1255.443083] RDX: 0000000000000000 RSI: ffffffff8188d659 RDI: 0000000000000000
      [ 1255.451043] RBP: ffffc900048abc10 R08: 0000000000000000 R09: 0000012433fe0025
      [ 1255.459005] R10: 0000000025e5a4b5 R11: 0000000025e5a4b5 R12: ffffffff8188d659
      [ 1255.466972] R13: 0000000000000000 R14: ffff8805f55e5088 R15: 0000000000000000
      [ 1255.474931] FS:  0000000000000000(0000) GS:ffff880616b40000(0000) knlGS:0000000000000000
      [ 1255.483959] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      [ 1255.490370] CR2: 0000000000000068 CR3: 0000000001c09000 CR4: 00000000000406e0
      [ 1255.498332] Call Trace:
      [ 1255.501058]  kernfs_find_and_get_ns+0x31/0x60
      [ 1255.505916]  sysfs_unmerge_group+0x1d/0x60
      [ 1255.510498]  dpm_sysfs_remove+0x22/0x60
      [ 1255.514783]  device_del+0xf4/0x2e0
      [ 1255.518577]  ? device_remove_file+0x19/0x20
      [ 1255.523241]  attribute_container_class_device_del+0x1a/0x20
      [ 1255.529457]  transport_remove_classdev+0x4e/0x60
      [ 1255.534607]  ? transport_add_class_device+0x40/0x40
      [ 1255.540046]  attribute_container_device_trigger+0xb0/0xc0
      [ 1255.546069]  transport_remove_device+0x15/0x20
      [ 1255.551025]  scsi_target_reap_ref_release+0x25/0x40
      [ 1255.556467]  scsi_target_reap+0x2e/0x40
      [ 1255.560744]  __scsi_scan_target+0xaa/0x5b0
      [ 1255.565312]  scsi_scan_target+0xec/0x100
      [ 1255.569689]  fc_scsi_scan_rport+0xb1/0xc0 [scsi_transport_fc]
      [ 1255.576099]  process_one_work+0x14b/0x390
      [ 1255.580569]  worker_thread+0x4b/0x390
      [ 1255.584651]  kthread+0x109/0x140
      [ 1255.588251]  ? rescuer_thread+0x330/0x330
      [ 1255.592730]  ? kthread_park+0x60/0x60
      [ 1255.596815]  ret_from_fork+0x29/0x40
      [ 1255.600801] Code: 24 08 48 83 42 40 01 5b 41 5c 5d c3 66 66 66 2e 0f 1f 84 00 00 00 00 00 66 66 66 66 90
      [ 1255.621876] RIP: kernfs_find_ns+0x13/0xc0 RSP: ffffc900048abbf0
      [ 1255.628479] CR2: 0000000000000068
      [ 1255.632756] ---[ end trace 34a69ba0477d036f ]---
      
      Fix this by adding another scsi_target state STARGET_CREATED_REMOVE
      to distinguish this case.
      
      Fixes: f05795d3 ("scsi: Add intermediate STARGET_REMOVE state to scsi_target_state")
      Reported-by: NDavid Jeffery <djeffery@redhat.com>
      Signed-off-by: NEwan D. Milne <emilne@redhat.com>
      Cc: <stable@vger.kernel.org>
      Reviewed-by: NLaurence Oberman <loberman@redhat.com>
      Tested-by: NLaurence Oberman <loberman@redhat.com>
      Reviewed-by: NJohannes Thumshirn <jthumshirn@suse.de>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      f9279c96
    • M
      scsi: ses: do not add a device to an enclosure if enclosure_add_links() fails. · 62e62ffd
      Maurizio Lombardi 提交于
      The enclosure_add_device() function should fail if it can't create the
      relevant sysfs links.
      
      Cc: <stable@vger.kernel.org>
      Signed-off-by: NMaurizio Lombardi <mlombard@redhat.com>
      Tested-by: NDouglas Miller <dougmill@linux.vnet.ibm.com>
      Acked-by: NJames Bottomley <jejb@linux.vnet.ibm.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      62e62ffd
    • Z
      scsi: ufs: flush eh_work when eh_work scheduled. · 8dc0da79
      Zang Leigang 提交于
      Forget a condition: eh_work scheduled but do not start to work.
      Signed-off-by: NZang Leigang <zangleigang@hisilicon.com>
      Reviewed-by: NSubhash Jadavani <subhashj@codeaurora.org>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      8dc0da79
    • J
      scsi: qla2xxx: Protect access to qpair members with qpair->qp_lock · 578079fa
      Johannes Thumshirn 提交于
      In qla2xx_start_scsi_mq() and qla2xx_dif_start_scsi_mq() we grab the
      qpair->qp_lock but do access members of the qpair before having the lock.
      Re-order the locking sequence to have all read and write access to qpair
      members under the qpair->qp_lock.
      Signed-off-by: NJohannes Thumshirn <jthumshirn@suse.de>
      Acked-by: NHimanshu Madhani <himanshu.madhani@cavium.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      578079fa
  2. 28 6月, 2017 33 次提交