Module Name:    src
Committed By:   tsutsui
Date:           Tue Apr 21 13:16:36 UTC 2009

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

Log Message:
Fix wrong arguments of bus_dmamem_free(9).

XXX: not all resouces are freed properly on error path in age_dma_alloc().


To generate a diff of this commit:
cvs rdiff -u -r1.25 -r1.26 src/sys/dev/pci/if_age.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_age.c
diff -u src/sys/dev/pci/if_age.c:1.25 src/sys/dev/pci/if_age.c:1.26
--- src/sys/dev/pci/if_age.c:1.25	Tue Mar  3 23:28:44 2009
+++ src/sys/dev/pci/if_age.c	Tue Apr 21 13:16:36 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: if_age.c,v 1.25 2009/03/03 23:28:44 cegger Exp $ */
+/*	$NetBSD: if_age.c,v 1.26 2009/04/21 13:16:36 tsutsui Exp $ */
 /*	$OpenBSD: if_age.c,v 1.1 2009/01/16 05:00:34 kevlo Exp $	*/
 
 /*-
@@ -31,7 +31,7 @@
 /* Driver for Attansic Technology Corp. L1 Gigabit Ethernet. */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_age.c,v 1.25 2009/03/03 23:28:44 cegger Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_age.c,v 1.26 2009/04/21 13:16:36 tsutsui Exp $");
 
 #include "bpfilter.h"
 #include "vlan.h"
@@ -736,7 +736,7 @@
 		printf("%s: could not load DMA'able memory for Tx ring, "
 		    "error = %i\n", device_xname(sc->sc_dev), error);
 		bus_dmamem_free(sc->sc_dmat, 
-		    (bus_dma_segment_t *)&sc->age_rdata.age_tx_ring, 1);
+		    &sc->age_rdata.age_tx_ring_seg, 1);
 		return error;
 	}
 
@@ -778,7 +778,7 @@
 		printf("%s: could not load DMA'able memory for Rx ring, "
 		    "error = %i.\n", device_xname(sc->sc_dev), error);
 		bus_dmamem_free(sc->sc_dmat,
-		    (bus_dma_segment_t *)sc->age_rdata.age_rx_ring, 1);
+		    &sc->age_rdata.age_rx_ring_seg, 1);
 		return error;
 	}
 
@@ -821,7 +821,7 @@
 		printf("%s: could not load DMA'able memory for Rx return ring, "
 		    "error = %i\n", device_xname(sc->sc_dev), error);
 		bus_dmamem_free(sc->sc_dmat,
-		    (bus_dma_segment_t *)&sc->age_rdata.age_rr_ring, 1);
+		    &sc->age_rdata.age_rr_ring_seg, 1);
 		return error;
 	}
 
@@ -865,7 +865,7 @@
 		printf("%s: could not load DMA'able memory for CMB block, "
 		    "error = %i\n", device_xname(sc->sc_dev), error);
 		bus_dmamem_free(sc->sc_dmat,
-		    (bus_dma_segment_t *)&sc->age_rdata.age_cmb_block, 1);
+		    &sc->age_rdata.age_cmb_block_seg, 1);
 		return error;
 	}
 
@@ -909,7 +909,7 @@
 		printf("%s: could not load DMA'able memory for SMB block, "
 		    "error = %i\n", device_xname(sc->sc_dev), error);
 		bus_dmamem_free(sc->sc_dmat,
-		    (bus_dma_segment_t *)&sc->age_rdata.age_smb_block, 1);
+		    &sc->age_rdata.age_smb_block_seg, 1);
 		return error;
 	}
 
@@ -992,7 +992,7 @@
 	if (sc->age_cdata.age_tx_ring_map != NULL &&
 	    sc->age_rdata.age_tx_ring != NULL)
 		bus_dmamem_free(sc->sc_dmat,
-		    (bus_dma_segment_t *)sc->age_rdata.age_tx_ring, 1);
+		    &sc->age_rdata.age_tx_ring_seg, 1);
 	sc->age_rdata.age_tx_ring = NULL;
 	sc->age_cdata.age_tx_ring_map = NULL;
 
@@ -1002,7 +1002,7 @@
 	if (sc->age_cdata.age_rx_ring_map != NULL &&
 	    sc->age_rdata.age_rx_ring != NULL)
 		bus_dmamem_free(sc->sc_dmat, 
-		    (bus_dma_segment_t *)sc->age_rdata.age_rx_ring, 1);
+		    &sc->age_rdata.age_rx_ring_seg, 1);
 	sc->age_rdata.age_rx_ring = NULL;
 	sc->age_cdata.age_rx_ring_map = NULL;
 
@@ -1012,7 +1012,7 @@
 	if (sc->age_cdata.age_rr_ring_map != NULL &&
 	    sc->age_rdata.age_rr_ring != NULL)
 		bus_dmamem_free(sc->sc_dmat, 
-		    (bus_dma_segment_t *)sc->age_rdata.age_rr_ring, 1);
+		    &sc->age_rdata.age_rr_ring_seg, 1);
 	sc->age_rdata.age_rr_ring = NULL;
 	sc->age_cdata.age_rr_ring_map = NULL;
 
@@ -1022,7 +1022,7 @@
 	if (sc->age_cdata.age_cmb_block_map != NULL &&
 	    sc->age_rdata.age_cmb_block != NULL)
 		bus_dmamem_free(sc->sc_dmat,
-		    (bus_dma_segment_t *)sc->age_rdata.age_cmb_block, 1);
+		    &sc->age_rdata.age_cmb_block_seg, 1);
 	sc->age_rdata.age_cmb_block = NULL;
 	sc->age_cdata.age_cmb_block_map = NULL;
 
@@ -1032,7 +1032,7 @@
 	if (sc->age_cdata.age_smb_block_map != NULL &&
 	    sc->age_rdata.age_smb_block != NULL)
 		bus_dmamem_free(sc->sc_dmat, 
-		    (bus_dma_segment_t *)sc->age_rdata.age_smb_block, 1);
+		    &sc->age_rdata.age_smb_block_seg, 1);
 	sc->age_rdata.age_smb_block = NULL;
 	sc->age_cdata.age_smb_block_map = NULL;
 }

Reply via email to