1. 02 3月, 2018 1 次提交
    • J
      ata: do not schedule hot plug if it is a sas host · 6f54120e
      Jason Yan 提交于
      We've got a kernel panic when using sata disk with sas controller:
      
      [115946.152283] Unable to handle kernel NULL pointer dereference at virtual address 000007d8
      [115946.223963] CPU: 0 PID: 22175 Comm: kworker/0:1 Tainted: G   W OEL  4.14.0 #1
      [115946.232925] Workqueue: events ata_scsi_hotplug
      [115946.237938] task: ffff8021ee50b180 task.stack: ffff00000d5d0000
      [115946.244717] PC is at sas_find_dev_by_rphy+0x44/0x114
      [115946.250224] LR is at sas_find_dev_by_rphy+0x3c/0x114
      ......
      [115946.355701] Process kworker/0:1 (pid: 22175, stack limit = 0xffff00000d5d0000)
      [115946.363369] Call trace:
      [115946.456356] [<ffff000008878a9c>] sas_find_dev_by_rphy+0x44/0x114
      [115946.462908] [<ffff000008878b8c>] sas_target_alloc+0x20/0x5c
      [115946.469408] [<ffff00000885a31c>] scsi_alloc_target+0x250/0x308
      [115946.475781] [<ffff00000885ba30>] __scsi_add_device+0xb0/0x154
      [115946.481991] [<ffff0000088b520c>] ata_scsi_scan_host+0x180/0x218
      [115946.488367] [<ffff0000088b53d8>] ata_scsi_hotplug+0xb0/0xcc
      [115946.494801] [<ffff0000080ebd70>] process_one_work+0x144/0x390
      [115946.501115] [<ffff0000080ec100>] worker_thread+0x144/0x418
      [115946.507093] [<ffff0000080f2c98>] kthread+0x10c/0x138
      [115946.512792] [<ffff0000080855dc>] ret_from_fork+0x10/0x18
      
      We found that Ding Xiang has reported a similar bug before:
      https://patchwork.kernel.org/patch/9179817/
      
      And this bug still exists in mainline. Since libsas handles hotplug and
      device adding/removing itself, do not need to schedule ata hot plug task
      here if it is a sas host.
      Signed-off-by: NJason Yan <yanaijie@huawei.com>
      Cc: Ding Xiang <dingxiang@huawei.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: NTejun Heo <tj@kernel.org>
      6f54120e
  2. 03 11月, 2017 1 次提交
  3. 23 10月, 2017 1 次提交
  4. 17 10月, 2017 1 次提交
  5. 19 9月, 2017 1 次提交
    • H
      libata: Add new med_power_with_dipm link_power_management_policy setting · f4ac6476
      Hans de Goede 提交于
      As described by Matthew Garret quite a while back:
      https://mjg59.dreamwidth.org/34868.html
      
      Intel CPUs starting with the Haswell generation need SATA links to power
      down for the "package" part of the CPU to reach low power-states like
      PC7 / P8 which bring a significant power-saving with them.
      
      The default max_performance lpm policy does not allow for these high
      PC states, both the medium_power and min_power policies do allow this.
      
      The min_power policy saves significantly more power, but there are some
      reports of some disks / SSDs not liking min_power leading to system
      crashes and in some cases even data corruption has been reported.
      
      Matthew has found a document documenting the default settings of
      Intel's IRST Windows driver with which most laptops ship:
      https://www-ssl.intel.com/content/dam/doc/reference-guide/sata-devices-implementation-recommendations.pdf
      
      Matthew wrote a patch changing med_power to match those defaults, but
      that never got anywhere as some people where reporting issues with the
      patch-set that patch was a part of.
      
      This commit is another attempt to make the default IRST driver settings
      available under Linux, but instead of changing medium_power and
      potentially introducing regressions, this commit adds a new
      med_power_with_dipm setting which is identical to the existing
      medium_power accept that it enables dipm on top, which makes it match
      the Windows IRST driver settings, which should hopefully be safe to
      use on most devices.
      
      The med_power_with_dipm setting is close to min_power, except that:
      a) It does not use host-initiated slumber mode (ASP not set),
         but it does allow device-initiated slumber
      b) It does not enable DevSlp mode
      
      On my T440s test laptop I get the following power savings when idle:
      medium_power		0.9W
      med_power_with_dipm	1.2W
      min_power		1.2W
      Suggested-by: NMatthew Garrett <mjg59@srcf.ucam.org>
      Cc: Matthew Garrett <mjg59@srcf.ucam.org>
      Signed-off-by: NHans de Goede <hdegoede@redhat.com>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      f4ac6476
  6. 17 8月, 2017 1 次提交
    • P
      drivers/ata: Replace spin_unlock_wait() with lock/unlock pair · a4f08141
      Paul E. McKenney 提交于
      There is no agreed-upon definition of spin_unlock_wait()'s semantics,
      and it appears that all callers could do just as well with a lock/unlock
      pair.  This commit therefore eliminates the spin_unlock_wait() call and
      associated else-clause and hoists the then-clause's lock and unlock out of
      the "if" statement.  This should be safe from a performance perspective
      because according to Tejun there should be few if any drivers that don't
      set their own error handler.
      Signed-off-by: NPaul E. McKenney <paulmck@linux.vnet.ibm.com>
      Acked-by: NTejun Heo <tj@kernel.org>
      Cc: <linux-ide@vger.kernel.org>
      Cc: Will Deacon <will.deacon@arm.com>
      Cc: Peter Zijlstra <peterz@infradead.org>
      Cc: Alan Stern <stern@rowland.harvard.edu>
      Cc: Andrea Parri <parri.andrea@gmail.com>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      a4f08141
  7. 31 7月, 2017 1 次提交
    • J
      libata: fix a couple of doc build warnings · 2f60e1ab
      Jonathan Corbet 提交于
      The kerneldoc comments for a couple of functions in drivers/ata/libata-eh.c
      had fallen behind the current implementation, resulting in these doc build
      warnings:
      
        ./drivers/ata/libata-eh.c:1449: warning: No description found for parameter 'link'
        ./drivers/ata/libata-eh.c:1449: warning: Excess function parameter 'ap' description in 'ata_eh_done'
        ./drivers/ata/libata-eh.c:1590: warning: No description found for parameter 'qc'
        ./drivers/ata/libata-eh.c:1590: warning: Excess function parameter 'dev' description in 'ata_eh_request_sense'
      
      Update the comments and make the warnings go away.
      Signed-off-by: NJonathan Corbet <corbet@lwn.net>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      2f60e1ab
  8. 15 7月, 2017 1 次提交
  9. 06 6月, 2017 1 次提交
  10. 16 5月, 2017 2 次提交
  11. 28 2月, 2017 1 次提交
  12. 07 2月, 2017 1 次提交
  13. 09 1月, 2017 1 次提交
  14. 15 7月, 2016 1 次提交
  15. 14 7月, 2016 2 次提交
  16. 09 6月, 2016 1 次提交
    • W
      scsi: fix race between simultaneous decrements of ->host_failed · 72d8c36e
      Wei Fang 提交于
      sas_ata_strategy_handler() adds the works of the ata error handler to
      system_unbound_wq. This workqueue asynchronously runs work items, so the
      ata error handler will be performed concurrently on different CPUs. In
      this case, ->host_failed will be decreased simultaneously in
      scsi_eh_finish_cmd() on different CPUs, and become abnormal.
      
      It will lead to permanently inequality between ->host_failed and
      ->host_busy, and scsi error handler thread won't start running. IO
      errors after that won't be handled.
      
      Since all scmds must have been handled in the strategy handler, just
      remove the decrement in scsi_eh_finish_cmd() and zero ->host_busy after
      the strategy handler to fix this race.
      
      Fixes: 50824d6c ("[SCSI] libsas: async ata-eh")
      Cc: stable@vger.kernel.org
      Signed-off-by: NWei Fang <fangwei1@huawei.com>
      Reviewed-by: NJames Bottomley <jejb@linux.vnet.ibm.com>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      72d8c36e
  17. 10 5月, 2016 3 次提交
  18. 05 4月, 2016 5 次提交
  19. 07 12月, 2015 1 次提交
  20. 04 8月, 2015 2 次提交
    • T
      Revert "libata: Implement NCQ autosense" · 74a80d67
      Tejun Heo 提交于
      This reverts commit 42b966fb.
      
      As implemented, ACS-4 sense reporting for ATA devices bypasses error
      diagnosis and handling in libata degrading EH behavior significantly.
      Revert the related changes for now.
      Signed-off-by: NTejun Heo <tj@kernel.org>
      Cc: Hannes Reinecke <hare@suse.de>
      Cc: stable@vger.kernel.org #v4.1+
      74a80d67
    • T
      Revert "libata: Implement support for sense data reporting" · 84ded2f8
      Tejun Heo 提交于
      This reverts commit fe7173c2.
      
      As implemented, ACS-4 sense reporting for ATA devices bypasses error
      diagnosis and handling in libata degrading EH behavior significantly.
      Revert the related changes for now.
      
      ATA_ID_COMMAND_SET_3/4 constants are not reverted as they're used by
      later changes.
      Signed-off-by: NTejun Heo <tj@kernel.org>
      Cc: Hannes Reinecke <hare@suse.de>
      Cc: stable@vger.kernel.org #v4.1+
      84ded2f8
  21. 03 8月, 2015 1 次提交
  22. 22 5月, 2015 1 次提交
  23. 05 5月, 2015 1 次提交
  24. 26 4月, 2015 1 次提交
  25. 27 3月, 2015 6 次提交
  26. 21 1月, 2015 1 次提交