Module Name:    src
Committed By:   thorpej
Date:           Mon Nov 20 21:45:34 UTC 2023

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

Log Message:
Revert previous.  I'm going to make a slight change to the patch, and
want it collapsed into a single commit to make it easier to pull into
netbsd-10.


To generate a diff of this commit:
cvs rdiff -u -r1.68 -r1.69 src/sys/dev/pci/pciide_common.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/pciide_common.c
diff -u src/sys/dev/pci/pciide_common.c:1.68 src/sys/dev/pci/pciide_common.c:1.69
--- src/sys/dev/pci/pciide_common.c:1.68	Mon Nov 20 15:16:46 2023
+++ src/sys/dev/pci/pciide_common.c	Mon Nov 20 21:45:34 2023
@@ -1,4 +1,4 @@
-/*	$NetBSD: pciide_common.c,v 1.68 2023/11/20 15:16:46 thorpej Exp $	*/
+/*	$NetBSD: pciide_common.c,v 1.69 2023/11/20 21:45:34 thorpej Exp $	*/
 
 
 /*
@@ -70,7 +70,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pciide_common.c,v 1.68 2023/11/20 15:16:46 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pciide_common.c,v 1.69 2023/11/20 21:45:34 thorpej Exp $");
 
 #include <sys/param.h>
 
@@ -735,31 +735,6 @@ pciide_dma_dmamap_setup(struct pciide_so
 		}
 		}
 #endif
-		/*
-		 * Some controllers get really upset if the length
-		 * of any DMA segment is odd.  This isn't something
-		 * that's going to happen in normal steady-state
-		 * operation (reading VM pages, etc.), but physio users
-		 * don't have as many guard rails.
-		 *
-		 * Consider an 8K read request that starts at an odd
-		 * offset within a page.  At first blush, all of the
-		 * checks pass because it's a sector-rounded size, but
-		 * unless the buffer spans 2 physically contiguous pages,
-		 * it's going to result in 2 odd-length DMA segments.
-		 */
-		if (dma_maps->dmamap_xfer->dm_segs[seg].ds_len & 1) {
-			unsigned long long phys =
-			    dma_maps->dmamap_xfer->dm_segs[seg].ds_addr;
-			unsigned long long len =
-			    dma_maps->dmamap_xfer->dm_segs[seg].ds_len;
-			aprint_verbose_dev(sc->sc_wdcdev.sc_atac.atac_dev,
-			    "ODD segment length: "
-			    "seg %d addr 0x%llx len 0x%llx\n",
-			    seg, phys, len);
-			bus_dmamap_unload(sc->sc_dmat, dma_maps->dmamap_xfer);
-			return EIO;
-		}
 		dma_maps->dma_table[seg].base_addr =
 		    htole32(dma_maps->dmamap_xfer->dm_segs[seg].ds_addr);
 		dma_maps->dma_table[seg].byte_count =

Reply via email to