linux-ide.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] PA-RISC update to 87415
@ 2004-11-03 20:00 Grant Grundler
  2004-11-03 20:21 ` Bartlomiej Zolnierkiewicz
  0 siblings, 1 reply; 9+ messages in thread
From: Grant Grundler @ 2004-11-03 20:00 UTC (permalink / raw)
  To: Bartlomiej Zolnierkiewicz; +Cc: matthew, linux-ide

Bartlomiej,
Here's a "final" patch to cleanup the exporting of IDE data
to suckyio support. I sent this before but it wasn't "verified"
at the time:
http://marc.theaimsgroup.com/?l=linux-ide&m=109587104530498&w=2

It's verified now to work and should be applied.

Changelog comment should read:
	Move Superio (NatSem 87560) IDE hacks into the ns87415 driver
	instead of exporting IDE data structures.
	To date, only PA-RISC port is known to use the 87560 chip.

thanks,
grant

----- Forwarded message from Matthew Wilcox <matthew@wil.cx> -----

tp://cvs.parisc-linux.org/linux-2.6/arch/parisc/kernel/drivers.c.diff?cvsroot=&r1=1.15&r2=1.16
http://cvs.parisc-linux.org/linux-2.6/include/asm-parisc/io.h.diff?cvsroot=&r1=1.11&r2=1.12

: text/plain; charset=us-ascii
Content-Disposition: inline
User-Agent: Mutt/1.4.1i
Sender: <willy@www.linux.org.uk>
X-Virus-Scanned: by amavisd-new-20030616-p10 (Debian) at lackof.org
X-Spam-Checker-Version: SpamAssassin 2.64 (2004-01-11) on colo.lackof.org
X-Spam-Status: No, hits=-2.7 required=5.0 tests=BAYES_00,DOMAIN_BODY 
	autolearn=no version=2.64
X-Spam-Level: 
Status: O
Content-Length: 4519
Lines: 136


Can I have a better description for this patch than "Superio
cleanup"?  And if you'd like to send it to Bartlomiej Zolnierkiewicz
<bzolnier@gmail.com> yourself, that's more than fine by me ;-)

diff -urpNX dontdiff linux-2.6.10-rc1-bk13/drivers/ide/pci/ns87415.c parisc-2.6-bk/drivers/ide/pci/ns87415.c
--- linux-2.6.10-rc1-bk13/drivers/ide/pci/ns87415.c	Fri Oct 22 15:39:07 2004
+++ parisc-2.6-bk/drivers/ide/pci/ns87415.c	Wed Nov  3 06:19:00 2004
@@ -4,6 +4,7 @@
  * Copyright (C) 1997-1998	Mark Lord <mlord@pobox.com>
  * Copyright (C) 1998		Eddie C. Dost <ecd@skynet.be>
  * Copyright (C) 1999-2000	Andre Hedrick <andre@linux-ide.org>
+ * Copyright (C) 2004		Grant Grundler <grundler at parisc-linux.org>
  *
  * Inspired by an earlier effort from David S. Miller <davem@redhat.com>
  */
@@ -25,6 +26,75 @@
 
 #include <asm/io.h>
 
+#ifdef CONFIG_SUPERIO
+/* SUPERIO 87560 is a PoS chip that NatSem denies exists.
+ * Unfortunately, it's built-in on all Astro-based PA-RISC workstations
+ * which use the integrated NS87514 cell for CD-ROM support.
+ * i.e we have to support for CD-ROM installs.
+ * See drivers/parisc/superio.c for more gory details.
+ */
+#include <asm/superio.h>
+
+static unsigned long superio_ide_status[2];
+static unsigned long superio_ide_select[2];
+static unsigned long superio_ide_dma_status[2];
+
+#define SUPERIO_IDE_MAX_RETRIES 25
+
+/* Because of a defect in Super I/O, all reads of the PCI DMA status 
+ * registers, IDE status register and the IDE select register need to be 
+ * retried
+ */
+static u8 superio_ide_inb (unsigned long port)
+{
+	if (port == superio_ide_status[0] ||
+	    port == superio_ide_status[1] ||
+	    port == superio_ide_select[0] ||
+	    port == superio_ide_select[1] ||
+	    port == superio_ide_dma_status[0] ||
+	    port == superio_ide_dma_status[1]) {
+		u8 tmp;
+		int retries = SUPERIO_IDE_MAX_RETRIES;
+
+		/* printk(" [ reading port 0x%x with retry ] ", port); */
+
+		do {
+			tmp = inb(port);
+			if (tmp == 0)
+				udelay(50);
+		} while (tmp == 0 && retries-- > 0);
+
+		return tmp;
+	}
+
+	return inb(port);
+}
+
+static void __devinit superio_ide_init_iops (struct hwif_s *hwif)
+{
+	u32 base, dmabase;
+	u8 tmp;
+	struct pci_dev *pdev = hwif->pci_dev;
+	u8 port = hwif->channel;
+
+	base = pci_resource_start(pdev, port * 2) & ~3;
+	dmabase = pci_resource_start(pdev, 4) & ~3;
+
+	superio_ide_status[port] = base + IDE_STATUS_OFFSET;
+	superio_ide_select[port] = base + IDE_SELECT_OFFSET;
+	superio_ide_dma_status[port] = dmabase + (!port ? 2 : 0xa);
+	
+	/* Clear error/interrupt, enable dma */
+	tmp = superio_ide_inb(superio_ide_dma_status[port]);
+	outb(tmp | 0x66, superio_ide_dma_status[port]);
+
+	/* We need to override inb to workaround a SuperIO errata */
+	hwif->INB = superio_ide_inb;
+}
+#else
+static void __devinit superio_ide_init_iops (struct hwif_s *hwif) {}
+#endif
+
 static unsigned int ns87415_count = 0, ns87415_control[MAX_HWIFS] = { 0 };
 
 /*
@@ -119,6 +189,16 @@ static int ns87415_ide_dma_check (ide_dr
 	return __ide_dma_check(drive);
 }
 
+static void __init init_iops_ns87415(ide_hwif_t *hwif)
+{
+#ifdef CONFIG_PARISC
+	if (PCI_SLOT(hwif->pci_dev->devfn) == 0xE) {
+		/* Built-in - assume it's under superio. */
+		superio_ide_init_iops(hwif);
+	}
+#endif
+}
+
 static void __init init_hwif_ns87415 (ide_hwif_t *hwif)
 {
 	struct pci_dev *dev = hwif->pci_dev;
@@ -132,10 +212,6 @@ static void __init init_hwif_ns87415 (id
 	hwif->autodma = 0;
 	hwif->selectproc = &ns87415_selectproc;
 
-	/* Set a good latency timer and cache line size value. */
-	(void) pci_write_config_byte(dev, PCI_LATENCY_TIMER, 64);
-	/* FIXME: use pci_set_master() to ensure good latency timer value */
-
 	/*
 	 * We cannot probe for IRQ: both ports share common IRQ on INTA.
 	 * Also, leave IRQ masked during drive probing, to prevent infinite
@@ -205,6 +281,7 @@ static void __init init_hwif_ns87415 (id
 
 static ide_pci_device_t ns87415_chipset __devinitdata = {
 	.name		= "NS87415",
+	.init_iops	= init_iops_ns87415,
 	.init_hwif	= init_hwif_ns87415,
 	.channels	= 2,
 	.autodma	= AUTODMA,

-- 
"Next the s
----- End forwarded message -----

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-03 20:00 [PATCH] PA-RISC update to 87415 Grant Grundler
@ 2004-11-03 20:21 ` Bartlomiej Zolnierkiewicz
  2004-11-03 21:19   ` Grant Grundler
  2004-11-03 21:33   ` Grant Grundler
  0 siblings, 2 replies; 9+ messages in thread
