Module Name:    src
Committed By:   dyoung
Date:           Tue Mar 23 21:22:25 UTC 2010

Modified Files:
        src/sys/dev/pci: if_hme_pci.c

Log Message:
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/.


To generate a diff of this commit:
cvs rdiff -u -r1.32 -r1.33 src/sys/dev/pci/if_hme_pci.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/dev/pci/if_hme_pci.c
diff -u src/sys/dev/pci/if_hme_pci.c:1.32 src/sys/dev/pci/if_hme_pci.c:1.33
--- src/sys/dev/pci/if_hme_pci.c:1.32	Thu Mar 11 04:00:36 2010
+++ src/sys/dev/pci/if_hme_pci.c	Tue Mar 23 21:22:25 2010
@@ -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;

Reply via email to