aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci/emu10k1/memory.c
diff options
context:
space:
mode:
Diffstat (limited to 'sound/pci/emu10k1/memory.c')
-rw-r--r--sound/pci/emu10k1/memory.c94
1 files changed, 49 insertions, 45 deletions
diff --git a/sound/pci/emu10k1/memory.c b/sound/pci/emu10k1/memory.c
index d42e4aeaa73a..68c795c03109 100644
--- a/sound/pci/emu10k1/memory.c
+++ b/sound/pci/emu10k1/memory.c
@@ -48,7 +48,7 @@
48#define set_silent_ptb(emu,page) __set_ptb_entry(emu,page,emu->silent_page.addr) 48#define set_silent_ptb(emu,page) __set_ptb_entry(emu,page,emu->silent_page.addr)
49#else 49#else
50/* fill PTB entries -- we need to fill UNIT_PAGES entries */ 50/* fill PTB entries -- we need to fill UNIT_PAGES entries */
51static inline void set_ptb_entry(emu10k1_t *emu, int page, dma_addr_t addr) 51static inline void set_ptb_entry(struct snd_emu10k1 *emu, int page, dma_addr_t addr)
52{ 52{
53 int i; 53 int i;
54 page *= UNIT_PAGES; 54 page *= UNIT_PAGES;
@@ -57,7 +57,7 @@ static inline void set_ptb_entry(emu10k1_t *emu, int page, dma_addr_t addr)
57 addr += EMUPAGESIZE; 57 addr += EMUPAGESIZE;
58 } 58 }
59} 59}
60static inline void set_silent_ptb(emu10k1_t *emu, int page) 60static inline void set_silent_ptb(struct snd_emu10k1 *emu, int page)
61{ 61{
62 int i; 62 int i;
63 page *= UNIT_PAGES; 63 page *= UNIT_PAGES;
@@ -70,14 +70,14 @@ static inline void set_silent_ptb(emu10k1_t *emu, int page)
70 70
71/* 71/*
72 */ 72 */
73static int synth_alloc_pages(emu10k1_t *hw, emu10k1_memblk_t *blk); 73static int synth_alloc_pages(struct snd_emu10k1 *hw, struct snd_emu10k1_memblk *blk);
74static int synth_free_pages(emu10k1_t *hw, emu10k1_memblk_t *blk); 74static int synth_free_pages(struct snd_emu10k1 *hw, struct snd_emu10k1_memblk *blk);
75 75
76#define get_emu10k1_memblk(l,member) list_entry(l, emu10k1_memblk_t, member) 76#define get_emu10k1_memblk(l,member) list_entry(l, struct snd_emu10k1_memblk, member)
77 77
78 78
79/* initialize emu10k1 part */ 79/* initialize emu10k1 part */
80static void emu10k1_memblk_init(emu10k1_memblk_t *blk) 80static void emu10k1_memblk_init(struct snd_emu10k1_memblk *blk)
81{ 81{
82 blk->mapped_page = -1; 82 blk->mapped_page = -1;
83 INIT_LIST_HEAD(&blk->mapped_link); 83 INIT_LIST_HEAD(&blk->mapped_link);
@@ -96,7 +96,7 @@ static void emu10k1_memblk_init(emu10k1_memblk_t *blk)
96 * in nextp 96 * in nextp
97 * if not found, return a negative error code. 97 * if not found, return a negative error code.
98 */ 98 */
99static int search_empty_map_area(emu10k1_t *emu, int npages, struct list_head **nextp) 99static int search_empty_map_area(struct snd_emu10k1 *emu, int npages, struct list_head **nextp)
100{ 100{
101 int page = 0, found_page = -ENOMEM; 101 int page = 0, found_page = -ENOMEM;
102 int max_size = npages; 102 int max_size = npages;
@@ -105,7 +105,7 @@ static int search_empty_map_area(emu10k1_t *emu, int npages, struct list_head **
105 struct list_head *pos; 105 struct list_head *pos;
106 106
107 list_for_each (pos, &emu->mapped_link_head) { 107 list_for_each (pos, &emu->mapped_link_head) {
108 emu10k1_memblk_t *blk = get_emu10k1_memblk(pos, mapped_link); 108 struct snd_emu10k1_memblk *blk = get_emu10k1_memblk(pos, mapped_link);
109 snd_assert(blk->mapped_page >= 0, continue); 109 snd_assert(blk->mapped_page >= 0, continue);
110 size = blk->mapped_page - page; 110 size = blk->mapped_page - page;
111 if (size == npages) { 111 if (size == npages) {
@@ -134,7 +134,7 @@ static int search_empty_map_area(emu10k1_t *emu, int npages, struct list_head **
134 * 134 *
135 * call with memblk_lock held 135 * call with memblk_lock held
136 */ 136 */
137static int map_memblk(emu10k1_t *emu, emu10k1_memblk_t *blk) 137static int map_memblk(struct snd_emu10k1 *emu, struct snd_emu10k1_memblk *blk)
138{ 138{
139 int page, pg; 139 int page, pg;
140 struct list_head *next; 140 struct list_head *next;
@@ -161,11 +161,11 @@ static int map_memblk(emu10k1_t *emu, emu10k1_memblk_t *blk)
161 * 161 *
162 * call with memblk_lock held 162 * call with memblk_lock held
163 */ 163 */
164static int unmap_memblk(emu10k1_t *emu, emu10k1_memblk_t *blk) 164static int unmap_memblk(struct snd_emu10k1 *emu, struct snd_emu10k1_memblk *blk)
165{ 165{
166 int start_page, end_page, mpage, pg; 166 int start_page, end_page, mpage, pg;
167 struct list_head *p; 167 struct list_head *p;
168 emu10k1_memblk_t *q; 168 struct snd_emu10k1_memblk *q;
169 169
170 /* calculate the expected size of empty region */ 170 /* calculate the expected size of empty region */
171 if ((p = blk->mapped_link.prev) != &emu->mapped_link_head) { 171 if ((p = blk->mapped_link.prev) != &emu->mapped_link_head) {
@@ -197,11 +197,11 @@ static int unmap_memblk(emu10k1_t *emu, emu10k1_memblk_t *blk)
197 * 197 *
198 * unlike synth_alloc the memory block is aligned to the page start 198 * unlike synth_alloc the memory block is aligned to the page start
199 */ 199 */
200static emu10k1_memblk_t * 200static struct snd_emu10k1_memblk *
201search_empty(emu10k1_t *emu, int size) 201search_empty(struct snd_emu10k1 *emu, int size)
202{ 202{
203 struct list_head *p; 203 struct list_head *p;
204 emu10k1_memblk_t *blk; 204 struct snd_emu10k1_memblk *blk;
205 int page, psize; 205 int page, psize;
206 206
207 psize = get_aligned_page(size + PAGE_SIZE -1); 207 psize = get_aligned_page(size + PAGE_SIZE -1);
@@ -217,7 +217,7 @@ search_empty(emu10k1_t *emu, int size)
217 217
218__found_pages: 218__found_pages:
219 /* create a new memory block */ 219 /* create a new memory block */
220 blk = (emu10k1_memblk_t *)__snd_util_memblk_new(emu->memhdr, psize << PAGE_SHIFT, p->prev); 220 blk = (struct snd_emu10k1_memblk *)__snd_util_memblk_new(emu->memhdr, psize << PAGE_SHIFT, p->prev);
221 if (blk == NULL) 221 if (blk == NULL)
222 return NULL; 222 return NULL;
223 blk->mem.offset = aligned_page_offset(page); /* set aligned offset */ 223 blk->mem.offset = aligned_page_offset(page); /* set aligned offset */
@@ -229,7 +229,7 @@ __found_pages:
229/* 229/*
230 * check if the given pointer is valid for pages 230 * check if the given pointer is valid for pages
231 */ 231 */
232static int is_valid_page(emu10k1_t *emu, dma_addr_t addr) 232static int is_valid_page(struct snd_emu10k1 *emu, dma_addr_t addr)
233{ 233{
234 if (addr & ~emu->dma_mask) { 234 if (addr & ~emu->dma_mask) {
235 snd_printk(KERN_ERR "max memory size is 0x%lx (addr = 0x%lx)!!\n", emu->dma_mask, (unsigned long)addr); 235 snd_printk(KERN_ERR "max memory size is 0x%lx (addr = 0x%lx)!!\n", emu->dma_mask, (unsigned long)addr);
@@ -248,12 +248,12 @@ static int is_valid_page(emu10k1_t *emu, dma_addr_t addr)
248 * if no empty pages are found, tries to release unsed memory blocks 248 * if no empty pages are found, tries to release unsed memory blocks
249 * and retry the mapping. 249 * and retry the mapping.
250 */ 250 */
251int snd_emu10k1_memblk_map(emu10k1_t *emu, emu10k1_memblk_t *blk) 251int snd_emu10k1_memblk_map(struct snd_emu10k1 *emu, struct snd_emu10k1_memblk *blk)
252{ 252{
253 int err; 253 int err;
254 int size; 254 int size;
255 struct list_head *p, *nextp; 255 struct list_head *p, *nextp;
256 emu10k1_memblk_t *deleted; 256 struct snd_emu10k1_memblk *deleted;
257 unsigned long flags; 257 unsigned long flags;
258 258
259 spin_lock_irqsave(&emu->memblk_lock, flags); 259 spin_lock_irqsave(&emu->memblk_lock, flags);
@@ -288,13 +288,13 @@ int snd_emu10k1_memblk_map(emu10k1_t *emu, emu10k1_memblk_t *blk)
288/* 288/*
289 * page allocation for DMA 289 * page allocation for DMA
290 */ 290 */
291snd_util_memblk_t * 291struct snd_util_memblk *
292snd_emu10k1_alloc_pages(emu10k1_t *emu, snd_pcm_substream_t *substream) 292snd_emu10k1_alloc_pages(struct snd_emu10k1 *emu, struct snd_pcm_substream *substream)
293{ 293{
294 snd_pcm_runtime_t *runtime = substream->runtime; 294 struct snd_pcm_runtime *runtime = substream->runtime;
295 struct snd_sg_buf *sgbuf = snd_pcm_substream_sgbuf(substream); 295 struct snd_sg_buf *sgbuf = snd_pcm_substream_sgbuf(substream);
296 snd_util_memhdr_t *hdr; 296 struct snd_util_memhdr *hdr;
297 emu10k1_memblk_t *blk; 297 struct snd_emu10k1_memblk *blk;
298 int page, err, idx; 298 int page, err, idx;
299 299
300 snd_assert(emu, return NULL); 300 snd_assert(emu, return NULL);
@@ -336,19 +336,19 @@ snd_emu10k1_alloc_pages(emu10k1_t *emu, snd_pcm_substream_t *substream)
336 blk->map_locked = 1; /* do not unmap this block! */ 336 blk->map_locked = 1; /* do not unmap this block! */
337 err = snd_emu10k1_memblk_map(emu, blk); 337 err = snd_emu10k1_memblk_map(emu, blk);
338 if (err < 0) { 338 if (err < 0) {
339 __snd_util_mem_free(hdr, (snd_util_memblk_t *)blk); 339 __snd_util_mem_free(hdr, (struct snd_util_memblk *)blk);
340 up(&hdr->block_mutex); 340 up(&hdr->block_mutex);
341 return NULL; 341 return NULL;
342 } 342 }
343 up(&hdr->block_mutex); 343 up(&hdr->block_mutex);
344 return (snd_util_memblk_t *)blk; 344 return (struct snd_util_memblk *)blk;
345} 345}
346 346
347 347
348/* 348/*
349 * release DMA buffer from page table 349 * release DMA buffer from page table
350 */ 350 */
351int snd_emu10k1_free_pages(emu10k1_t *emu, snd_util_memblk_t *blk) 351int snd_emu10k1_free_pages(struct snd_emu10k1 *emu, struct snd_util_memblk *blk)
352{ 352{
353 snd_assert(emu && blk, return -EINVAL); 353 snd_assert(emu && blk, return -EINVAL);
354 return snd_emu10k1_synth_free(emu, blk); 354 return snd_emu10k1_synth_free(emu, blk);
@@ -363,26 +363,26 @@ int snd_emu10k1_free_pages(emu10k1_t *emu, snd_util_memblk_t *blk)
363/* 363/*
364 * allocate a synth sample area 364 * allocate a synth sample area
365 */ 365 */
366snd_util_memblk_t * 366struct snd_util_memblk *
367snd_emu10k1_synth_alloc(emu10k1_t *hw, unsigned int size) 367snd_emu10k1_synth_alloc(struct snd_emu10k1 *hw, unsigned int size)
368{ 368{
369 emu10k1_memblk_t *blk; 369 struct snd_emu10k1_memblk *blk;
370 snd_util_memhdr_t *hdr = hw->memhdr; 370 struct snd_util_memhdr *hdr = hw->memhdr;
371 371
372 down(&hdr->block_mutex); 372 down(&hdr->block_mutex);
373 blk = (emu10k1_memblk_t *)__snd_util_mem_alloc(hdr, size); 373 blk = (struct snd_emu10k1_memblk *)__snd_util_mem_alloc(hdr, size);
374 if (blk == NULL) { 374 if (blk == NULL) {
375 up(&hdr->block_mutex); 375 up(&hdr->block_mutex);
376 return NULL; 376 return NULL;
377 } 377 }
378 if (synth_alloc_pages(hw, blk)) { 378 if (synth_alloc_pages(hw, blk)) {
379 __snd_util_mem_free(hdr, (snd_util_memblk_t *)blk); 379 __snd_util_mem_free(hdr, (struct snd_util_memblk *)blk);
380 up(&hdr->block_mutex); 380 up(&hdr->block_mutex);
381 return NULL; 381 return NULL;
382 } 382 }
383 snd_emu10k1_memblk_map(hw, blk); 383 snd_emu10k1_memblk_map(hw, blk);
384 up(&hdr->block_mutex); 384 up(&hdr->block_mutex);
385 return (snd_util_memblk_t *)blk; 385 return (struct snd_util_memblk *)blk;
386} 386}
387 387
388 388
@@ -390,10 +390,10 @@ snd_emu10k1_synth_alloc(emu10k1_t *hw, unsigned int size)
390 * free a synth sample area 390 * free a synth sample area
391 */ 391 */
392int 392int
393snd_emu10k1_synth_free(emu10k1_t *emu, snd_util_memblk_t *memblk) 393snd_emu10k1_synth_free(struct snd_emu10k1 *emu, struct snd_util_memblk *memblk)
394{ 394{
395 snd_util_memhdr_t *hdr = emu->memhdr; 395 struct snd_util_memhdr *hdr = emu->memhdr;
396 emu10k1_memblk_t *blk = (emu10k1_memblk_t *)memblk; 396 struct snd_emu10k1_memblk *blk = (struct snd_emu10k1_memblk *)memblk;
397 unsigned long flags; 397 unsigned long flags;
398 398
399 down(&hdr->block_mutex); 399 down(&hdr->block_mutex);
@@ -409,10 +409,12 @@ snd_emu10k1_synth_free(emu10k1_t *emu, snd_util_memblk_t *memblk)
409 409
410 410
411/* check new allocation range */ 411/* check new allocation range */
412static void get_single_page_range(snd_util_memhdr_t *hdr, emu10k1_memblk_t *blk, int *first_page_ret, int *last_page_ret) 412static void get_single_page_range(struct snd_util_memhdr *hdr,
413 struct snd_emu10k1_memblk *blk,
414 int *first_page_ret, int *last_page_ret)
413{ 415{
414 struct list_head *p; 416 struct list_head *p;
415 emu10k1_memblk_t *q; 417 struct snd_emu10k1_memblk *q;
416 int first_page, last_page; 418 int first_page, last_page;
417 first_page = blk->first_page; 419 first_page = blk->first_page;
418 if ((p = blk->mem.list.prev) != &hdr->block) { 420 if ((p = blk->mem.list.prev) != &hdr->block) {
@@ -433,7 +435,7 @@ static void get_single_page_range(snd_util_memhdr_t *hdr, emu10k1_memblk_t *blk,
433/* 435/*
434 * allocate kernel pages 436 * allocate kernel pages
435 */ 437 */
436static int synth_alloc_pages(emu10k1_t *emu, emu10k1_memblk_t *blk) 438static int synth_alloc_pages(struct snd_emu10k1 *emu, struct snd_emu10k1_memblk *blk)
437{ 439{
438 int page, first_page, last_page; 440 int page, first_page, last_page;
439 struct snd_dma_buffer dmab; 441 struct snd_dma_buffer dmab;
@@ -472,7 +474,7 @@ __fail:
472/* 474/*
473 * free pages 475 * free pages
474 */ 476 */
475static int synth_free_pages(emu10k1_t *emu, emu10k1_memblk_t *blk) 477static int synth_free_pages(struct snd_emu10k1 *emu, struct snd_emu10k1_memblk *blk)
476{ 478{
477 int page, first_page, last_page; 479 int page, first_page, last_page;
478 struct snd_dma_buffer dmab; 480 struct snd_dma_buffer dmab;
@@ -495,7 +497,7 @@ static int synth_free_pages(emu10k1_t *emu, emu10k1_memblk_t *blk)
495} 497}
496 498
497/* calculate buffer pointer from offset address */ 499/* calculate buffer pointer from offset address */
498static inline void *offset_ptr(emu10k1_t *emu, int page, int offset) 500static inline void *offset_ptr(struct snd_emu10k1 *emu, int page, int offset)
499{ 501{
500 char *ptr; 502 char *ptr;
501 snd_assert(page >= 0 && page < emu->max_cache_pages, return NULL); 503 snd_assert(page >= 0 && page < emu->max_cache_pages, return NULL);
@@ -511,11 +513,12 @@ static inline void *offset_ptr(emu10k1_t *emu, int page, int offset)
511/* 513/*
512 * bzero(blk + offset, size) 514 * bzero(blk + offset, size)
513 */ 515 */
514int snd_emu10k1_synth_bzero(emu10k1_t *emu, snd_util_memblk_t *blk, int offset, int size) 516int snd_emu10k1_synth_bzero(struct snd_emu10k1 *emu, struct snd_util_memblk *blk,
517 int offset, int size)
515{ 518{
516 int page, nextofs, end_offset, temp, temp1; 519 int page, nextofs, end_offset, temp, temp1;
517 void *ptr; 520 void *ptr;
518 emu10k1_memblk_t *p = (emu10k1_memblk_t *)blk; 521 struct snd_emu10k1_memblk *p = (struct snd_emu10k1_memblk *)blk;
519 522
520 offset += blk->offset & (PAGE_SIZE - 1); 523 offset += blk->offset & (PAGE_SIZE - 1);
521 end_offset = offset + size; 524 end_offset = offset + size;
@@ -538,11 +541,12 @@ int snd_emu10k1_synth_bzero(emu10k1_t *emu, snd_util_memblk_t *blk, int offset,
538/* 541/*
539 * copy_from_user(blk + offset, data, size) 542 * copy_from_user(blk + offset, data, size)
540 */ 543 */
541int snd_emu10k1_synth_copy_from_user(emu10k1_t *emu, snd_util_memblk_t *blk, int offset, const char __user *data, int size) 544int snd_emu10k1_synth_copy_from_user(struct snd_emu10k1 *emu, struct snd_util_memblk *blk,
545 int offset, const char __user *data, int size)
542{ 546{
543 int page, nextofs, end_offset, temp, temp1; 547 int page, nextofs, end_offset, temp, temp1;
544 void *ptr; 548 void *ptr;
545 emu10k1_memblk_t *p = (emu10k1_memblk_t *)blk; 549 struct snd_emu10k1_memblk *p = (struct snd_emu10k1_memblk *)blk;
546 550
547 offset += blk->offset & (PAGE_SIZE - 1); 551 offset += blk->offset & (PAGE_SIZE - 1);
548 end_offset = offset + size; 552 end_offset = offset + size;