Module Name:    src
Committed By:   msaitoh
Date:           Tue Oct 31 13:57:08 UTC 2023

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

Log Message:
eqos_pci: Limit to 32bit DMA only for PSE devices.


To generate a diff of this commit:
cvs rdiff -u -r1.2 -r1.3 src/sys/dev/pci/if_eqos_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_eqos_pci.c
diff -u src/sys/dev/pci/if_eqos_pci.c:1.2 src/sys/dev/pci/if_eqos_pci.c:1.3
--- src/sys/dev/pci/if_eqos_pci.c:1.2	Thu Oct 26 18:02:51 2023
+++ src/sys/dev/pci/if_eqos_pci.c	Tue Oct 31 13:57:08 2023
@@ -1,4 +1,4 @@
-/* $NetBSD: if_eqos_pci.c,v 1.2 2023/10/26 18:02:51 msaitoh Exp $ */
+/* $NetBSD: if_eqos_pci.c,v 1.3 2023/10/31 13:57:08 msaitoh Exp $ */
 
 /*-
  * Copyright (c) 2023 Masanobu SAITOH <msai...@netbsd.org>
@@ -35,7 +35,7 @@
 #include "opt_net_mpsafe.h"
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_eqos_pci.c,v 1.2 2023/10/26 18:02:51 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_eqos_pci.c,v 1.3 2023/10/31 13:57:08 msaitoh Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -130,17 +130,11 @@ eqos_pci_attach(device_t parent, device_
 	sc->sc_bsh = memh;
 	prop = device_properties(sc->sc_dev);
 
-#if 0 /* I don't know why dmat64 doesn't work... */
-	if (pci_dma64_available(pa)) {
-		aprint_verbose(", 64-bit DMA");
+	if (pci_dma64_available(pa))
 		sc->sc_dmat = pa->pa_dmat64;
-	} else  {
-		aprint_verbose(", 32-bit DMA");
+	else
 		sc->sc_dmat = pa->pa_dmat;
-	}
-#else
-	sc->sc_dmat = pa->pa_dmat;
-#endif
+
 	sc->sc_phy_id = MII_PHY_ANY;
 	switch (psc->sc_pcidevid) {
 	case PCI_PRODUCT_INTEL_EHL_ETH:
@@ -153,6 +147,7 @@ eqos_pci_attach(device_t parent, device_
 	case PCI_PRODUCT_INTEL_EHL_PSE_ETH_1_SGMII_1G:
 	case PCI_PRODUCT_INTEL_EHL_PSE_ETH_0_SGMII_2_5G:
 	case PCI_PRODUCT_INTEL_EHL_PSE_ETH_1_SGMII_2_5G:
+		sc->sc_dmat = pa->pa_dmat; /* 32bit DMA only */
 		sc->sc_csr_clock = 200000000;
 		dma_pbl = 32;
 		break;
@@ -163,6 +158,12 @@ eqos_pci_attach(device_t parent, device_
 	default:
 		sc->sc_csr_clock = 200000000; /* XXX */
 	}
+
+	if (sc->sc_dmat == pa->pa_dmat64)
+		aprint_verbose(", 64-bit DMA");
+	else
+		aprint_verbose(", 32-bit DMA");
+
 	/* Defaults */
 	if (dma_pbl != 0) {
 		prop = device_properties(sc->sc_dev);

Reply via email to