linux-ide.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 1/4] libata: re-initialize parameters before configuring
  2006-02-15 10:02 [PATCHSET] libata: implement and use ata_dev_revalidate() Tejun Heo
@ 2006-02-15 10:02 ` Tejun Heo
  2006-02-20 10:49   ` Jeff Garzik
  0 siblings, 1 reply; 9+ messages in thread
From: Tejun Heo @ 2006-02-15 10:02 UTC (permalink / raw)
  To: jgarzik, albertcc, linux-ide; +Cc: Tejun Heo

In ata_dev_configure(), reinitialize parameters before configuring.
This change is for revalidation and hotplug.  As ata_dev_configure()
can be entered multiple times, parameters need to be reinitialized.

Signed-off-by: Tejun Heo <htejun@gmail.com>

---

 drivers/scsi/libata-core.c |    9 +++++++++
 1 files changed, 9 insertions(+), 0 deletions(-)

1f2bfa33d83b17398e8207a2fa0926f7454592de
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c
index 8c0d48f..abb08c5 100644
--- a/drivers/scsi/libata-core.c
+++ b/drivers/scsi/libata-core.c
@@ -1082,6 +1082,15 @@ static int ata_dev_configure(struct ata_
 
 	DPRINTK("ENTER, host %u, dev %u\n", ap->id, dev->devno);
 
+	/* initialize to-be-configured parameters */
+	dev->flags = 0;
+	dev->max_sectors = 0;
+	dev->cdb_len = 0;
+	dev->n_sectors = 0;
+	dev->cylinders = 0;
+	dev->heads = 0;
+	dev->sectors = 0;
+
 	/*
 	 * common ATA, ATAPI feature tests
 	 */
-- 
1.1.5



^ permalink raw reply related	[flat|nested] 9+ messages in thread

* Re: [PATCH 1/4] libata: re-initialize parameters before configuring
  2006-02-15 10:02 ` [PATCH 1/4] libata: re-initialize parameters before configuring Tejun Heo
@ 2006-02-20 10:49   ` Jeff Garzik
  0 siblings, 0 replies; 9+ messages in thread
From: Jeff Garzik @ 2006-02-20 10:49 UTC (permalink / raw)
  To: Tejun Heo; +Cc: albertcc, linux-ide

Tejun Heo wrote:
> In ata_dev_configure(), reinitialize parameters before configuring.
> This change is for revalidation and hotplug.  As ata_dev_configure()
> can be entered multiple times, parameters need to be reinitialized.
> 
> Signed-off-by: Tejun Heo <htejun@gmail.com>

ACK



^ permalink raw reply	[flat|nested] 9+ messages in thread

* [PATCH 1/4] libata: re-initialize parameters before configuring
  2006-03-01  8:20 [PATCHSET] libata: implement and use ata_dev_revalidate(), take #2 Tejun Heo
@ 2006-03-01  8:20 ` Tejun Heo
  0 siblings, 0 replies; 9+ messages in thread
From: Tejun Heo @ 2006-03-01  8:20 UTC (permalink / raw)
  To: jgarzik, linux-ide; +Cc: Tejun Heo

In ata_dev_configure(), reinitialize parameters before configuring.
This change is for revalidation and hotplug.  As ata_dev_configure()
can be entered multiple times, parameters need to be reinitialized.

Signed-off-by: Tejun Heo <htejun@gmail.com>

---

 drivers/scsi/libata-core.c |    9 +++++++++
 1 files changed, 9 insertions(+), 0 deletions(-)

ce0cef100691a38180b32a74ce6ab7ca90b390f0
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c
index 63ba1aa..17d113b 100644
--- a/drivers/scsi/libata-core.c
+++ b/drivers/scsi/libata-core.c
@@ -1082,6 +1082,15 @@ static int ata_dev_configure(struct ata_
 
 	DPRINTK("ENTER, host %u, dev %u\n", ap->id, dev->devno);
 
+	/* initialize to-be-configured parameters */
+	dev->flags = 0;
+	dev->max_sectors = 0;
+	dev->cdb_len = 0;
+	dev->n_sectors = 0;
+	dev->cylinders = 0;
+	dev->heads = 0;
+	dev->sectors = 0;
+
 	/*
 	 * common ATA, ATAPI feature tests
 	 */
-- 
1.2.1



^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 1/4] libata: re-initialize parameters before configuring
  2006-03-05  8:55 [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Tejun Heo
@ 2006-03-05  8:55 ` Tejun Heo
  2006-03-05  8:55 ` [PATCH 4/4] libata: revalidate after transfer mode configuration Tejun Heo
                   ` (2 subsequent siblings)
  3 siblings, 0 replies; 9+ messages in thread
From: Tejun Heo @ 2006-03-05  8:55 UTC (permalink / raw)
  To: jgarzik, linux-ide; +Cc: Tejun Heo

In ata_dev_configure(), reinitialize parameters before configuring.
This change is for revalidation and hotplug.  As ata_dev_configure()
can be entered multiple times, parameters need to be reinitialized.

Signed-off-by: Tejun Heo <htejun@gmail.com>

---

 drivers/scsi/libata-core.c |    9 +++++++++
 1 files changed, 9 insertions(+), 0 deletions(-)

1c25bf6bd9a1176c2510d27868e475e2c0a801ff
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c
index b710fc4..5982849 100644
--- a/drivers/scsi/libata-core.c
+++ b/drivers/scsi/libata-core.c
@@ -1086,6 +1086,15 @@ static int ata_dev_configure(struct ata_
 
 	DPRINTK("ENTER, host %u, dev %u\n", ap->id, dev->devno);
 
+	/* initialize to-be-configured parameters */
+	dev->flags = 0;
+	dev->max_sectors = 0;
+	dev->cdb_len = 0;
+	dev->n_sectors = 0;
+	dev->cylinders = 0;
+	dev->heads = 0;
+	dev->sectors = 0;
+
 	/*
 	 * common ATA, ATAPI feature tests
 	 */
-- 
1.2.1



^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 3/4] libata: implement ata_dev_revalidate()
  2006-03-05  8:55 [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Tejun Heo
  2006-03-05  8:55 ` [PATCH 1/4] libata: re-initialize parameters before configuring Tejun Heo
  2006-03-05  8:55 ` [PATCH 4/4] libata: revalidate after transfer mode configuration Tejun Heo
@ 2006-03-05  8:55 ` Tejun Heo
  2006-03-05 16:10 ` [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Jeff Garzik
  3 siblings, 0 replies; 9+ messages in thread
From: Tejun Heo @ 2006-03-05  8:55 UTC (permalink / raw)
  To: jgarzik, linux-ide; +Cc: Tejun Heo

ata_dev_revalidate() re-reads IDENTIFY PAGE of the given device and
makes sure it's the same device as the configured one.  Once it's
verified that it's the same device, @dev is configured according to
newly read IDENTIFY PAGE.  Note that revalidation currently doesn't
invoke transfer mode reconfiguration.

Criteria for 'same device'

* same class (of course)
* same model string
* same serial string
* if ATA, same n_sectors (to catch geometry parameter changes)

Signed-off-by: Tejun Heo <htejun@gmail.com>

---

 drivers/scsi/libata-core.c |  115 ++++++++++++++++++++++++++++++++++++++++++++
 include/linux/libata.h     |    2 +
 2 files changed, 117 insertions(+), 0 deletions(-)

291782c65f9b708317c75869df3cbe58c36cb2b2
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c
index d65aa86..5d0adfa 100644
--- a/drivers/scsi/libata-core.c
+++ b/drivers/scsi/libata-core.c
@@ -2345,6 +2345,120 @@ int ata_drive_probe_reset(struct ata_por
 	return rc;
 }
 
+/**
+ *	ata_dev_same_device - Determine whether new ID matches configured device
+ *	@ap: port on which the device to compare against resides
+ *	@dev: device to compare against
+ *	@new_class: class of the new device
+ *	@new_id: IDENTIFY page of the new device
+ *
+ *	Compare @new_class and @new_id against @dev and determine
+ *	whether @dev is the device indicated by @new_class and
+ *	@new_id.
+ *
+ *	LOCKING:
+ *	None.
+ *
+ *	RETURNS:
+ *	1 if @dev matches @new_class and @new_id, 0 otherwise.
+ */
+static int ata_dev_same_device(struct ata_port *ap, struct ata_device *dev,
+			       unsigned int new_class, const u16 *new_id)
+{
+	const u16 *old_id = dev->id;
+	unsigned char model[2][41], serial[2][21];
+	u64 new_n_sectors;
+
+	if (dev->class != new_class) {
+		printk(KERN_INFO
+		       "ata%u: dev %u class mismatch %d != %d\n",
+		       ap->id, dev->devno, dev->class, new_class);
+		return 0;
+	}
+
+	ata_id_c_string(old_id, model[0], ATA_ID_PROD_OFS, sizeof(model[0]));
+	ata_id_c_string(new_id, model[1], ATA_ID_PROD_OFS, sizeof(model[1]));
+	ata_id_c_string(old_id, serial[0], ATA_ID_SERNO_OFS, sizeof(serial[0]));
+	ata_id_c_string(new_id, serial[1], ATA_ID_SERNO_OFS, sizeof(serial[1]));
+	new_n_sectors = ata_id_n_sectors(new_id);
+
+	if (strcmp(model[0], model[1])) {
+		printk(KERN_INFO
+		       "ata%u: dev %u model number mismatch '%s' != '%s'\n",
+		       ap->id, dev->devno, model[0], model[1]);
+		return 0;
+	}
+
+	if (strcmp(serial[0], serial[1])) {
+		printk(KERN_INFO
+		       "ata%u: dev %u serial number mismatch '%s' != '%s'\n",
+		       ap->id, dev->devno, serial[0], serial[1]);
+		return 0;
+	}
+
+	if (dev->class == ATA_DEV_ATA && dev->n_sectors != new_n_sectors) {
+		printk(KERN_INFO
+		       "ata%u: dev %u n_sectors mismatch %llu != %llu\n",
+		       ap->id, dev->devno, (unsigned long long)dev->n_sectors,
+		       (unsigned long long)new_n_sectors);
+		return 0;
+	}
+
+	return 1;
+}
+
+/**
+ *	ata_dev_revalidate - Revalidate ATA device
+ *	@ap: port on which the device to revalidate resides
+ *	@dev: device to revalidate
+ *	@post_reset: is this revalidation after reset?
+ *
+ *	Re-read IDENTIFY page and make sure @dev is still attached to
+ *	the port.
+ *
+ *	LOCKING:
+ *	Kernel thread context (may sleep)
+ *
+ *	RETURNS:
+ *	0 on success, negative errno otherwise
+ */
+int ata_dev_revalidate(struct ata_port *ap, struct ata_device *dev,
+		       int post_reset)
+{
+	unsigned int class;
+	u16 *id;
+	int rc;
+
+	if (!ata_dev_present(dev))
+		return -ENODEV;
+
+	class = dev->class;
+	id = NULL;
+
+	/* allocate & read ID data */
+	rc = ata_dev_read_id(ap, dev, &class, post_reset, &id);
+	if (rc)
+		goto fail;
+
+	/* is the device still there? */
+	if (!ata_dev_same_device(ap, dev, class, id)) {
+		rc = -ENODEV;
+		goto fail;
+	}
+
+	kfree(dev->id);
+	dev->id = id;
+
+	/* configure device according to the new ID */
+	return ata_dev_configure(ap, dev, 0);
+
+ fail:
+	printk(KERN_ERR "ata%u: dev %u revalidation failed (errno=%d)\n",
+	       ap->id, dev->devno, rc);
+	kfree(id);
+	return rc;
+}
+
 static void ata_pr_blacklisted(const struct ata_port *ap,
 			       const struct ata_device *dev)
 {
@@ -4964,6 +5078,7 @@ EXPORT_SYMBOL_GPL(sata_std_hardreset);
 EXPORT_SYMBOL_GPL(ata_std_postreset);
 EXPORT_SYMBOL_GPL(ata_std_probe_reset);
 EXPORT_SYMBOL_GPL(ata_drive_probe_reset);
+EXPORT_SYMBOL_GPL(ata_dev_revalidate);
 EXPORT_SYMBOL_GPL(ata_port_disable);
 EXPORT_SYMBOL_GPL(ata_ratelimit);
 EXPORT_SYMBOL_GPL(ata_busy_sleep);
diff --git a/include/linux/libata.h b/include/linux/libata.h
index 86a504f..66dce58 100644
--- a/include/linux/libata.h
+++ b/include/linux/libata.h
@@ -485,6 +485,8 @@ extern int ata_std_softreset(struct ata_
 extern int sata_std_hardreset(struct ata_port *ap, int verbose,
 			      unsigned int *class);
 extern void ata_std_postreset(struct ata_port *ap, unsigned int *classes);
+extern int ata_dev_revalidate(struct ata_port *ap, struct ata_device *dev,
+			      int post_reset);
 extern void ata_port_disable(struct ata_port *);
 extern void ata_std_ports(struct ata_ioports *ioaddr);
 #ifdef CONFIG_PCI
-- 
1.2.1



^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3
@ 2006-03-05  8:55 Tejun Heo
  2006-03-05  8:55 ` [PATCH 1/4] libata: re-initialize parameters before configuring Tejun Heo
                   ` (3 more replies)
  0 siblings, 4 replies; 9+ messages in thread
From: Tejun Heo @ 2006-03-05  8:55 UTC (permalink / raw)
  To: jgarzik, linux-ide, htejun

Hello, Jeff.

This is the third take of implement-and-use-ata_dev_revalidate
patchset.  In the last take[1], out of four patches, %1, %2 and %4 got
ACK'ed while %3 had some minor issues.

Changes from the last take are...

* in #3, ata_dev_same_device() tags mismatch messages with KERN_INFO
  instead of KERN_WARNING.

* in #3, ata_dev_revalidate() returns -ENODEV instead of 0 if device
  isn't present

Thanks.

--
tejun

[1] http://marc.theaimsgroup.com/?l=linux-ide&m=114120130020500&w=2
    (gmane is down...)



^ permalink raw reply	[flat|nested] 9+ messages in thread

* [PATCH 4/4] libata: revalidate after transfer mode configuration
  2006-03-05  8:55 [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Tejun Heo
  2006-03-05  8:55 ` [PATCH 1/4] libata: re-initialize parameters before configuring Tejun Heo
@ 2006-03-05  8:55 ` Tejun Heo
  2006-03-05  8:55 ` [PATCH 3/4] libata: implement ata_dev_revalidate() Tejun Heo
  2006-03-05 16:10 ` [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Jeff Garzik
  3 siblings, 0 replies; 9+ messages in thread
From: Tejun Heo @ 2006-03-05  8:55 UTC (permalink / raw)
  To: jgarzik, linux-ide; +Cc: Tejun Heo

Revalidate device after transfer mode configuration.  This also makes
dev->id up-to-date.

Signed-off-by: Tejun Heo <htejun@gmail.com>

---

 drivers/scsi/libata-core.c |    6 ++++++
 1 files changed, 6 insertions(+), 0 deletions(-)

09956f0e1eb537c8324f402dc1588c3405c10b42
diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c
index 5d0adfa..5dbcf0c 100644
--- a/drivers/scsi/libata-core.c
+++ b/drivers/scsi/libata-core.c
@@ -1625,6 +1625,12 @@ static void ata_dev_set_mode(struct ata_
 	idx = ofs + dev->xfer_shift;
 	WARN_ON(idx >= ARRAY_SIZE(xfer_mode_str));
 
+	if (ata_dev_revalidate(ap, dev, 0)) {
+		printk(KERN_ERR "ata%u: failed to revalidate after set "
+		       "xfermode, disabled\n", ap->id);
+		ata_port_disable(ap);
+	}
+
 	DPRINTK("idx=%d xfer_shift=%u, xfer_mode=0x%x, base=0x%x, offset=%d\n",
 		idx, dev->xfer_shift, (int)dev->xfer_mode, (int)base, ofs);
 
-- 
1.2.1



^ permalink raw reply related	[flat|nested] 9+ messages in thread

* Re: [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3
  2006-03-05  8:55 [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Tejun Heo
                   ` (2 preceding siblings ...)
  2006-03-05  8:55 ` [PATCH 3/4] libata: implement ata_dev_revalidate() Tejun Heo
@ 2006-03-05 16:10 ` Jeff Garzik
  2006-03-05 16:33   ` Tejun Heo
  3 siblings, 1 reply; 9+ messages in thread
From: Jeff Garzik @ 2006-03-05 16:10 UTC (permalink / raw)
  To: Tejun Heo; +Cc: linux-ide

Tejun Heo wrote:
> Hello, Jeff.
> 
> This is the third take of implement-and-use-ata_dev_revalidate
> patchset.  In the last take[1], out of four patches, %1, %2 and %4 got
> ACK'ed while %3 had some minor issues.
> 
> Changes from the last take are...
> 
> * in #3, ata_dev_same_device() tags mismatch messages with KERN_INFO
>   instead of KERN_WARNING.
> 
> * in #3, ata_dev_revalidate() returns -ENODEV instead of 0 if device
>   isn't present

I thought this was take #4?  Anyway...

applied 1-4



^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3
  2006-03-05 16:10 ` [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Jeff Garzik
@ 2006-03-05 16:33   ` Tejun Heo
  0 siblings, 0 replies; 9+ messages in thread
From: Tejun Heo @ 2006-03-05 16:33 UTC (permalink / raw)
  To: Jeff Garzik; +Cc: linux-ide

On Sun, Mar 05, 2006 at 11:10:56AM -0500, Jeff Garzik wrote:
> Tejun Heo wrote:
> >Hello, Jeff.
> >
> >This is the third take of implement-and-use-ata_dev_revalidate
> >patchset.  In the last take[1], out of four patches, %1, %2 and %4 got
> >ACK'ed while %3 had some minor issues.
> >
> >Changes from the last take are...
> >
> >* in #3, ata_dev_same_device() tags mismatch messages with KERN_INFO
> >  instead of KERN_WARNING.
> >
> >* in #3, ata_dev_revalidate() returns -ENODEV instead of 0 if device
> >  isn't present
> 
> I thought this was take #4?  Anyway...
> 

The first take was on Feb 15, the second on Mar 1, and this one.
Although the first take wan't really first (it was chopped off part of
previously posted larger patchset), it's the third take, technically.

Thanks.  :-)

-- 
tejun

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2006-03-05 16:33 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-03-05  8:55 [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Tejun Heo
2006-03-05  8:55 ` [PATCH 1/4] libata: re-initialize parameters before configuring Tejun Heo
2006-03-05  8:55 ` [PATCH 4/4] libata: revalidate after transfer mode configuration Tejun Heo
2006-03-05  8:55 ` [PATCH 3/4] libata: implement ata_dev_revalidate() Tejun Heo
2006-03-05 16:10 ` [PATCHSET] libata: implement and use ata_dev_revalidate(), take #3 Jeff Garzik
2006-03-05 16:33   ` Tejun Heo
  -- strict thread matches above, loose matches on Subject: below --
2006-03-01  8:20 [PATCHSET] libata: implement and use ata_dev_revalidate(), take #2 Tejun Heo
2006-03-01  8:20 ` [PATCH 1/4] libata: re-initialize parameters before configuring Tejun Heo
2006-02-15 10:02 [PATCHSET] libata: implement and use ata_dev_revalidate() Tejun Heo
2006-02-15 10:02 ` [PATCH 1/4] libata: re-initialize parameters before configuring Tejun Heo
2006-02-20 10:49   ` Jeff Garzik

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).