diff options
author | cognet <cognet@FreeBSD.org> | 2003-02-26 16:11:18 +0000 |
---|---|---|
committer | cognet <cognet@FreeBSD.org> | 2003-02-26 16:11:18 +0000 |
commit | 9280077d45d02ebef0ad3094c1736288ca9d2def (patch) | |
tree | c6c98bdd0df71cfa131b478f91249aa9613a8604 | |
parent | 39b6d14ab492b391ff4eee3737dd03a2ddbb33fa (diff) | |
download | FreeBSD-src-9280077d45d02ebef0ad3094c1736288ca9d2def.zip FreeBSD-src-9280077d45d02ebef0ad3094c1736288ca9d2def.tar.gz |
Unbreak emu10k1 by properly using the buffer address.
New contestant for the lamest commit of the year award: cognet
-rw-r--r-- | sys/dev/sound/pci/emu10k1.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/sys/dev/sound/pci/emu10k1.c b/sys/dev/sound/pci/emu10k1.c index db8cf73..19980ff 100644 --- a/sys/dev/sound/pci/emu10k1.c +++ b/sys/dev/sound/pci/emu10k1.c @@ -1022,9 +1022,9 @@ emu_intr(void *p) static void emu_setmap(void *arg, bus_dma_segment_t *segs, int nseg, int error) { - void **phys = arg; + bus_addr_t *phys = arg; - *phys = error? 0 : (void *)segs->ds_addr; + *phys = error? 0 : (bus_addr_t)segs->ds_addr; if (bootverbose) { printf("emu: setmap (%lx, %lx), nseg=%d, error=%d\n", @@ -1043,7 +1043,7 @@ emu_malloc(struct sc_info *sc, u_int32_t sz, bus_addr_t *addr) if (bus_dmamem_alloc(sc->parent_dmat, &buf, BUS_DMA_NOWAIT, &map)) return NULL; if (bus_dmamap_load(sc->parent_dmat, map, buf, sz, emu_setmap, addr, 0) - || !addr) + || !*addr) return NULL; return buf; } @@ -1094,7 +1094,7 @@ emu_memalloc(struct sc_info *sc, u_int32_t sz, bus_addr_t *addr) ofs = 0; for (idx = start; idx < start + blksz; idx++) { mem->bmap[idx >> 3] |= 1 << (idx & 7); - tmp = (u_int32_t)(u_long)((u_int8_t *)&blk->buf_addr + ofs); + tmp = (u_int32_t)(u_long)((u_int8_t *)blk->buf_addr + ofs); /* printf("pte[%d] -> %x phys, %x virt\n", idx, tmp, ((u_int32_t)buf) + ofs); */ mem->ptb_pages[idx] = (tmp << 1) | idx; ofs += EMUPAGESIZE; |