tag | line | file | source code |
dmap | 500 | drivers/sound/dev_table.h | int sound_alloc_dmap (int dev, struct dma_buffparms *dmap, int chan); |
dmap | 501 | drivers/sound/dev_table.h | void sound_free_dmap (int dev, struct dma_buffparms *dmap); |
dmap | 502 | drivers/sound/dev_table.h | extern int soud_map_buffer (int dev, struct dma_buffparms *dmap, buffmem_desc *info); |
dmap | 507 | drivers/sound/dev_table.h | int sound_start_dma ( int dev, struct dma_buffparms *dmap, int chan, |
dmap | 510 | drivers/sound/dev_table.h | void sound_dma_intr (int dev, struct dma_buffparms *dmap, int chan); |
dmap | 65 | drivers/sound/dmabuf.c | reorganize_buffers (int dev, struct dma_buffparms *dmap) |
dmap | 76 | drivers/sound/dmabuf.c | if (dmap->fragment_size == 0) |
dmap | 84 | drivers/sound/dmabuf.c | dmap->neutral_byte = 0x80; |
dmap | 86 | drivers/sound/dmabuf.c | dmap->neutral_byte = 0x00; |
dmap | 114 | drivers/sound/dmabuf.c | if (dmap->subdivision == 0) /* Not already set */ |
dmap | 115 | drivers/sound/dmabuf.c | dmap->subdivision = 1; /* Init to default value */ |
dmap | 117 | drivers/sound/dmabuf.c | bsz /= dmap->subdivision; |
dmap | 122 | drivers/sound/dmabuf.c | dmap->fragment_size = bsz; |
dmap | 130 | drivers/sound/dmabuf.c | if (dmap->fragment_size > (audio_devs[dev]->buffsize / 2)) |
dmap | 131 | drivers/sound/dmabuf.c | dmap->fragment_size = (audio_devs[dev]->buffsize / 2); |
dmap | 132 | drivers/sound/dmabuf.c | bsz = dmap->fragment_size; |
dmap | 140 | drivers/sound/dmabuf.c | if (n > dmap->max_fragments) |
dmap | 141 | drivers/sound/dmabuf.c | n = dmap->max_fragments; |
dmap | 142 | drivers/sound/dmabuf.c | dmap->nbufs = n; |
dmap | 143 | drivers/sound/dmabuf.c | dmap->bytes_in_use = n * bsz; |
dmap | 145 | drivers/sound/dmabuf.c | for (i = 0; i < dmap->nbufs; i++) |
dmap | 147 | drivers/sound/dmabuf.c | dmap->counts[i] = 0; |
dmap | 150 | drivers/sound/dmabuf.c | dmap->flags |= DMA_ALLOC_DONE; |
dmap | 154 | drivers/sound/dmabuf.c | dma_init_buffers (int dev, struct dma_buffparms *dmap) |
dmap | 156 | drivers/sound/dmabuf.c | if (dmap == audio_devs[dev]->dmap_out) |
dmap | 163 | drivers/sound/dmabuf.c | dmap->flags = DMA_BUSY; /* Other flags off */ |
dmap | 164 | drivers/sound/dmabuf.c | dmap->qlen = dmap->qhead = dmap->qtail = 0; |
dmap | 165 | drivers/sound/dmabuf.c | dmap->nbufs = 1; |
dmap | 166 | drivers/sound/dmabuf.c | dmap->bytes_in_use = audio_devs[dev]->buffsize; |
dmap | 168 | drivers/sound/dmabuf.c | dmap->dma_mode = DMODE_NONE; |
dmap | 169 | drivers/sound/dmabuf.c | dmap->mapping_flags = 0; |
dmap | 170 | drivers/sound/dmabuf.c | dmap->neutral_byte = 0x00; |
dmap | 174 | drivers/sound/dmabuf.c | open_dmap (int dev, int mode, struct dma_buffparms *dmap, int chan) |
dmap | 176 | drivers/sound/dmabuf.c | if (dmap->flags & DMA_BUSY) |
dmap | 182 | drivers/sound/dmabuf.c | if ((err = sound_alloc_dmap (dev, dmap, chan)) < 0) |
dmap | 186 | drivers/sound/dmabuf.c | if (dmap->raw_buf == NULL) |
dmap | 195 | drivers/sound/dmabuf.c | dmap->open_mode = mode; |
dmap | 196 | drivers/sound/dmabuf.c | dmap->subdivision = dmap->underrun_count = 0; |
dmap | 197 | drivers/sound/dmabuf.c | dmap->fragment_size = 0; |
dmap | 198 | drivers/sound/dmabuf.c | dmap->max_fragments = 65536; /* Just a large value */ |
dmap | 199 | drivers/sound/dmabuf.c | dmap->byte_counter = 0; |
dmap | 201 | drivers/sound/dmabuf.c | dma_init_buffers (dev, dmap); |
dmap | 207 | drivers/sound/dmabuf.c | close_dmap (int dev, struct dma_buffparms *dmap, int chan) |
dmap | 211 | drivers/sound/dmabuf.c | if (dmap->flags & DMA_BUSY) |
dmap | 212 | drivers/sound/dmabuf.c | dmap->dma_mode = DMODE_NONE; |
dmap | 213 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_BUSY; |
dmap | 215 | drivers/sound/dmabuf.c | sound_free_dmap (dev, dmap); |
dmap | 431 | drivers/sound/dmabuf.c | activate_recording (int dev, struct dma_buffparms *dmap) |
dmap | 436 | drivers/sound/dmabuf.c | if (dmap->flags & DMA_RESTART) |
dmap | 439 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_RESTART; |
dmap | 442 | drivers/sound/dmabuf.c | if (dmap->dma_mode == DMODE_OUTPUT) /* Direction change */ |
dmap | 446 | drivers/sound/dmabuf.c | dmap->dma_mode = DMODE_NONE; |
dmap | 449 | drivers/sound/dmabuf.c | if (!(dmap->flags & DMA_ALLOC_DONE)) |
dmap | 450 | drivers/sound/dmabuf.c | reorganize_buffers (dev, dmap); |
dmap | 452 | drivers/sound/dmabuf.c | if (!dmap->dma_mode) |
dmap | 457 | drivers/sound/dmabuf.c | dmap->fragment_size, dmap->nbufs)) < 0) |
dmap | 461 | drivers/sound/dmabuf.c | dmap->dma_mode = DMODE_INPUT; |
dmap | 464 | drivers/sound/dmabuf.c | if (!(dmap->flags & DMA_ACTIVE)) |
dmap | 466 | drivers/sound/dmabuf.c | audio_devs[dev]->start_input (dev, dmap->raw_buf_phys + |
dmap | 467 | drivers/sound/dmabuf.c | dmap->qtail * dmap->fragment_size, |
dmap | 468 | drivers/sound/dmabuf.c | dmap->fragment_size, 0, |
dmap | 470 | drivers/sound/dmabuf.c | !(dmap->flags & DMA_STARTED)); |
dmap | 471 | drivers/sound/dmabuf.c | dmap->flags |= DMA_ACTIVE | DMA_STARTED; |
dmap | 484 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = audio_devs[dev]->dmap_in; |
dmap | 488 | drivers/sound/dmabuf.c | if (!dmap->qlen) |
dmap | 492 | drivers/sound/dmabuf.c | if ((err = activate_recording (dev, dmap)) < 0) |
dmap | 546 | drivers/sound/dmabuf.c | if (!dmap->qlen) |
dmap | 549 | drivers/sound/dmabuf.c | *buf = &dmap->raw_buf[dmap->qhead * dmap->fragment_size + dmap->counts[dmap->qhead]]; |
dmap | 550 | drivers/sound/dmabuf.c | *len = dmap->fragment_size - dmap->counts[dmap->qhead]; |
dmap | 552 | drivers/sound/dmabuf.c | return dmap->qhead; |
dmap | 558 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = audio_devs[dev]->dmap_in; |
dmap | 560 | drivers/sound/dmabuf.c | int p = dmap->counts[dmap->qhead] + c; |
dmap | 562 | drivers/sound/dmabuf.c | if (p >= dmap->fragment_size) |
dmap | 564 | drivers/sound/dmabuf.c | dmap->counts[dmap->qhead] = 0; |
dmap | 565 | drivers/sound/dmabuf.c | if (dmap->qlen <= 0 || dmap->qlen > dmap->nbufs) |
dmap | 567 | drivers/sound/dmabuf.c | dev, dmap->qlen, dmap->nbufs); |
dmap | 568 | drivers/sound/dmabuf.c | dmap->qlen--; |
dmap | 569 | drivers/sound/dmabuf.c | dmap->qhead = (dmap->qhead + 1) % dmap->nbufs; |
dmap | 572 | drivers/sound/dmabuf.c | dmap->counts[dmap->qhead] = p; |
dmap | 578 | drivers/sound/dmabuf.c | dma_subdivide (int dev, struct dma_buffparms *dmap, ioctl_arg arg, int fact) |
dmap | 582 | drivers/sound/dmabuf.c | fact = dmap->subdivision; |
dmap | 588 | drivers/sound/dmabuf.c | if (dmap->subdivision != 0 || |
dmap | 589 | drivers/sound/dmabuf.c | dmap->fragment_size) /* Loo late to change */ |
dmap | 598 | drivers/sound/dmabuf.c | dmap->subdivision = fact; |
dmap | 603 | drivers/sound/dmabuf.c | dma_set_fragment (int dev, struct dma_buffparms *dmap, ioctl_arg arg, int fact) |
dmap | 610 | drivers/sound/dmabuf.c | if (dmap->subdivision != 0 || |
dmap | 611 | drivers/sound/dmabuf.c | dmap->fragment_size) /* Loo late to change */ |
dmap | 626 | drivers/sound/dmabuf.c | dmap->fragment_size = (1 << bytes); |
dmap | 627 | drivers/sound/dmabuf.c | dmap->max_fragments = count; |
dmap | 629 | drivers/sound/dmabuf.c | if (dmap->fragment_size > audio_devs[dev]->buffsize) |
dmap | 630 | drivers/sound/dmabuf.c | dmap->fragment_size = audio_devs[dev]->buffsize; |
dmap | 632 | drivers/sound/dmabuf.c | if (dmap->fragment_size == audio_devs[dev]->buffsize && |
dmap | 634 | drivers/sound/dmabuf.c | dmap->fragment_size /= 2; /* Needs at least 2 buffers */ |
dmap | 636 | drivers/sound/dmabuf.c | dmap->subdivision = 1; /* Disable SNDCTL_DSP_SUBDIVIDE */ |
dmap | 641 | drivers/sound/dmabuf.c | get_buffer_pointer (int dev, int chan, struct dma_buffparms *dmap) |
dmap | 648 | drivers/sound/dmabuf.c | if (!(dmap->flags & DMA_ACTIVE)) |
dmap | 661 | drivers/sound/dmabuf.c | return dmap->bytes_in_use - pos; |
dmap | 664 | drivers/sound/dmabuf.c | pos = dmap->fragment_size - pos; |
dmap | 735 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = dmap_out; |
dmap | 740 | drivers/sound/dmabuf.c | dmap = dmap_in; |
dmap | 743 | drivers/sound/dmabuf.c | if (!(dmap->flags & DMA_ALLOC_DONE)) |
dmap | 744 | drivers/sound/dmabuf.c | reorganize_buffers (dev, dmap); |
dmap | 746 | drivers/sound/dmabuf.c | info->fragstotal = dmap->nbufs; |
dmap | 749 | drivers/sound/dmabuf.c | info->fragments = dmap->qlen; |
dmap | 756 | drivers/sound/dmabuf.c | info->fragments = dmap->nbufs - dmap->qlen; |
dmap | 772 | drivers/sound/dmabuf.c | else if (info->fragments > dmap->nbufs) |
dmap | 773 | drivers/sound/dmabuf.c | info->fragments = dmap->nbufs; |
dmap | 775 | drivers/sound/dmabuf.c | info->fragsize = dmap->fragment_size; |
dmap | 776 | drivers/sound/dmabuf.c | info->bytes = info->fragments * dmap->fragment_size; |
dmap | 778 | drivers/sound/dmabuf.c | if (cmd == SNDCTL_DSP_GETISPACE && dmap->qlen) |
dmap | 779 | drivers/sound/dmabuf.c | info->bytes -= dmap->counts[dmap->qhead]; |
dmap | 889 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = audio_devs[dev]->dmap_out; |
dmap | 891 | drivers/sound/dmabuf.c | if (dmap->qlen >= dmap->nbufs) /* No space at all */ |
dmap | 899 | drivers/sound/dmabuf.c | max = dmap->max_fragments; |
dmap | 900 | drivers/sound/dmabuf.c | len = dmap->qlen; |
dmap | 922 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = audio_devs[dev]->dmap_out; |
dmap | 925 | drivers/sound/dmabuf.c | if (dmap->dma_mode == DMODE_INPUT) /* Direction change */ |
dmap | 928 | drivers/sound/dmabuf.c | dmap->dma_mode = DMODE_NONE; |
dmap | 930 | drivers/sound/dmabuf.c | else if (dmap->flags & DMA_RESTART) /* Restart buffering */ |
dmap | 936 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_RESTART; |
dmap | 938 | drivers/sound/dmabuf.c | if (!(dmap->flags & DMA_ALLOC_DONE)) |
dmap | 939 | drivers/sound/dmabuf.c | reorganize_buffers (dev, dmap); |
dmap | 941 | drivers/sound/dmabuf.c | if (!dmap->dma_mode) |
dmap | 945 | drivers/sound/dmabuf.c | dmap->dma_mode = DMODE_OUTPUT; |
dmap | 947 | drivers/sound/dmabuf.c | dmap->fragment_size, dmap->nbufs)) < 0) |
dmap | 1018 | drivers/sound/dmabuf.c | *buf = dmap->raw_buf + dmap->qtail * dmap->fragment_size; |
dmap | 1019 | drivers/sound/dmabuf.c | *size = dmap->fragment_size; |
dmap | 1020 | drivers/sound/dmabuf.c | dmap->counts[dmap->qtail] = 0; |
dmap | 1022 | drivers/sound/dmabuf.c | return dmap->qtail; |
dmap | 1028 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = audio_devs[dev]->dmap_out; |
dmap | 1034 | drivers/sound/dmabuf.c | if (dmap != NULL) |
dmap | 1037 | drivers/sound/dmabuf.c | if (buff_no != dmap->qtail) |
dmap | 1038 | drivers/sound/dmabuf.c | printk ("Sound warning: DMA buffers out of sync %d != %d\n", buff_no, dmap->qtail); |
dmap | 1040 | drivers/sound/dmabuf.c | dmap->qlen++; |
dmap | 1041 | drivers/sound/dmabuf.c | if (dmap->qlen <= 0 || dmap->qlen > dmap->nbufs) |
dmap | 1043 | drivers/sound/dmabuf.c | dev, dmap->qlen, dmap->nbufs); |
dmap | 1045 | drivers/sound/dmabuf.c | dmap->counts[dmap->qtail] = l; |
dmap | 1047 | drivers/sound/dmabuf.c | if ((l != dmap->fragment_size) && |
dmap | 1050 | drivers/sound/dmabuf.c | dmap->flags |= DMA_RESTART; |
dmap | 1052 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_RESTART; |
dmap | 1054 | drivers/sound/dmabuf.c | dmap->qtail = (dmap->qtail + 1) % dmap->nbufs; |
dmap | 1057 | drivers/sound/dmabuf.c | if (!(dmap->flags & DMA_ACTIVE)) |
dmap | 1059 | drivers/sound/dmabuf.c | dmap->flags |= DMA_ACTIVE; |
dmap | 1060 | drivers/sound/dmabuf.c | audio_devs[dev]->output_block (dev, dmap->raw_buf_phys + |
dmap | 1061 | drivers/sound/dmabuf.c | dmap->qhead * dmap->fragment_size, |
dmap | 1062 | drivers/sound/dmabuf.c | dmap->counts[dmap->qhead], 0, |
dmap | 1064 | drivers/sound/dmabuf.c | !(dmap->flags & DMA_STARTED)); |
dmap | 1065 | drivers/sound/dmabuf.c | dmap->flags |= DMA_STARTED; |
dmap | 1078 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap; |
dmap | 1084 | drivers/sound/dmabuf.c | dmap = audio_devs[dev]->dmap_out; |
dmap | 1089 | drivers/sound/dmabuf.c | dmap = audio_devs[dev]->dmap_in; |
dmap | 1107 | drivers/sound/dmabuf.c | set_dma_addr (chan, dmap->raw_buf_phys); |
dmap | 1108 | drivers/sound/dmabuf.c | set_dma_count (chan, dmap->bytes_in_use); |
dmap | 1166 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = audio_devs[dev]->dmap_out; |
dmap | 1168 | drivers/sound/dmabuf.c | dmap->byte_counter += dmap->counts[dmap->qhead]; |
dmap | 1176 | drivers/sound/dmabuf.c | if (dmap->qlen <= 0 || dmap->qlen > dmap->nbufs) |
dmap | 1179 | drivers/sound/dmabuf.c | dev, dmap->qlen, dmap->nbufs); |
dmap | 1183 | drivers/sound/dmabuf.c | dmap->qlen--; |
dmap | 1184 | drivers/sound/dmabuf.c | dmap->qhead = (dmap->qhead + 1) % dmap->nbufs; |
dmap | 1185 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_ACTIVE; |
dmap | 1187 | drivers/sound/dmabuf.c | if (dmap->qlen) |
dmap | 1191 | drivers/sound/dmabuf.c | audio_devs[dev]->output_block (dev, dmap->raw_buf_phys + |
dmap | 1192 | drivers/sound/dmabuf.c | dmap->qhead * dmap->fragment_size, |
dmap | 1193 | drivers/sound/dmabuf.c | dmap->counts[dmap->qhead], 1, |
dmap | 1199 | drivers/sound/dmabuf.c | dmap->flags |= DMA_ACTIVE; |
dmap | 1203 | drivers/sound/dmabuf.c | dmap->underrun_count++; |
dmap | 1212 | drivers/sound/dmabuf.c | dmap->flags |= DMA_RESTART; |
dmap | 1214 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_RESTART; |
dmap | 1234 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap = audio_devs[dev]->dmap_in; |
dmap | 1236 | drivers/sound/dmabuf.c | dmap->byte_counter += dmap->fragment_size; |
dmap | 1242 | drivers/sound/dmabuf.c | if (dmap->qlen == (dmap->nbufs - 1)) |
dmap | 1245 | drivers/sound/dmabuf.c | dmap->underrun_count++; |
dmap | 1252 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_ACTIVE; |
dmap | 1254 | drivers/sound/dmabuf.c | dmap->flags |= DMA_RESTART; |
dmap | 1256 | drivers/sound/dmabuf.c | dmap->flags &= ~DMA_RESTART; |
dmap | 1260 | drivers/sound/dmabuf.c | dmap->qlen++; |
dmap | 1261 | drivers/sound/dmabuf.c | if (dmap->qlen <= 0 || dmap->qlen > dmap->nbufs) |
dmap | 1263 | drivers/sound/dmabuf.c | dev, dmap->qlen, dmap->nbufs); |
dmap | 1264 | drivers/sound/dmabuf.c | dmap->qtail = (dmap->qtail + 1) % dmap->nbufs; |
dmap | 1268 | drivers/sound/dmabuf.c | audio_devs[dev]->start_input (dev, dmap->raw_buf_phys + |
dmap | 1269 | drivers/sound/dmabuf.c | dmap->qtail * dmap->fragment_size, |
dmap | 1270 | drivers/sound/dmabuf.c | dmap->fragment_size, 1, |
dmap | 1277 | drivers/sound/dmabuf.c | dmap->flags |= DMA_ACTIVE; |
dmap | 1357 | drivers/sound/dmabuf.c | struct dma_buffparms *dmap; |
dmap | 1363 | drivers/sound/dmabuf.c | dmap = audio_devs[dev]->dmap_in; |
dmap | 1366 | drivers/sound/dmabuf.c | if (dmap->dma_mode != DMODE_INPUT) |
dmap | 1368 | drivers/sound/dmabuf.c | if ((audio_devs[dev]->flags & DMA_DUPLEX) && !dmap->qlen && |
dmap | 1376 | drivers/sound/dmabuf.c | activate_recording (dev, dmap); |
dmap | 1382 | drivers/sound/dmabuf.c | if (!dmap->qlen) |
dmap | 1395 | drivers/sound/dmabuf.c | dmap = audio_devs[dev]->dmap_out; |
dmap | 1398 | drivers/sound/dmabuf.c | if (dmap->dma_mode == DMODE_INPUT) |
dmap | 1403 | drivers/sound/dmabuf.c | if (dmap->dma_mode == DMODE_NONE) |
dmap | 534 | drivers/sound/soundcard.c | sound_alloc_dmap (int dev, struct dma_buffparms *dmap, int chan) |
dmap | 539 | drivers/sound/soundcard.c | if (dmap->raw_buf != NULL) |
dmap | 550 | drivers/sound/soundcard.c | dmap->raw_buf = NULL; |
dmap | 608 | drivers/sound/soundcard.c | dmap->raw_buf = start_addr; |
dmap | 609 | drivers/sound/soundcard.c | dmap->raw_buf_phys = virt_to_bus (start_addr); |
dmap | 611 | drivers/sound/soundcard.c | memset (dmap->raw_buf, 0x00, audio_devs[dev]->buffsize); |
dmap | 622 | drivers/sound/soundcard.c | sound_free_dmap (int dev, struct dma_buffparms *dmap) |
dmap | 624 | drivers/sound/soundcard.c | if (dmap->raw_buf == NULL) |
dmap | 634 | drivers/sound/soundcard.c | start_addr = (unsigned long) dmap->raw_buf; |
dmap | 642 | drivers/sound/soundcard.c | free_pages ((unsigned long) dmap->raw_buf, sz); |
dmap | 644 | drivers/sound/soundcard.c | dmap->raw_buf = NULL; |
dmap | 648 | drivers/sound/soundcard.c | soud_map_buffer (int dev, struct dma_buffparms *dmap, buffmem_desc * info) |