Module Name: src Committed By: rin Date: Mon May 23 13:53:37 UTC 2022
Modified Files: src/sys/dev/pci: esm.c if_bwfm_pci.c if_ena.c if_iwi.c if_ixl.c if_sk.c if_ti.c if_vge.c ubsec.c src/sys/dev/pci/bktr: bktr_os.c Log Message: Audit unload/unmap v.s. free against DMA buffer for sys/dev/pci; make sure that bus_dmamap_unload(9) [or bus_dmamap_destroy(9)] or bus_dmamem_unmap(9) are preceding to freeing DMA buffer, if it is loaded or mapped, respectively. This is mandatory for some archs. See, e.g.: http://www.nerv.org/netbsd/?q=id:20210511T013030Z.013443cc790088147e4beed43f53dedabeaf9312 http://www.nerv.org/netbsd/?q=id:20220511T172220Z.561179f0b6fcc5b9cd73e274f69d74e2ce9e4c93 XXX XXX XXX Compile test only (for amd64/ALL). Thanks riastradh@ for double check. To generate a diff of this commit: cvs rdiff -u -r1.65 -r1.66 src/sys/dev/pci/esm.c cvs rdiff -u -r1.12 -r1.13 src/sys/dev/pci/if_bwfm_pci.c cvs rdiff -u -r1.32 -r1.33 src/sys/dev/pci/if_ena.c cvs rdiff -u -r1.117 -r1.118 src/sys/dev/pci/if_iwi.c cvs rdiff -u -r1.82 -r1.83 src/sys/dev/pci/if_ixl.c cvs rdiff -u -r1.110 -r1.111 src/sys/dev/pci/if_sk.c cvs rdiff -u -r1.122 -r1.123 src/sys/dev/pci/if_ti.c cvs rdiff -u -r1.83 -r1.84 src/sys/dev/pci/if_vge.c cvs rdiff -u -r1.59 -r1.60 src/sys/dev/pci/ubsec.c cvs rdiff -u -r1.68 -r1.69 src/sys/dev/pci/bktr/bktr_os.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/esm.c diff -u src/sys/dev/pci/esm.c:1.65 src/sys/dev/pci/esm.c:1.66 --- src/sys/dev/pci/esm.c:1.65 Sun Apr 19 08:18:19 2020 +++ src/sys/dev/pci/esm.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: esm.c,v 1.65 2020/04/19 08:18:19 isaki Exp $ */ +/* $NetBSD: esm.c,v 1.66 2022/05/23 13:53:37 rin Exp $ */ /*- * Copyright (c) 2002, 2003 Matt Fredette @@ -66,7 +66,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: esm.c,v 1.65 2020/04/19 08:18:19 isaki Exp $"); +__KERNEL_RCSID(0, "$NetBSD: esm.c,v 1.66 2022/05/23 13:53:37 rin Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -1418,13 +1418,13 @@ esm_freemem(struct esm_softc *sc, struct if (p->size == 0) return; - bus_dmamem_free(sc->dmat, p->segs, p->nsegs); - - bus_dmamem_unmap(sc->dmat, p->addr, p->size); + bus_dmamap_unload(sc->dmat, p->map); bus_dmamap_destroy(sc->dmat, p->map); - bus_dmamap_unload(sc->dmat, p->map); + bus_dmamem_unmap(sc->dmat, p->addr, p->size); + + bus_dmamem_free(sc->dmat, p->segs, p->nsegs); p->size = 0; } Index: src/sys/dev/pci/if_bwfm_pci.c diff -u src/sys/dev/pci/if_bwfm_pci.c:1.12 src/sys/dev/pci/if_bwfm_pci.c:1.13 --- src/sys/dev/pci/if_bwfm_pci.c:1.12 Sun Apr 24 07:11:31 2022 +++ src/sys/dev/pci/if_bwfm_pci.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: if_bwfm_pci.c,v 1.12 2022/04/24 07:11:31 skrll Exp $ */ +/* $NetBSD: if_bwfm_pci.c,v 1.13 2022/05/23 13:53:37 rin Exp $ */ /* $OpenBSD: if_bwfm_pci.c,v 1.18 2018/02/08 05:00:38 patrick Exp $ */ /* * Copyright (c) 2010-2016 Broadcom Corporation @@ -18,7 +18,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_bwfm_pci.c,v 1.12 2022/04/24 07:11:31 skrll Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_bwfm_pci.c,v 1.13 2022/05/23 13:53:37 rin Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -911,6 +911,7 @@ bdmfree: void bwfm_pci_dmamem_free(struct bwfm_pci_softc *sc, struct bwfm_pci_dmamem *bdm) { + bus_dmamap_unload(sc->sc_dmat, bdm->bdm_map); bus_dmamem_unmap(sc->sc_dmat, bdm->bdm_kva, bdm->bdm_size); bus_dmamem_free(sc->sc_dmat, &bdm->bdm_seg, 1); bus_dmamap_destroy(sc->sc_dmat, bdm->bdm_map); Index: src/sys/dev/pci/if_ena.c diff -u src/sys/dev/pci/if_ena.c:1.32 src/sys/dev/pci/if_ena.c:1.33 --- src/sys/dev/pci/if_ena.c:1.32 Thu Sep 23 10:31:23 2021 +++ src/sys/dev/pci/if_ena.c Mon May 23 13:53:37 2022 @@ -36,7 +36,7 @@ #if 0 __FBSDID("$FreeBSD: head/sys/dev/ena/ena.c 333456 2018-05-10 09:37:54Z mw $"); #endif -__KERNEL_RCSID(0, "$NetBSD: if_ena.c,v 1.32 2021/09/23 10:31:23 jmcneill Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_ena.c,v 1.33 2022/05/23 13:53:37 rin Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -793,12 +793,12 @@ ena_free_tx_resources(struct ena_adapter /* Free buffer DMA maps, */ for (int i = 0; i < tx_ring->ring_size; i++) { - m_freem(tx_ring->tx_buffer_info[i].mbuf); - tx_ring->tx_buffer_info[i].mbuf = NULL; bus_dmamap_unload(adapter->sc_dmat, tx_ring->tx_buffer_info[i].map); bus_dmamap_destroy(adapter->sc_dmat, tx_ring->tx_buffer_info[i].map); + m_freem(tx_ring->tx_buffer_info[i].mbuf); + tx_ring->tx_buffer_info[i].mbuf = NULL; } /* And free allocated memory. */ @@ -994,12 +994,12 @@ ena_free_rx_resources(struct ena_adapter /* Free buffer DMA maps, */ for (int i = 0; i < rx_ring->ring_size; i++) { - m_freem(rx_ring->rx_buffer_info[i].mbuf); - rx_ring->rx_buffer_info[i].mbuf = NULL; bus_dmamap_unload(adapter->sc_dmat, rx_ring->rx_buffer_info[i].map); bus_dmamap_destroy(adapter->sc_dmat, rx_ring->rx_buffer_info[i].map); + m_freem(rx_ring->rx_buffer_info[i].mbuf); + rx_ring->rx_buffer_info[i].mbuf = NULL; } #ifdef LRO Index: src/sys/dev/pci/if_iwi.c diff -u src/sys/dev/pci/if_iwi.c:1.117 src/sys/dev/pci/if_iwi.c:1.118 --- src/sys/dev/pci/if_iwi.c:1.117 Thu Sep 9 23:26:36 2021 +++ src/sys/dev/pci/if_iwi.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: if_iwi.c,v 1.117 2021/09/09 23:26:36 riastradh Exp $ */ +/* $NetBSD: if_iwi.c,v 1.118 2022/05/23 13:53:37 rin Exp $ */ /* $OpenBSD: if_iwi.c,v 1.111 2010/11/15 19:11:57 damien Exp $ */ /*- @@ -19,7 +19,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_iwi.c,v 1.117 2021/09/09 23:26:36 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_iwi.c,v 1.118 2022/05/23 13:53:37 rin Exp $"); /*- * Intel(R) PRO/Wireless 2200BG/2225BG/2915ABG driver @@ -661,11 +661,6 @@ iwi_reset_tx_ring(struct iwi_softc *sc, for (i = 0; i < ring->count; i++) { data = &ring->data[i]; - - if (data->m != NULL) { - m_freem(data->m); - data->m = NULL; - } if (data->map != NULL) { bus_dmamap_sync(sc->sc_dmat, data->map, 0, @@ -673,6 +668,11 @@ iwi_reset_tx_ring(struct iwi_softc *sc, bus_dmamap_unload(sc->sc_dmat, data->map); } + if (data->m != NULL) { + m_freem(data->m); + data->m = NULL; + } + if (data->ni != NULL) { ieee80211_free_node(data->ni); data->ni = NULL; @@ -702,14 +702,14 @@ iwi_free_tx_ring(struct iwi_softc *sc, s for (i = 0; i < ring->count; i++) { data = &ring->data[i]; - if (data->m != NULL) { - m_freem(data->m); - } - if (data->map != NULL) { bus_dmamap_unload(sc->sc_dmat, data->map); bus_dmamap_destroy(sc->sc_dmat, data->map); } + + if (data->m != NULL) { + m_freem(data->m); + } } } @@ -776,15 +776,14 @@ iwi_free_rx_ring(struct iwi_softc *sc, s for (i = 0; i < ring->count; i++) { data = &ring->data[i]; - if (data->m != NULL) { - m_freem(data->m); - } - if (data->map != NULL) { bus_dmamap_unload(sc->sc_dmat, data->map); bus_dmamap_destroy(sc->sc_dmat, data->map); } + if (data->m != NULL) { + m_freem(data->m); + } } } Index: src/sys/dev/pci/if_ixl.c diff -u src/sys/dev/pci/if_ixl.c:1.82 src/sys/dev/pci/if_ixl.c:1.83 --- src/sys/dev/pci/if_ixl.c:1.82 Thu Mar 31 06:23:18 2022 +++ src/sys/dev/pci/if_ixl.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: if_ixl.c,v 1.82 2022/03/31 06:23:18 yamaguchi Exp $ */ +/* $NetBSD: if_ixl.c,v 1.83 2022/05/23 13:53:37 rin Exp $ */ /* * Copyright (c) 2013-2015, Intel Corporation @@ -74,7 +74,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_ixl.c,v 1.82 2022/03/31 06:23:18 yamaguchi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_ixl.c,v 1.83 2022/05/23 13:53:37 rin Exp $"); #ifdef _KERNEL_OPT #include "opt_net_mpsafe.h" @@ -2532,9 +2532,6 @@ ixl_txr_free(struct ixl_softc *sc, struc unsigned int i; softint_disestablish(txr->txr_si); - while ((m = pcq_get(txr->txr_intrq)) != NULL) - m_freem(m); - pcq_destroy(txr->txr_intrq); maps = txr->txr_maps; for (i = 0; i < sc->sc_tx_ring_ndescs; i++) { @@ -2543,6 +2540,10 @@ ixl_txr_free(struct ixl_softc *sc, struc bus_dmamap_destroy(sc->sc_dmat, txm->txm_map); } + while ((m = pcq_get(txr->txr_intrq)) != NULL) + m_freem(m); + pcq_destroy(txr->txr_intrq); + ixl_dmamem_free(sc, &txr->txr_mem); mutex_destroy(&txr->txr_lock); kmem_free(maps, sizeof(maps[0]) * sc->sc_tx_ring_ndescs); Index: src/sys/dev/pci/if_sk.c diff -u src/sys/dev/pci/if_sk.c:1.110 src/sys/dev/pci/if_sk.c:1.111 --- src/sys/dev/pci/if_sk.c:1.110 Tue May 3 20:52:32 2022 +++ src/sys/dev/pci/if_sk.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: if_sk.c,v 1.110 2022/05/03 20:52:32 andvar Exp $ */ +/* $NetBSD: if_sk.c,v 1.111 2022/05/23 13:53:37 rin Exp $ */ /*- * Copyright (c) 2003 The NetBSD Foundation, Inc. @@ -115,7 +115,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_sk.c,v 1.110 2022/05/03 20:52:32 andvar Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_sk.c,v 1.111 2022/05/23 13:53:37 rin Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -2152,9 +2152,6 @@ sk_txeof(struct sk_if_softc *sc_if) if (sc_if->sk_cdata.sk_tx_chain[idx].sk_mbuf != NULL) { entry = sc_if->sk_cdata.sk_tx_map[idx]; - m_freem(sc_if->sk_cdata.sk_tx_chain[idx].sk_mbuf); - sc_if->sk_cdata.sk_tx_chain[idx].sk_mbuf = NULL; - bus_dmamap_sync(sc->sc_dmatag, entry->dmamap, 0, entry->dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE); @@ -2162,6 +2159,9 @@ sk_txeof(struct sk_if_softc *sc_if) SIMPLEQ_INSERT_TAIL(&sc_if->sk_txmap_head, entry, link); sc_if->sk_cdata.sk_tx_map[idx] = NULL; + + m_freem(sc_if->sk_cdata.sk_tx_chain[idx].sk_mbuf); + sc_if->sk_cdata.sk_tx_chain[idx].sk_mbuf = NULL; } sc_if->sk_cdata.sk_tx_cnt--; SK_INC(idx, SK_TX_RING_CNT); Index: src/sys/dev/pci/if_ti.c diff -u src/sys/dev/pci/if_ti.c:1.122 src/sys/dev/pci/if_ti.c:1.123 --- src/sys/dev/pci/if_ti.c:1.122 Wed Nov 10 16:17:34 2021 +++ src/sys/dev/pci/if_ti.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: if_ti.c,v 1.122 2021/11/10 16:17:34 msaitoh Exp $ */ +/* $NetBSD: if_ti.c,v 1.123 2022/05/23 13:53:37 rin Exp $ */ /* * Copyright (c) 1997, 1998, 1999 @@ -81,7 +81,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_ti.c,v 1.122 2021/11/10 16:17:34 msaitoh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_ti.c,v 1.123 2022/05/23 13:53:37 rin Exp $"); #include "opt_inet.h" @@ -913,12 +913,12 @@ ti_free_rx_ring_std(struct ti_softc *sc) for (i = 0; i < TI_STD_RX_RING_CNT; i++) { if (sc->ti_cdata.ti_rx_std_chain[i] != NULL) { - m_freem(sc->ti_cdata.ti_rx_std_chain[i]); - sc->ti_cdata.ti_rx_std_chain[i] = NULL; - /* if (sc->std_dmamap[i] == 0) panic() */ bus_dmamap_destroy(sc->sc_dmat, sc->std_dmamap[i]); sc->std_dmamap[i] = 0; + + m_freem(sc->ti_cdata.ti_rx_std_chain[i]); + sc->ti_cdata.ti_rx_std_chain[i] = NULL; } memset((char *)&sc->ti_rdata->ti_rx_std_ring[i], 0, sizeof(struct ti_rx_desc)); @@ -984,12 +984,12 @@ ti_free_rx_ring_mini(struct ti_softc *sc for (i = 0; i < TI_MINI_RX_RING_CNT; i++) { if (sc->ti_cdata.ti_rx_mini_chain[i] != NULL) { - m_freem(sc->ti_cdata.ti_rx_mini_chain[i]); - sc->ti_cdata.ti_rx_mini_chain[i] = NULL; - /* if (sc->mini_dmamap[i] == 0) panic() */ bus_dmamap_destroy(sc->sc_dmat, sc->mini_dmamap[i]); sc->mini_dmamap[i] = 0; + + m_freem(sc->ti_cdata.ti_rx_mini_chain[i]); + sc->ti_cdata.ti_rx_mini_chain[i] = NULL; } memset((char *)&sc->ti_rdata->ti_rx_mini_ring[i], 0, sizeof(struct ti_rx_desc)); @@ -1006,13 +1006,18 @@ ti_free_tx_ring(struct ti_softc *sc) for (i = 0; i < TI_TX_RING_CNT; i++) { if (sc->ti_cdata.ti_tx_chain[i] != NULL) { - m_freem(sc->ti_cdata.ti_tx_chain[i]); - sc->ti_cdata.ti_tx_chain[i] = NULL; + dma = sc->txdma[i]; + KDASSERT(dma != NULL); + bus_dmamap_sync(sc->sc_dmat, dma->dmamap, 0, + dma->dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE); + bus_dmamap_unload(sc->sc_dmat, dma->dmamap); - /* if (sc->txdma[i] == 0) panic() */ SIMPLEQ_INSERT_HEAD(&sc->txdma_list, sc->txdma[i], link); - sc->txdma[i] = 0; + sc->txdma[i] = NULL; + + m_freem(sc->ti_cdata.ti_tx_chain[i]); + sc->ti_cdata.ti_tx_chain[i] = NULL; } memset((char *)&sc->ti_rdata->ti_tx_ring[i], 0, sizeof(struct ti_tx_desc)); @@ -2070,9 +2075,6 @@ ti_txeof_tigon1(struct ti_softc *sc) if (cur_tx->ti_flags & TI_BDFLAG_END) if_statinc(ifp, if_opackets); if (sc->ti_cdata.ti_tx_chain[idx] != NULL) { - m_freem(sc->ti_cdata.ti_tx_chain[idx]); - sc->ti_cdata.ti_tx_chain[idx] = NULL; - dma = sc->txdma[idx]; KDASSERT(dma != NULL); bus_dmamap_sync(sc->sc_dmat, dma->dmamap, 0, @@ -2081,6 +2083,9 @@ ti_txeof_tigon1(struct ti_softc *sc) SIMPLEQ_INSERT_HEAD(&sc->txdma_list, dma, link); sc->txdma[idx] = NULL; + + m_freem(sc->ti_cdata.ti_tx_chain[idx]); + sc->ti_cdata.ti_tx_chain[idx] = NULL; } sc->ti_txcnt--; TI_INC(sc->ti_tx_saved_considx, TI_TX_RING_CNT); @@ -2115,9 +2120,6 @@ ti_txeof_tigon2(struct ti_softc *sc) if (cur_tx->ti_flags & TI_BDFLAG_END) if_statinc(ifp, if_opackets); if (sc->ti_cdata.ti_tx_chain[idx] != NULL) { - m_freem(sc->ti_cdata.ti_tx_chain[idx]); - sc->ti_cdata.ti_tx_chain[idx] = NULL; - dma = sc->txdma[idx]; KDASSERT(dma != NULL); bus_dmamap_sync(sc->sc_dmat, dma->dmamap, 0, @@ -2126,6 +2128,9 @@ ti_txeof_tigon2(struct ti_softc *sc) SIMPLEQ_INSERT_HEAD(&sc->txdma_list, dma, link); sc->txdma[idx] = NULL; + + m_freem(sc->ti_cdata.ti_tx_chain[idx]); + sc->ti_cdata.ti_tx_chain[idx] = NULL; } cnt++; sc->ti_txcnt--; Index: src/sys/dev/pci/if_vge.c diff -u src/sys/dev/pci/if_vge.c:1.83 src/sys/dev/pci/if_vge.c:1.84 --- src/sys/dev/pci/if_vge.c:1.83 Sat Jan 22 19:09:21 2022 +++ src/sys/dev/pci/if_vge.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: if_vge.c,v 1.83 2022/01/22 19:09:21 martin Exp $ */ +/* $NetBSD: if_vge.c,v 1.84 2022/05/23 13:53:37 rin Exp $ */ /*- * Copyright (c) 2004 @@ -35,7 +35,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_vge.c,v 1.83 2022/01/22 19:09:21 martin Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_vge.c,v 1.84 2022/05/23 13:53:37 rin Exp $"); /* * VIA Networking Technologies VT612x PCI gigabit ethernet NIC driver. @@ -1382,11 +1382,11 @@ vge_txeof(struct vge_softc *sc) } txs = &sc->sc_txsoft[idx]; - m_freem(txs->txs_mbuf); - txs->txs_mbuf = NULL; bus_dmamap_sync(sc->sc_dmat, txs->txs_dmamap, 0, txs->txs_dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE); bus_dmamap_unload(sc->sc_dmat, txs->txs_dmamap); + m_freem(txs->txs_mbuf); + txs->txs_mbuf = NULL; net_stat_ref_t nsr = IF_STAT_GETREF(ifp); if (txstat & (VGE_TDSTS_EXCESSCOLL | VGE_TDSTS_COLL)) if_statinc_ref(nsr, if_collisions); Index: src/sys/dev/pci/ubsec.c diff -u src/sys/dev/pci/ubsec.c:1.59 src/sys/dev/pci/ubsec.c:1.60 --- src/sys/dev/pci/ubsec.c:1.59 Sun May 22 11:39:27 2022 +++ src/sys/dev/pci/ubsec.c Mon May 23 13:53:37 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: ubsec.c,v 1.59 2022/05/22 11:39:27 riastradh Exp $ */ +/* $NetBSD: ubsec.c,v 1.60 2022/05/23 13:53:37 rin Exp $ */ /* $FreeBSD: src/sys/dev/ubsec/ubsec.c,v 1.6.2.6 2003/01/23 21:06:43 sam Exp $ */ /* $OpenBSD: ubsec.c,v 1.143 2009/03/27 13:31:30 reyk Exp$ */ @@ -35,7 +35,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: ubsec.c,v 1.59 2022/05/22 11:39:27 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: ubsec.c,v 1.60 2022/05/23 13:53:37 rin Exp $"); #undef UBSEC_DEBUG @@ -1753,9 +1753,6 @@ ubsec_process(void *arg, struct cryptop errout: if (q != NULL) { - if ((q->q_dst_m != NULL) && (q->q_src_m != q->q_dst_m)) - m_freem(q->q_dst_m); - if (q->q_dst_map != NULL && q->q_dst_map != q->q_src_map) { bus_dmamap_unload(sc->sc_dmat, q->q_dst_map); } @@ -1763,6 +1760,9 @@ errout: bus_dmamap_unload(sc->sc_dmat, q->q_src_map); } + if ((q->q_dst_m != NULL) && (q->q_src_m != q->q_dst_m)) + m_freem(q->q_dst_m); + mutex_spin_enter(&sc->sc_mtx); SIMPLEQ_INSERT_TAIL(&sc->sc_freequeue, q, q_next); mutex_spin_exit(&sc->sc_mtx); Index: src/sys/dev/pci/bktr/bktr_os.c diff -u src/sys/dev/pci/bktr/bktr_os.c:1.68 src/sys/dev/pci/bktr/bktr_os.c:1.69 --- src/sys/dev/pci/bktr/bktr_os.c:1.68 Sun Dec 9 11:22:35 2018 +++ src/sys/dev/pci/bktr/bktr_os.c Mon May 23 13:53:37 2022 @@ -1,6 +1,6 @@ /* $SourceForge: bktr_os.c,v 1.5 2003/03/11 23:11:25 thomasklausner Exp $ */ -/* $NetBSD: bktr_os.c,v 1.68 2018/12/09 11:22:35 jdolecek Exp $ */ +/* $NetBSD: bktr_os.c,v 1.69 2022/05/23 13:53:37 rin Exp $ */ /* $FreeBSD: src/sys/dev/bktr/bktr_os.c,v 1.20 2000/10/20 08:16:53 roger Exp$ */ /* @@ -51,7 +51,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: bktr_os.c,v 1.68 2018/12/09 11:22:35 jdolecek Exp $"); +__KERNEL_RCSID(0, "$NetBSD: bktr_os.c,v 1.69 2022/05/23 13:53:37 rin Exp $"); #ifdef __FreeBSD__ #include "bktr.h" @@ -1624,6 +1624,7 @@ free_bktr_mem(bktr_ptr_t bktr, bus_dmama { bus_dma_tag_t dmat = bktr->dmat; + bus_dmamap_unload(dmat, dmap); #ifdef __NetBSD__ bus_dmamem_unmap(dmat, (void *)kva, dmap->dm_mapsize); #else