From: Bartlomiej Zolnierkiewicz @ 2004-11-03 20:21 UTC (permalink / raw)
  To: Grant Grundler; +Cc: matthew, linux-ide

On Wed, 3 Nov 2004 13:00:59 -0700, Grant Grundler
<grundler@parisc-linux.org> wrote:
> Bartlomiej,
> Here's a "final" patch to cleanup the exporting of IDE data
> to suckyio support. I sent this before but it wasn't "verified"
> at the time:
> http://marc.theaimsgroup.com/?l=linux-ide&m=109587104530498&w=2
> 
> It's verified now to work and should be applied.

thanks, looks OK

I only wonder about this change:

> @@ -132,10 +212,6 @@ static void __init init_hwif_ns87415 (id
>         hwif->autodma = 0;
>         hwif->selectproc = &ns87415_selectproc;
> 
> -       /* Set a good latency timer and cache line size value. */
> -       (void) pci_write_config_byte(dev, PCI_LATENCY_TIMER, 64);
> -       /* FIXME: use pci_set_master() to ensure good latency timer value */
> -
>         /*
>          * We cannot probe for IRQ: both ports share common IRQ on INTA.
>          * Also, leave IRQ masked during drive probing, to prevent infinite

?

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-03 20:21 ` Bartlomiej Zolnierkiewicz
@ 2004-11-03 21:19   ` Grant Grundler
  2004-11-03 21:33   ` Grant Grundler
  1 sibling, 0 replies; 9+ messages in thread
From: Grant Grundler @ 2004-11-03 21:19 UTC (permalink / raw)
  To: Bartlomiej Zolnierkiewicz; +Cc: matthew, linux-ide

On Wed, Nov 03, 2004 at 09:21:02PM +0100, Bartlomiej Zolnierkiewicz wrote:
> I only wonder about this change:
> 
> > @@ -132,10 +212,6 @@ static void __init init_hwif_ns87415 (id
> >         hwif->autodma = 0;
> >         hwif->selectproc = &ns87415_selectproc;
> > 
> > -       /* Set a good latency timer and cache line size value. */
> > -       (void) pci_write_config_byte(dev, PCI_LATENCY_TIMER, 64);
> > -       /* FIXME: use pci_set_master() to ensure good latency timer value */
> > -

I don't expect a driver to always blindly write this value since
it affects the max latency other PCI bus guests will see. 64 is a
fairly safe value if you really want to keep that bit of code in.

ide_hwif_setup_dma() calls pci_set_master() if necessary.
pci_set_master() (indirectly via pcibios_set_master() sets
PCI_LATENCY_TIMER to a "reasonable" value.

grundler <506>fgrep pci_set_master drivers/ide/*
drivers/ide/setup-pci.c:                        pci_set_master(dev);

thanks,
grant

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-03 20:21 ` Bartlomiej Zolnierkiewicz
  2004-11-03 21:19   ` Grant Grundler
@ 2004-11-03 21:33   ` Grant Grundler
  2004-11-03 22:01     ` Bartlomiej Zolnierkiewicz
  1 sibling, 1 reply; 9+ messages in thread
From: Grant Grundler @ 2004-11-03 21:33 UTC (permalink / raw)
  To: Bartlomiej Zolnierkiewicz; +Cc: matthew, linux-ide

On Wed, Nov 03, 2004 at 09:21:02PM +0100, Bartlomiej Zolnierkiewicz wrote:
> I only wonder about this change:
> 
> > @@ -132,10 +212,6 @@ static void __init init_hwif_ns87415 (id
> >         hwif->autodma = 0;
> >         hwif->selectproc = &ns87415_selectproc;
> > 
> > -       /* Set a good latency timer and cache line size value. */
> > -       (void) pci_write_config_byte(dev, PCI_LATENCY_TIMER, 64);
> > -       /* FIXME: use pci_set_master() to ensure good latency timer value */

Bartlomiej,
two more notes:
1) both comments are wrong.
  (byte write only covers LATENCY, pci_set_master is called)

2) I realize now this should have been submitted this as a seperate patch.
   Sorry about that. I didn't review the patch today (again) as thoroughly
   as I should have. I started glossing over it when I saw all the suckyio
   code that I've stared at more than a few times...*sigh*
   You want a seperate patch+changelog entry for this one or was the
   previous email sufficient?

