Lines Matching refs:dmab

27 static void snd_malloc_dev_pages(struct snd_dma_buffer *dmab, size_t size)  in snd_malloc_dev_pages()  argument
35 dmab->area = dma_alloc_coherent(dmab->dev.dev, size, &dmab->addr, in snd_malloc_dev_pages()
38 if (dmab->area && dmab->dev.type == SNDRV_DMA_TYPE_DEV_UC) in snd_malloc_dev_pages()
39 set_memory_wc((unsigned long)dmab->area, in snd_malloc_dev_pages()
45 static void snd_free_dev_pages(struct snd_dma_buffer *dmab) in snd_free_dev_pages() argument
48 if (dmab->dev.type == SNDRV_DMA_TYPE_DEV_UC) in snd_free_dev_pages()
49 set_memory_wb((unsigned long)dmab->area, in snd_free_dev_pages()
50 PAGE_ALIGN(dmab->bytes) >> PAGE_SHIFT); in snd_free_dev_pages()
52 dma_free_coherent(dmab->dev.dev, dmab->bytes, dmab->area, dmab->addr); in snd_free_dev_pages()
63 static void snd_malloc_dev_iram(struct snd_dma_buffer *dmab, size_t size) in snd_malloc_dev_iram() argument
65 struct device *dev = dmab->dev.dev; in snd_malloc_dev_iram()
68 dmab->area = NULL; in snd_malloc_dev_iram()
69 dmab->addr = 0; in snd_malloc_dev_iram()
78 dmab->private_data = pool; in snd_malloc_dev_iram()
80 dmab->area = gen_pool_dma_alloc(pool, size, &dmab->addr); in snd_malloc_dev_iram()
87 static void snd_free_dev_iram(struct snd_dma_buffer *dmab) in snd_free_dev_iram() argument
89 struct gen_pool *pool = dmab->private_data; in snd_free_dev_iram()
91 if (pool && dmab->area) in snd_free_dev_iram()
92 gen_pool_free(pool, (unsigned long)dmab->area, dmab->bytes); in snd_free_dev_iram()
126 struct snd_dma_buffer *dmab) in snd_dma_alloc_pages() argument
132 if (WARN_ON(!dmab)) in snd_dma_alloc_pages()
135 dmab->dev.type = type; in snd_dma_alloc_pages()
136 dmab->dev.dev = device; in snd_dma_alloc_pages()
137 dmab->bytes = 0; in snd_dma_alloc_pages()
138 dmab->area = NULL; in snd_dma_alloc_pages()
139 dmab->addr = 0; in snd_dma_alloc_pages()
140 dmab->private_data = NULL; in snd_dma_alloc_pages()
144 dmab->area = alloc_pages_exact(size, gfp); in snd_dma_alloc_pages()
148 dmab->area = __vmalloc(size, gfp); in snd_dma_alloc_pages()
153 snd_malloc_dev_iram(dmab, size); in snd_dma_alloc_pages()
154 if (dmab->area) in snd_dma_alloc_pages()
159 dmab->dev.type = SNDRV_DMA_TYPE_DEV; in snd_dma_alloc_pages()
164 snd_malloc_dev_pages(dmab, size); in snd_dma_alloc_pages()
170 snd_malloc_sgbuf_pages(device, size, dmab, NULL); in snd_dma_alloc_pages()
177 if (! dmab->area) in snd_dma_alloc_pages()
179 dmab->bytes = size; in snd_dma_alloc_pages()
200 struct snd_dma_buffer *dmab) in snd_dma_alloc_pages_fallback() argument
204 while ((err = snd_dma_alloc_pages(type, device, size, dmab)) < 0) { in snd_dma_alloc_pages_fallback()
212 if (! dmab->area) in snd_dma_alloc_pages_fallback()
225 void snd_dma_free_pages(struct snd_dma_buffer *dmab) in snd_dma_free_pages() argument
227 switch (dmab->dev.type) { in snd_dma_free_pages()
229 free_pages_exact(dmab->area, dmab->bytes); in snd_dma_free_pages()
232 vfree(dmab->area); in snd_dma_free_pages()
237 snd_free_dev_iram(dmab); in snd_dma_free_pages()
242 snd_free_dev_pages(dmab); in snd_dma_free_pages()
248 snd_free_sgbuf_pages(dmab); in snd_dma_free_pages()
252 pr_err("snd-malloc: invalid device type %d\n", dmab->dev.type); in snd_dma_free_pages()