Don't provide mutexes for static busdma allocations.

This commit is contained in:
scottl 2003-08-11 03:39:41 +00:00
parent 2a20cf3396
commit 39ed719ae9

View File

@ -442,9 +442,8 @@ mly_pci_attach(struct mly_softc *sc)
NULL, NULL, /* filter, filterarg */ NULL, NULL, /* filter, filterarg */
sizeof(union mly_command_packet) * MLY_MAX_COMMANDS, 1, /* maxsize, nsegments */ sizeof(union mly_command_packet) * MLY_MAX_COMMANDS, 1, /* maxsize, nsegments */
BUS_SPACE_MAXSIZE_32BIT, /* maxsegsize */ BUS_SPACE_MAXSIZE_32BIT, /* maxsegsize */
0, /* flags */ BUS_DMA_ALLOCNOW, /* flags */
busdma_lock_mutex, /* lockfunc */ NULL, NULL, /* lockfunc, lockarg */
&Giant, /* lockarg */
&sc->mly_packet_dmat)) { &sc->mly_packet_dmat)) {
mly_printf(sc, "can't allocate command packet DMA tag\n"); mly_printf(sc, "can't allocate command packet DMA tag\n");
goto fail; goto fail;
@ -583,17 +582,16 @@ mly_sg_map(struct mly_softc *sc)
* Create a single tag describing a region large enough to hold all of * Create a single tag describing a region large enough to hold all of
* the s/g lists we will need. * the s/g lists we will need.
*/ */
segsize = sizeof(struct mly_sg_entry) * MLY_MAX_COMMANDS * MLY_MAX_SGENTRIES; segsize = sizeof(struct mly_sg_entry) * MLY_MAX_COMMANDS *MLY_MAX_SGENTRIES;
if (bus_dma_tag_create(sc->mly_parent_dmat, /* parent */ if (bus_dma_tag_create(sc->mly_parent_dmat, /* parent */
1, 0, /* alignment, boundary */ 1, 0, /* alignment,boundary */
BUS_SPACE_MAXADDR, /* lowaddr */ BUS_SPACE_MAXADDR, /* lowaddr */
BUS_SPACE_MAXADDR, /* highaddr */ BUS_SPACE_MAXADDR, /* highaddr */
NULL, NULL, /* filter, filterarg */ NULL, NULL, /* filter, filterarg */
segsize, 1, /* maxsize, nsegments */ segsize, 1, /* maxsize, nsegments */
BUS_SPACE_MAXSIZE_32BIT, /* maxsegsize */ BUS_SPACE_MAXSIZE_32BIT, /* maxsegsize */
0, /* flags */ BUS_DMA_ALLOCNOW, /* flags */
busdma_lock_mutex, /* lockfunc */ NULL, NULL, /* lockfunc, lockarg */
&Giant, /* lockarg */
&sc->mly_sg_dmat)) { &sc->mly_sg_dmat)) {
mly_printf(sc, "can't allocate scatter/gather DMA tag\n"); mly_printf(sc, "can't allocate scatter/gather DMA tag\n");
return(ENOMEM); return(ENOMEM);
@ -606,11 +604,14 @@ mly_sg_map(struct mly_softc *sc)
* XXX this assumes we can get enough space for all the s/g maps in one * XXX this assumes we can get enough space for all the s/g maps in one
* contiguous slab. * contiguous slab.
*/ */
if (bus_dmamem_alloc(sc->mly_sg_dmat, (void **)&sc->mly_sg_table, BUS_DMA_NOWAIT, &sc->mly_sg_dmamap)) { if (bus_dmamem_alloc(sc->mly_sg_dmat, (void **)&sc->mly_sg_table,
BUS_DMA_NOWAIT, &sc->mly_sg_dmamap)) {
mly_printf(sc, "can't allocate s/g table\n"); mly_printf(sc, "can't allocate s/g table\n");
return(ENOMEM); return(ENOMEM);
} }
bus_dmamap_load(sc->mly_sg_dmat, sc->mly_sg_dmamap, sc->mly_sg_table, segsize, mly_sg_map_helper, sc, 0); if (bus_dmamap_load(sc->mly_sg_dmat, sc->mly_sg_dmamap, sc->mly_sg_table,
segsize, mly_sg_map_helper, sc, BUS_DMA_NOWAIT) != 0)
return (ENOMEM);
return(0); return(0);
} }
@ -640,15 +641,14 @@ mly_mmbox_map(struct mly_softc *sc)
* memory mailbox structure. * memory mailbox structure.
*/ */
if (bus_dma_tag_create(sc->mly_parent_dmat, /* parent */ if (bus_dma_tag_create(sc->mly_parent_dmat, /* parent */
1, 0, /* alignment, boundary */ 1, 0, /* alignment,boundary */
BUS_SPACE_MAXADDR, /* lowaddr */ BUS_SPACE_MAXADDR, /* lowaddr */
BUS_SPACE_MAXADDR, /* highaddr */ BUS_SPACE_MAXADDR, /* highaddr */
NULL, NULL, /* filter, filterarg */ NULL, NULL, /* filter, filterarg */
sizeof(struct mly_mmbox), 1, /* maxsize, nsegments */ sizeof(struct mly_mmbox), 1, /* maxsize, nsegments */
BUS_SPACE_MAXSIZE_32BIT, /* maxsegsize */ BUS_SPACE_MAXSIZE_32BIT, /* maxsegsize */
0, /* flags */ BUS_DMA_ALLOCNOW, /* flags */
busdma_lock_mutex, /* lockfunc */ NULL, NULL, /* lockfunc, lockarg */
&Giant, /* lockarg */
&sc->mly_mmbox_dmat)) { &sc->mly_mmbox_dmat)) {
mly_printf(sc, "can't allocate memory mailbox DMA tag\n"); mly_printf(sc, "can't allocate memory mailbox DMA tag\n");
return(ENOMEM); return(ENOMEM);
@ -661,8 +661,10 @@ mly_mmbox_map(struct mly_softc *sc)
mly_printf(sc, "can't allocate memory mailbox\n"); mly_printf(sc, "can't allocate memory mailbox\n");
return(ENOMEM); return(ENOMEM);
} }
bus_dmamap_load(sc->mly_mmbox_dmat, sc->mly_mmbox_dmamap, sc->mly_mmbox, sizeof(struct mly_mmbox), if (bus_dmamap_load(sc->mly_mmbox_dmat, sc->mly_mmbox_dmamap, sc->mly_mmbox,
mly_mmbox_map_helper, sc, 0); sizeof(struct mly_mmbox), mly_mmbox_map_helper, sc,
BUS_DMA_NOWAIT) != 0)
return (ENOMEM);
bzero(sc->mly_mmbox, sizeof(*sc->mly_mmbox)); bzero(sc->mly_mmbox, sizeof(*sc->mly_mmbox));
return(0); return(0);
@ -1755,9 +1757,10 @@ mly_alloc_commands(struct mly_softc *sc)
BUS_DMA_NOWAIT, &sc->mly_packetmap)) { BUS_DMA_NOWAIT, &sc->mly_packetmap)) {
return(ENOMEM); return(ENOMEM);
} }
bus_dmamap_load(sc->mly_packet_dmat, sc->mly_packetmap, sc->mly_packet, if (bus_dmamap_load(sc->mly_packet_dmat, sc->mly_packetmap, sc->mly_packet,
ncmd * sizeof(union mly_command_packet), ncmd * sizeof(union mly_command_packet),
mly_alloc_commands_map, sc, 0); mly_alloc_commands_map, sc, BUS_DMA_NOWAIT) != 0)
return (ENOMEM);
for (i = 0; i < ncmd; i++) { for (i = 0; i < ncmd; i++) {
mc = &sc->mly_command[i]; mc = &sc->mly_command[i];