thanks,
grant

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-03 21:33   ` Grant Grundler
@ 2004-11-03 22:01     ` Bartlomiej Zolnierkiewicz
  2004-11-03 23:19       ` Grant Grundler
  2004-11-03 23:23       ` Grant Grundler
  0 siblings, 2 replies; 9+ messages in thread
From: Bartlomiej Zolnierkiewicz @ 2004-11-03 22:01 UTC (permalink / raw)
  To: Grant Grundler; +Cc: matthew, linux-ide

On Wed, 3 Nov 2004 14:33:51 -0700, Grant Grundler
<grundler@parisc-linux.org> wrote:
> 
> 
> On Wed, Nov 03, 2004 at 09:21:02PM +0100, Bartlomiej Zolnierkiewicz wrote:
> > I only wonder about this change:
> >
> > > @@ -132,10 +212,6 @@ static void __init init_hwif_ns87415 (id
> > >         hwif->autodma = 0;
> > >         hwif->selectproc = &ns87415_selectproc;
> > >
> > > -       /* Set a good latency timer and cache line size value. */
> > > -       (void) pci_write_config_byte(dev, PCI_LATENCY_TIMER, 64);
> > > -       /* FIXME: use pci_set_master() to ensure good latency timer value */
> 
> Bartlomiej,
> two more notes:
> 1) both comments are wrong.
>   (byte write only covers LATENCY, pci_set_master is called)

