Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/pci Use the PCI BAR type to decide which I/O enables...



details:   https://anonhg.NetBSD.org/src/rev/06b58d73eea6
branches:  trunk
changeset: 753358:06b58d73eea6
user:      dyoung <dyoung%NetBSD.org@localhost>
date:      Tue Mar 23 21:22:25 2010 +0000

description:
Use the PCI BAR type to decide which I/O enables to set.

TBD: Put back the old BAR #definition, s/PCI_BAR(0)/PCI_HME_BASEADDR/.

diffstat:

 sys/dev/pci/if_hme_pci.c |  26 +++++++++++++-------------
 1 files changed, 13 insertions(+), 13 deletions(-)

diffs (62 lines):

diff -r b2c78f34a97d -r 06b58d73eea6 sys/dev/pci/if_hme_pci.c
--- a/sys/dev/pci/if_hme_pci.c  Tue Mar 23 21:18:23 2010 +0000
+++ b/sys/dev/pci/if_hme_pci.c  Tue Mar 23 21:22:25 2010 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_hme_pci.c,v 1.32 2010/03/11 04:00:36 mrg Exp $      */
+/*     $NetBSD: if_hme_pci.c,v 1.33 2010/03/23 21:22:25 dyoung Exp $   */
 
 /*
  * Copyright (c) 2000 Matthew R. Green
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_hme_pci.c,v 1.32 2010/03/11 04:00:36 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_hme_pci.c,v 1.33 2010/03/23 21:22:25 dyoung Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -144,23 +144,24 @@
            PCI_REVISION(pa->pa_class));
        aprint_naive(": Ethernet controller\n");
 
+       csr = pci_conf_read(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG);
+       type = pci_mapreg_type(pa->pa_pc, pa->pa_tag, PCI_BAR(0));
+
        /*
         * enable io/memory-space accesses.  this is kinda of gross; but
-        # the hme comes up with neither IO space enabled, or memory space.
+        * the hme comes up with neither IO space enabled, or memory space.
         */
-       if (pa->pa_memt)
+       switch (type) {
+       case PCI_MAPREG_TYPE_MEM:
                pa->pa_flags |= PCI_FLAGS_MEM_ENABLED;
-       if (pa->pa_iot)
-               pa->pa_flags |= PCI_FLAGS_IO_ENABLED;
-       csr = pci_conf_read(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG);
-       if (pa->pa_memt) {
-               type = PCI_MAPREG_TYPE_MEM;
                csr |= PCI_COMMAND_MEM_ENABLE;
                sc->sc_bustag = pa->pa_memt;
-       } else {
-               type = PCI_MAPREG_TYPE_IO;
+               break;
+       case PCI_MAPREG_TYPE_IO:
+               pa->pa_flags |= PCI_FLAGS_IO_ENABLED;
                csr |= PCI_COMMAND_IO_ENABLE;
                sc->sc_bustag = pa->pa_iot;
+               break;
        }
        pci_conf_write(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG,
            csr | PCI_COMMAND_MEM_ENABLE);
@@ -179,8 +180,7 @@
         *
         */
 
-#define PCI_HME_BASEADDR       0x10
-       if (pci_mapreg_map(pa, PCI_HME_BASEADDR, type, 0,
+       if (pci_mapreg_map(pa, PCI_BAR(0), type, 0,
            &hsc->hsc_memt, &hsc->hsc_memh, NULL, NULL) != 0) {
                aprint_error_dev(self, "unable to map device registers\n");
                return;



Home | Main Index | Thread Index | Old Index