sata_promise: don't classify overruns as HSM errors

When sata_promise encounters an overrun or underrun error it
translates that to a libata AC_ERR_HSM, causing a hard reset.
Since over/under-runs were thought to be rare and transient,
this action seemed reasonable.

Unfortunately it turns out that the controller throws overrun
errors when e.g. hal polls a CD or DVD writer containing blank
media, causing long sequences of hard resets and retries before
EH finally gives up.

This patch updates sata_promise to classify over/under-runs as
AC_ERR_OTHER instead. This allows libata EH and upper layers to
retry or fail the operation as they see fit without the disruption
caused by repeated hard resets.

This fixes a problem using a DVD-RAM drive with sata_promise,
reported by Thomas Schorpp. I also tested it on a DVD-RW drive.

Signed-off-by: Mikael Pettersson <mikpe@it.uu.se>
Tested-by: thomas schorpp <thomas.schorpp@googlemail.com>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>

authored by Mikael Pettersson and committed by Jeff Garzik a2342f46 066000dd

+1 -1
+1 -1
drivers/ata/sata_promise.c
··· 862 862 if (port_status & PDC_DRIVE_ERR) 863 863 ac_err_mask |= AC_ERR_DEV; 864 864 if (port_status & (PDC_OVERRUN_ERR | PDC_UNDERRUN_ERR)) 865 - ac_err_mask |= AC_ERR_HSM; 865 + ac_err_mask |= AC_ERR_OTHER; 866 866 if (port_status & (PDC2_ATA_HBA_ERR | PDC2_ATA_DMA_CNT_ERR)) 867 867 ac_err_mask |= AC_ERR_ATA_BUS; 868 868 if (port_status & (PDC_PH_ERR | PDC_SH_ERR | PDC_DH_ERR | PDC2_HTO_ERR