Thread (3 messages) 3 messages, 3 authors, 2011-03-14

RE: [PATCH][v3] driver/FSL SATA:Fix wrong Device Error Register usage

From: Kushwaha Prabhakar-B32579 <hidden>
Date: 2011-03-14 10:34:04
Also in: linux-ide

Hi Jeff,

I am not finding any new comments on this.

Could you please ACK this patch so that it can be applied on external list.=
=20

--Prabhakar

quoted hunk ↗ jump to hunk
-----Original Message-----
From: Kushwaha Prabhakar-B32579
Sent: Wednesday, March 09, 2011 12:47 PM
To: linux-ide@vger.kernel.org
Cc: linuxppc-dev@lists.ozlabs.org; jgarzik@pobox.com;
meet2prabhu@gmail.com; Kushwaha Prabhakar-B32579; Kalra Ashish-B00888
Subject: [PATCH][v3] driver/FSL SATA:Fix wrong Device Error Register
usage
=20
When a single device error is detected, the device under the error is
indicated by the error bit set in the DER. There is a one to one mapping
between register bit and devices on Port multiplier(PMP) i.e. bit 0
represents PMP device 0 and bit 1 represents PMP device 1 etc.
=20
Current implementation treats Device error register value as device
number not set of bits representing multiple device on PMP. It is changed
to consider bit level.
No need to check for each set bit as all command is going to be aborted.
=20
Signed-off-by: Ashish Kalra <redacted>
Signed-off-by: Prabhakar Kushwaha <redacted>
---
=20
 git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
(branch master)
=20
 This patch is already gone through review of linuxppc-dev mail list.
 Making CC linuxppc-dev@lists.ozlabs.org
=20
 Changes for v2: Incorporated Sergei Shtylyov's comment
	- Put space after -
	- added a line
 Changes for v3: Incorporated David Laight's comment
 	- Condition check for dereg 0 for hardware error
=20
 drivers/ata/sata_fsl.c |    7 +++++--
 1 files changed, 5 insertions(+), 2 deletions(-)
=20
diff --git a/drivers/ata/sata_fsl.c b/drivers/ata/sata_fsl.c index
b0214d0..ad84ddc 100644
--- a/drivers/ata/sata_fsl.c
+++ b/drivers/ata/sata_fsl.c
@@ -1040,12 +1040,15 @@ static void sata_fsl_error_intr(struct ata_port
*ap)
=20
 		/* find out the offending link and qc */
 		if (ap->nr_pmp_links) {
+			unsigned int dev_num;
+
 			dereg =3D ioread32(hcr_base + DE);
 			iowrite32(dereg, hcr_base + DE);
 			iowrite32(cereg, hcr_base + CE);
=20
-			if (dereg < ap->nr_pmp_links) {
-				link =3D &ap->pmp_link[dereg];
+			dev_num =3D ffs(dereg) - 1;
+			if (dev_num < ap->nr_pmp_links && dereg !=3D 0) {
+				link =3D &ap->pmp_link[dev_num];
 				ehi =3D &link->eh_info;
 				qc =3D ata_qc_from_tag(ap, link->active_tag);
 				/*
--
1.7.3
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help