提交 a0b9f4bc 编写于 作者: T Tejun Heo 提交者: Jeff Garzik

sata_nv: make hardreset return -EAGAIN on success

sata_nv hardreset can't classify but was left out while unifying
follow-up SRST request mechanism[1].  This caused detection failures
on those controllers.  Fix it.

Reported and bisected by Roland Dreier, Petr Vandrovec and Marc
Dionne.  Thanks guys.

[1] 305d2a1aSigned-off-by: NTejun Heo <htejun@gmail.com>
Cc: Roland Dreier <rdreier@cisco.com>
Cc: Petr Vandrovec <vandrove@vc.cvut.cz>
Cc: Marc Dionne <marc.c.dionne@gmail.com>
Signed-off-by: NJeff Garzik <jgarzik@redhat.com>
上级 15fe982e
...@@ -1591,13 +1591,16 @@ static void nv_mcp55_thaw(struct ata_port *ap) ...@@ -1591,13 +1591,16 @@ static void nv_mcp55_thaw(struct ata_port *ap)
static int nv_hardreset(struct ata_link *link, unsigned int *class, static int nv_hardreset(struct ata_link *link, unsigned int *class,
unsigned long deadline) unsigned long deadline)
{ {
unsigned int dummy; int rc;
/* SATA hardreset fails to retrieve proper device signature on /* SATA hardreset fails to retrieve proper device signature on
* some controllers. Don't classify on hardreset. For more * some controllers. Request follow up SRST. For more info,
* info, see http://bugzilla.kernel.org/show_bug.cgi?id=3352 * see http://bugzilla.kernel.org/show_bug.cgi?id=3352
*/ */
return sata_sff_hardreset(link, &dummy, deadline); rc = sata_sff_hardreset(link, class, deadline);
if (rc)
return rc;
return -EAGAIN;
} }
static void nv_adma_error_handler(struct ata_port *ap) static void nv_adma_error_handler(struct ata_port *ap)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册