1. 10 9月, 2016 1 次提交
  2. 25 8月, 2016 4 次提交
  3. 10 8月, 2016 2 次提交
    • T
      libata-scsi: fix MODE SELECT translation for Control mode page · 535fd072
      Tom Yan 提交于
      scsi_done() was called repeatedly and apparently because of that,
      the kernel would call trace when we touch the Control mode page:
      
      Call Trace:
       [<ffffffff812ea0d2>] dump_stack+0x63/0x81
       [<ffffffff81079cfb>] __warn+0xcb/0xf0
       [<ffffffff81079e2d>] warn_slowpath_null+0x1d/0x20
       [<ffffffffa00f51b0>] ata_eh_finish+0xe0/0xf0 [libata]
       [<ffffffffa00fb830>] sata_pmp_error_handler+0x640/0xa50 [libata]
       [<ffffffffa00470ed>] ahci_error_handler+0x1d/0x70 [libahci]
       [<ffffffffa00f55f0>] ata_scsi_port_error_handler+0x430/0x770 [libata]
       [<ffffffffa00eff8d>] ? ata_scsi_cmd_error_handler+0xdd/0x160 [libata]
       [<ffffffffa00f59d7>] ata_scsi_error+0xa7/0xf0 [libata]
       [<ffffffffa00913ba>] scsi_error_handler+0xaa/0x560 [scsi_mod]
       [<ffffffffa0091310>] ? scsi_eh_get_sense+0x180/0x180 [scsi_mod]
       [<ffffffff81098eb8>] kthread+0xd8/0xf0
       [<ffffffff815d913f>] ret_from_fork+0x1f/0x40
       [<ffffffff81098de0>] ? kthread_worker_fn+0x170/0x170
      ---[ end trace 8b7501047e928a17 ]---
      
      Removed the unnecessary code and let ata_scsi_translate() do the job.
      
      Also, since ata_mselect_control() has no ATA command to send to the
      device, ata_scsi_mode_select_xlat() should return 1 for it, so that
      ata_scsi_translate() will finish early to avoid ata_qc_issue().
      Signed-off-by: NTom Yan <tom.ty89@gmail.com>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      535fd072
    • T
      libata-scsi: use u8 array to store mode page copy · d7372cb6
      Tom Yan 提交于
      ata_mselect_*() would initialize a char array for storing a copy of
      the current mode page. However, char could be signed char. In that
      case, bytes larger than 127 would be converted to negative number.
      
      For example, 0xff from def_control_mpage[] would become -1. This
      prevented ata_mselect_control() from working at all, since when it
      did the read-only bits check, there would always be a mismatch.
      Signed-off-by: NTom Yan <tom.ty89@gmail.com>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      d7372cb6
  4. 20 7月, 2016 1 次提交
    • T
      libata-scsi: better style in ata_msense_*() · 737bee93
      Tom Yan 提交于
      `changeable` is the "version" of mode page requested by the user.
      It will be less confusing/misleading if we do not check it
      "together" with the setting bits of the drive.
      
      Not to mention that we currently have ata_mselect_*() implemented
      in a way that each of them will serve exclusively a particular bit
      on each page. The old style will hence make the condition look even
      more unnecessarily arcane if the ata_msense_*() is reflecting more
      than one bit.
      Signed-off-by: NTom Yan <tom.ty89@gmail.com>
      Signed-off-by: NTejun Heo <tj@kernel.org>
      737bee93
  5. 15 7月, 2016 4 次提交
  6. 14 7月, 2016 1 次提交
  7. 13 7月, 2016 4 次提交
  8. 12 7月, 2016 3 次提交
  9. 07 7月, 2016 2 次提交
  10. 08 6月, 2016 1 次提交
  11. 10 5月, 2016 7 次提交
  12. 14 4月, 2016 1 次提交
  13. 05 4月, 2016 9 次提交