?

> 2) I realize now this should have been submitted this as a seperate patch.
>    Sorry about that. I didn't review the patch today (again) as thoroughly
>    as I should have. I started glossing over it when I saw all the suckyio
>    code that I've stared at more than a few times...*sigh*
>    You want a seperate patch+changelog entry for this one or was the
>    previous email sufficient?

Please make a separate patch+changelog if this is not a problem.

Thanks.

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-03 22:01     ` Bartlomiej Zolnierkiewicz
@ 2004-11-03 23:19       ` Grant Grundler
  2004-11-03 23:23       ` Grant Grundler
  1 sibling, 0 replies; 9+ messages in thread
From: Grant Grundler @ 2004-11-03 23:19 UTC (permalink / raw)
  To: Bartlomiej Zolnierkiewicz; +Cc: Grant Grundler, matthew, linux-ide

On Wed, Nov 03, 2004 at 11:01:58PM +0100, Bartlomiej Zolnierkiewicz wrote:
> Please make a separate patch+changelog if this is not a problem.

ide_hwif_setup_dma() calls pci_set_master() if necessary.
pci_set_master() (indirectly via pcibios_set_master() sets
PCI_LATENCY_TIMER to a "reasonable" value.

Signed-off-by: Grant Grundler <grundler@parisc-linux.org>


Index: linux-2.6/drivers/ide/pci/ns87415.c
===================================================================
RCS file: /var/cvs/linux-2.6/drivers/ide/pci/ns87415.c,v
retrieving revision 1.17
retrieving revision 1.18
diff -u -p -r1.17 -r1.18
--- linux-2.6/drivers/ide/pci/ns87415.c	13 Sep 2004 15:23:04 -0000	1.17
+++ linux-2.6/drivers/ide/pci/ns87415.c	28 Sep 2004 17:07:01 -0000	1.18
@@ -153,10 +223,6 @@ static void __init init_hwif_ns87415 (id
 	hwif->autodma = 0;
 	hwif->selectproc = &ns87415_selectproc;
 
-	/* Set a good latency timer and cache line size value. */
-	(void) pci_write_config_byte(dev, PCI_LATENCY_TIMER, 64);
-	/* FIXME: use pci_set_master() to ensure good latency timer value */
-
 	/*
 	 * We cannot probe for IRQ: both ports share common IRQ on INTA.
 	 * Also, leave IRQ masked during drive probing, to prevent infinite

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-03 22:01     ` Bartlomiej Zolnierkiewicz
  2004-11-03 23:19       ` Grant Grundler
@ 2004-11-03 23:23       ` Grant Grundler
  2004-11-05 20:17         ` Bartlomiej Zolnierkiewicz
  1 sibling, 1 reply; 9+ messages in thread
From: Grant Grundler @ 2004-11-03 23:23 UTC (permalink / raw)
  To: Bartlomiej Zolnierkiewicz; +Cc: Grant Grundler, matthew, linux-ide

On Wed, Nov 03, 2004 at 11:01:58PM +0100, Bartlomiej Zolnierkiewicz wrote:
> > 1) both comments are wrong.
> >   (byte write only covers LATENCY, pci_set_master is called)
> 
> ?

	/* Set a good latency timer and cache line size value. */

The PCI config write only modifies the latency timer, not the cache line
size register.

#define PCI_CACHE_LINE_SIZE     0x0c    /* 8 bits */
#define PCI_LATENCY_TIMER       0x0d    /* 8 bits */

	/* FIXME: use pci_set_master() to ensure good latency timer value */

This has been in fact already been fixed.
That's why I submitted the patch to delete the code.

thanks,
grant

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-03 23:23       ` Grant Grundler
@ 2004-11-05 20:17         ` Bartlomiej Zolnierkiewicz
  2004-11-06  6:28           ` Grant Grundler
  0 siblings, 1 reply; 9+ messages in thread
