diff options
author | Jason Wright <jason@cvs.openbsd.org> | 2003-10-10 18:05:13 +0000 |
---|---|---|
committer | Jason Wright <jason@cvs.openbsd.org> | 2003-10-10 18:05:13 +0000 |
commit | a9c36dbd56599b4e72744bdbce5bf6f3022a9904 (patch) | |
tree | d37c0ad83a2117c03965d9c50d1739d8ffdf427f | |
parent | c7c38e279d4263a70d6be27625516210777ef25e (diff) |
don't use vtophys on rx lists any more
-rw-r--r-- | sys/dev/pci/if_vr.c | 34 | ||||
-rw-r--r-- | sys/dev/pci/if_vrreg.h | 4 |
2 files changed, 21 insertions, 17 deletions
diff --git a/sys/dev/pci/if_vr.c b/sys/dev/pci/if_vr.c index 57c2d88ef8c..312b36fbae7 100644 --- a/sys/dev/pci/if_vr.c +++ b/sys/dev/pci/if_vr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_vr.c,v 1.32 2003/10/07 12:42:07 miod Exp $ */ +/* $OpenBSD: if_vr.c,v 1.33 2003/10/10 18:05:12 jason Exp $ */ /* * Copyright (c) 1997, 1998 @@ -87,6 +87,8 @@ #include <net/bpf.h> #endif +#include <machine/bus.h> + #include <uvm/uvm_extern.h> /* for vtophys */ #include <dev/mii/mii.h> @@ -678,8 +680,6 @@ vr_attach(parent, self, aux) struct ifnet *ifp = &sc->arpcom.ac_if; bus_addr_t iobase; bus_size_t iosize; - bus_dma_segment_t seg; - bus_dmamap_t dmamap; int rseg; caddr_t kva; @@ -810,30 +810,30 @@ vr_attach(parent, self, aux) sc->sc_dmat = pa->pa_dmat; if (bus_dmamem_alloc(sc->sc_dmat, sizeof(struct vr_list_data), - PAGE_SIZE, 0, &seg, 1, &rseg, BUS_DMA_NOWAIT)) { + PAGE_SIZE, 0, &sc->sc_listseg, 1, &rseg, BUS_DMA_NOWAIT)) { printf("%s: can't alloc list\n", sc->sc_dev.dv_xname); goto fail; } - if (bus_dmamem_map(sc->sc_dmat, &seg, rseg, sizeof(struct vr_list_data), - &kva, BUS_DMA_NOWAIT)) { + if (bus_dmamem_map(sc->sc_dmat, &sc->sc_listseg, rseg, + sizeof(struct vr_list_data), &kva, BUS_DMA_NOWAIT)) { printf("%s: can't map dma buffers (%d bytes)\n", sc->sc_dev.dv_xname, sizeof(struct vr_list_data)); - bus_dmamem_free(sc->sc_dmat, &seg, rseg); + bus_dmamem_free(sc->sc_dmat, &sc->sc_listseg, rseg); goto fail; } if (bus_dmamap_create(sc->sc_dmat, sizeof(struct vr_list_data), 1, - sizeof(struct vr_list_data), 0, BUS_DMA_NOWAIT, &dmamap)) { + sizeof(struct vr_list_data), 0, BUS_DMA_NOWAIT, &sc->sc_listmap)) { printf("%s: can't create dma map\n", sc->sc_dev.dv_xname); bus_dmamem_unmap(sc->sc_dmat, kva, sizeof(struct vr_list_data)); - bus_dmamem_free(sc->sc_dmat, &seg, rseg); + bus_dmamem_free(sc->sc_dmat, &sc->sc_listseg, rseg); goto fail; } - if (bus_dmamap_load(sc->sc_dmat, dmamap, kva, + if (bus_dmamap_load(sc->sc_dmat, sc->sc_listmap, kva, sizeof(struct vr_list_data), NULL, BUS_DMA_NOWAIT)) { printf("%s: can't load dma map\n", sc->sc_dev.dv_xname); - bus_dmamap_destroy(sc->sc_dmat, dmamap); + bus_dmamap_destroy(sc->sc_dmat, sc->sc_listmap); bus_dmamem_unmap(sc->sc_dmat, kva, sizeof(struct vr_list_data)); - bus_dmamem_free(sc->sc_dmat, &seg, rseg); + bus_dmamem_free(sc->sc_dmat, &sc->sc_listseg, rseg); goto fail; } sc->vr_ldata = (struct vr_list_data *)kva; @@ -934,14 +934,16 @@ vr_list_rx_init(sc) return(ENOBUFS); if (i == (VR_RX_LIST_CNT - 1)) { cd->vr_rx_chain[i].vr_nextdesc = - &cd->vr_rx_chain[0]; + &cd->vr_rx_chain[0]; ld->vr_rx_list[i].vr_next = - vtophys(&ld->vr_rx_list[0]); + sc->sc_listmap->dm_segs[0].ds_addr + + offsetof(struct vr_list_data, vr_rx_list[0]); } else { cd->vr_rx_chain[i].vr_nextdesc = - &cd->vr_rx_chain[i + 1]; + &cd->vr_rx_chain[i + 1]; ld->vr_rx_list[i].vr_next = - vtophys(&ld->vr_rx_list[i + 1]); + sc->sc_listmap->dm_segs[0].ds_addr + + offsetof(struct vr_list_data, vr_rx_list[i + 1]); } } diff --git a/sys/dev/pci/if_vrreg.h b/sys/dev/pci/if_vrreg.h index 8602ea1fedc..141d738dd13 100644 --- a/sys/dev/pci/if_vrreg.h +++ b/sys/dev/pci/if_vrreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_vrreg.h,v 1.7 2003/02/19 14:38:23 miod Exp $ */ +/* $OpenBSD: if_vrreg.h,v 1.8 2003/10/10 18:05:12 jason Exp $ */ /* * Copyright (c) 1997, 1998 @@ -467,6 +467,8 @@ struct vr_softc { struct vr_chain_data vr_cdata; struct mii_data sc_mii; struct timeout sc_to; + bus_dmamap_t sc_listmap; /* descriptor list map */ + bus_dma_segment_t sc_listseg; }; #define VR_F_RESTART 0x01 /* Restart unit on next tick */ |