Lines Matching refs:dmab
26 static void snd_malloc_dev_pages(struct snd_dma_buffer *dmab, size_t size) in snd_malloc_dev_pages() argument
34 dmab->area = dma_alloc_coherent(dmab->dev.dev, size, &dmab->addr, in snd_malloc_dev_pages()
37 if (dmab->area && dmab->dev.type == SNDRV_DMA_TYPE_DEV_UC) in snd_malloc_dev_pages()
38 set_memory_wc((unsigned long)dmab->area, in snd_malloc_dev_pages()
44 static void snd_free_dev_pages(struct snd_dma_buffer *dmab) in snd_free_dev_pages() argument
47 if (dmab->dev.type == SNDRV_DMA_TYPE_DEV_UC) in snd_free_dev_pages()
48 set_memory_wb((unsigned long)dmab->area, in snd_free_dev_pages()
49 PAGE_ALIGN(dmab->bytes) >> PAGE_SHIFT); in snd_free_dev_pages()
51 dma_free_coherent(dmab->dev.dev, dmab->bytes, dmab->area, dmab->addr); in snd_free_dev_pages()
62 static void snd_malloc_dev_iram(struct snd_dma_buffer *dmab, size_t size) in snd_malloc_dev_iram() argument
64 struct device *dev = dmab->dev.dev; in snd_malloc_dev_iram()
67 dmab->area = NULL; in snd_malloc_dev_iram()
68 dmab->addr = 0; in snd_malloc_dev_iram()
77 dmab->private_data = pool; in snd_malloc_dev_iram()
79 dmab->area = gen_pool_dma_alloc(pool, size, &dmab->addr); in snd_malloc_dev_iram()
86 static void snd_free_dev_iram(struct snd_dma_buffer *dmab) in snd_free_dev_iram() argument
88 struct gen_pool *pool = dmab->private_data; in snd_free_dev_iram()
90 if (pool && dmab->area) in snd_free_dev_iram()
91 gen_pool_free(pool, (unsigned long)dmab->area, dmab->bytes); in snd_free_dev_iram()
117 struct snd_dma_buffer *dmab) in snd_dma_alloc_pages() argument
121 if (WARN_ON(!dmab)) in snd_dma_alloc_pages()
126 dmab->dev.type = type; in snd_dma_alloc_pages()
127 dmab->dev.dev = device; in snd_dma_alloc_pages()
128 dmab->bytes = 0; in snd_dma_alloc_pages()
131 dmab->area = alloc_pages_exact(size, in snd_dma_alloc_pages()
133 dmab->addr = 0; in snd_dma_alloc_pages()
138 snd_malloc_dev_iram(dmab, size); in snd_dma_alloc_pages()
139 if (dmab->area) in snd_dma_alloc_pages()
144 dmab->dev.type = SNDRV_DMA_TYPE_DEV; in snd_dma_alloc_pages()
149 snd_malloc_dev_pages(dmab, size); in snd_dma_alloc_pages()
155 snd_malloc_sgbuf_pages(device, size, dmab, NULL); in snd_dma_alloc_pages()
160 dmab->area = NULL; in snd_dma_alloc_pages()
161 dmab->addr = 0; in snd_dma_alloc_pages()
164 if (! dmab->area) in snd_dma_alloc_pages()
166 dmab->bytes = size; in snd_dma_alloc_pages()
187 struct snd_dma_buffer *dmab) in snd_dma_alloc_pages_fallback() argument
191 while ((err = snd_dma_alloc_pages(type, device, size, dmab)) < 0) { in snd_dma_alloc_pages_fallback()
199 if (! dmab->area) in snd_dma_alloc_pages_fallback()
212 void snd_dma_free_pages(struct snd_dma_buffer *dmab) in snd_dma_free_pages() argument
214 switch (dmab->dev.type) { in snd_dma_free_pages()
216 free_pages_exact(dmab->area, dmab->bytes); in snd_dma_free_pages()
221 snd_free_dev_iram(dmab); in snd_dma_free_pages()
226 snd_free_dev_pages(dmab); in snd_dma_free_pages()
232 snd_free_sgbuf_pages(dmab); in snd_dma_free_pages()
236 pr_err("snd-malloc: invalid device type %d\n", dmab->dev.type); in snd_dma_free_pages()