1. 22 Feb, 2023 2 commits
    • Deepak R Varma's avatar
      scsi: ipr: Make ipr_probe_ioa_part2() return void · 3a2d1efa
      Deepak R Varma authored
      Convert function ipr_probe_ioa_part2() to return void instead of int since
      the current implementation always returns 0 to the caller.  The
      transformation also eliminates the dead code when calling
      ipr_probe_ioa_part2() function.  Issue identified using returnvar
      Coccinelle semantic patch.
      
      Link: https://lore.kernel.org/r/Y7rvQyMOGcPKPTv8@ubun2204.myguest.virtualbox.orgSigned-off-by: default avatarDeepak R Varma <drv@mailo.com>
      Acked-by: default avatarBrian King <brking@linux.vnet.ibm.com>
      Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
      3a2d1efa
    • Xingui Yang's avatar
      scsi: sd: Update DIX config every time sd_revalidate_disk() is called · 26a02d97
      Xingui Yang authored
      If a controller has DIX is enabled and an attached disk is formatted using
      a protection type supported by the controller, a block integrity profile is
      registered to enable protected transfers.
      
      If the disk is subsequently reformatted to disable PI, and the controller
      does not support DIX Type 0, this can lead to failures such as this:
      
      [142829.032340] hisi_sas_v3_hw 0000:b4:04.0: erroneous completion iptt=2375 task=00000000bea0970c dev id=5 direct-attached phy4 addr=51c20dbaf642a000 CQ hdr: 0x1023 0x50947 0x0 0x20000 Error info: 0x0 0x0 0x4 0x0
      [142829.073883] sas: Enter sas_scsi_recover_host busy: 1 failed: 1
      [142829.079783] sas: sas_scsi_find_task: aborting task 0x00000000bea0970c
      [142829.102342] sas: Internal abort: task to dev 51c20dbaf642a000 response: 0x0 status 0x5
      [142829.110319] sas: sas_eh_handle_sas_errors: task 0x00000000bea0970c is done
      [142829.117275] sd 7:0:5:0: [sdc] tag#2375 UNKNOWN(0x2003) Result: hostbyte=0x05 driverbyte=DRIVER_OK cmd_age=0s
      [142829.127171] sd 7:0:5:0: [sdc] tag#2375 CDB: opcode=0x2a 2a 00 00 00 00 00 00 00 08 00
      [142829.135059] I/O error, dev sdc, sector 0 op 0x1:(WRITE) flags 0x18800 phys_seg 1 prio class 2
      
      This is because the block layer integrity profile is currently only set up
      the first time a disk is discovered.
      
      To address this, remove the first_scan check when configuring protection
      information during revalidate. Also unregister the block integrity profile
      if DIX is not supported with a given protection type.
      
      [mkp: commit description + printk dedup]
      
      Link: https://lore.kernel.org/r/20230221081026.24736-1-yangxingui@huawei.comSigned-off-by: default avatarXingui Yang <yangxingui@huawei.com>
      Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
      26a02d97
  2. 21 Feb, 2023 11 commits
  3. 09 Feb, 2023 5 commits
  4. 08 Feb, 2023 12 commits
  5. 04 Feb, 2023 1 commit
    • Arnd Bergmann's avatar
      scsi: ufs: qcom: fix platform_msi_domain_free_irqs() reference · 49f262bc
      Arnd Bergmann authored
      The newly added MSI support is mostly hidden inside of an #ifdef,
      except for one line that now causes a build failure when MSI
      is disabled:
      
      drivers/ufs/host/ufs-qcom.c: In function 'ufs_qcom_remove':
      drivers/ufs/host/ufs-qcom.c:1698:9: error: implicit declaration of function 'platform_msi_domain_free_irqs' [-Werror=i]
       1698 |         platform_msi_domain_free_irqs(hba->dev);
            |         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
      
      Above that, the symbol that guards the other call was recently removed, so
      that is all dead code at the moment.
      
      Remove the incorrect #ifdef and instead of a Kconfig dependency to only
      allow building the driver when CONFIG_GENERIC_MSI_IRQ is enabled. This
      symbol is always present when PCI_MSI or ARM_GIC_V3_ITS are enabled, both
      of which should be present on kernels that can run on Qualcomm SoCs.
      
      The 'select RESET_CONTROLLER' in combination with this dependency
      unfortunately causes a dependency loop and this is a user-visible symbol,
      so it's better to change both to 'depends on'.
      
      Link: https://lore.kernel.org/r/20230126211831.2274211-1-arnd@kernel.org
      Fixes: 519b6274 ("scsi: ufs: qcom: Add MCQ ESI config vendor specific ops")
      Fixes: 13e7accb ("genirq: Get rid of GENERIC_MSI_IRQ_DOMAIN")
      Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
      Reviewed-by: default avatarManivannan Sadhasivam <mani@kernel.org>
      Acked-by: default avatarCan Guo <quic_cang@quicinc.com>
      Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
      49f262bc
  6. 24 Jan, 2023 7 commits
  7. 18 Jan, 2023 2 commits