From: Bartlomiej Zolnierkiewicz @ 2004-11-05 20:17 UTC (permalink / raw)
  To: Grant Grundler; +Cc: matthew, linux-ide

applied

I had to cover init_iops_ns87415 by CONFIG_SUPERIO to fix:

drivers/ide/pci/ns87415.c:95: warning: `superio_ide_init_iops' defined
but not used

I also marked init_iops_ns87415 with __devinit

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

* Re: [PATCH] PA-RISC update to 87415
  2004-11-05 20:17         ` Bartlomiej Zolnierkiewicz
@ 2004-11-06  6:28           ` Grant Grundler
  0 siblings, 0 replies; 9+ messages in thread
From: Grant Grundler @ 2004-11-06  6:28 UTC (permalink / raw)
  To: Bartlomiej Zolnierkiewicz; +Cc: matthew, linux-ide

On Fri, Nov 05, 2004 at 09:17:03PM +0100, Bartlomiej Zolnierkiewicz wrote:
> applied

Thanks!

> I had to cover init_iops_ns87415 by CONFIG_SUPERIO to fix:
> 
> drivers/ide/pci/ns87415.c:95: warning: `superio_ide_init_iops' defined
> but not used
> 
> I also marked init_iops_ns87415 with __devinit

oh - sorry. I only tested with CONFIG_SUPERIO enabled
since that's the platform I'm focused on requires.
Thanks for cleaning up instead of bouncing it.

grant

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

end of thread, other threads:[~2004-11-06  6:28 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-11-03 20:00 [PATCH] PA-RISC update to 87415 Grant Grundler
2004-11-03 20:21 ` Bartlomiej Zolnierkiewicz
2004-11-03 21:19   ` Grant Grundler
2004-11-03 21:33   ` Grant Grundler
2004-11-03 22:01     ` Bartlomiej Zolnierkiewicz
2004-11-03 23:19       ` Grant Grundler
2004-11-03 23:23       ` Grant Grundler
2004-11-05 20:17         ` Bartlomiej Zolnierkiewicz
2004-11-06  6:28           ` Grant Grundler

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).