diff options
| -rw-r--r-- | include/sound/memalloc.h | 6 | ||||
| -rw-r--r-- | include/sound/pcm.h | 23 | ||||
| -rw-r--r-- | sound/core/Kconfig | 4 | ||||
| -rw-r--r-- | sound/core/Makefile | 2 | ||||
| -rw-r--r-- | sound/core/memalloc.c | 4 | ||||
| -rw-r--r-- | sound/core/pcm_memory.c | 2 |
6 files changed, 40 insertions, 1 deletions
diff --git a/include/sound/memalloc.h b/include/sound/memalloc.h index 7ccce94a5255..c42506212649 100644 --- a/include/sound/memalloc.h +++ b/include/sound/memalloc.h | |||
| @@ -47,7 +47,11 @@ struct snd_dma_device { | |||
| 47 | #define SNDRV_DMA_TYPE_UNKNOWN 0 /* not defined */ | 47 | #define SNDRV_DMA_TYPE_UNKNOWN 0 /* not defined */ |
| 48 | #define SNDRV_DMA_TYPE_CONTINUOUS 1 /* continuous no-DMA memory */ | 48 | #define SNDRV_DMA_TYPE_CONTINUOUS 1 /* continuous no-DMA memory */ |
| 49 | #define SNDRV_DMA_TYPE_DEV 2 /* generic device continuous */ | 49 | #define SNDRV_DMA_TYPE_DEV 2 /* generic device continuous */ |
| 50 | #ifdef CONFIG_SND_DMA_SGBUF | ||
| 50 | #define SNDRV_DMA_TYPE_DEV_SG 3 /* generic device SG-buffer */ | 51 | #define SNDRV_DMA_TYPE_DEV_SG 3 /* generic device SG-buffer */ |
| 52 | #else | ||
| 53 | #define SNDRV_DMA_TYPE_DEV_SG SNDRV_DMA_TYPE_DEV /* no SG-buf support */ | ||
| 54 | #endif | ||
| 51 | 55 | ||
| 52 | /* | 56 | /* |
| 53 | * info for buffer allocation | 57 | * info for buffer allocation |
| @@ -60,6 +64,7 @@ struct snd_dma_buffer { | |||
| 60 | void *private_data; /* private for allocator; don't touch */ | 64 | void *private_data; /* private for allocator; don't touch */ |
| 61 | }; | 65 | }; |
| 62 | 66 | ||
| 67 | #ifdef CONFIG_SND_DMA_SGBUF | ||
| 63 | /* | 68 | /* |
| 64 | * Scatter-Gather generic device pages | 69 | * Scatter-Gather generic device pages |
| 65 | */ | 70 | */ |
| @@ -107,6 +112,7 @@ static inline void *snd_sgbuf_get_ptr(struct snd_sg_buf *sgbuf, size_t offset) | |||
| 107 | { | 112 | { |
| 108 | return sgbuf->table[offset >> PAGE_SHIFT].buf + offset % PAGE_SIZE; | 113 | return sgbuf->table[offset >> PAGE_SHIFT].buf + offset % PAGE_SIZE; |
| 109 | } | 114 | } |
| 115 | #endif /* CONFIG_SND_DMA_SGBUF */ | ||
| 110 | 116 | ||
| 111 | /* allocate/release a buffer */ | 117 | /* allocate/release a buffer */ |
| 112 | int snd_dma_alloc_pages(int type, struct device *dev, size_t size, | 118 | int snd_dma_alloc_pages(int type, struct device *dev, size_t size, |
diff --git a/include/sound/pcm.h b/include/sound/pcm.h index 23893523dc8c..1691c7fe35af 100644 --- a/include/sound/pcm.h +++ b/include/sound/pcm.h | |||
| @@ -902,6 +902,7 @@ int snd_pcm_lib_preallocate_pages_for_all(struct snd_pcm *pcm, | |||
| 902 | int snd_pcm_lib_malloc_pages(struct snd_pcm_substream *substream, size_t size); | 902 | int snd_pcm_lib_malloc_pages(struct snd_pcm_substream *substream, size_t size); |
| 903 | int snd_pcm_lib_free_pages(struct snd_pcm_substream *substream); | 903 | int snd_pcm_lib_free_pages(struct snd_pcm_substream *substream); |
| 904 | 904 | ||
| 905 | #ifdef CONFIG_SND_DMA_SGBUF | ||
| 905 | /* | 906 | /* |
| 906 | * SG-buffer handling | 907 | * SG-buffer handling |
| 907 | */ | 908 | */ |
| @@ -927,6 +928,28 @@ struct page *snd_pcm_sgbuf_ops_page(struct snd_pcm_substream *substream, | |||
| 927 | unsigned int snd_pcm_sgbuf_get_chunk_size(struct snd_pcm_substream *substream, | 928 | unsigned int snd_pcm_sgbuf_get_chunk_size(struct snd_pcm_substream *substream, |
| 928 | unsigned int ofs, unsigned int size); | 929 | unsigned int ofs, unsigned int size); |
| 929 | 930 | ||
| 931 | #else /* !SND_DMA_SGBUF */ | ||
| 932 | /* | ||
| 933 | * fake using a continuous buffer | ||
| 934 | */ | ||
| 935 | static inline dma_addr_t | ||
| 936 | snd_pcm_sgbuf_get_addr(struct snd_pcm_substream *substream, unsigned int ofs) | ||
| 937 | { | ||
| 938 | return substream->runtime->dma_addr + ofs; | ||
| 939 | } | ||
| 940 | |||
| 941 | static inline void * | ||
| 942 | snd_pcm_sgbuf_get_ptr(struct snd_pcm_substream *substream, unsigned int ofs) | ||
| 943 | { | ||
| 944 | return substream->runtime->dma_area + ofs; | ||
| 945 | } | ||
| 946 | |||
| 947 | #define snd_pcm_sgbuf_ops_page NULL | ||
| 948 | |||
| 949 | #define snd_pcm_sgbuf_get_chunk_size(subs, ofs, size) (size) | ||
| 950 | |||
| 951 | #endif /* SND_DMA_SGBUF */ | ||
| 952 | |||
| 930 | /* handle mmap counter - PCM mmap callback should handle this counter properly */ | 953 | /* handle mmap counter - PCM mmap callback should handle this counter properly */ |
| 931 | static inline void snd_pcm_mmap_data_open(struct vm_area_struct *area) | 954 | static inline void snd_pcm_mmap_data_open(struct vm_area_struct *area) |
| 932 | { | 955 | { |
diff --git a/sound/core/Kconfig b/sound/core/Kconfig index 6061fb5f4e1c..c15682a2f9db 100644 --- a/sound/core/Kconfig +++ b/sound/core/Kconfig | |||
| @@ -206,4 +206,8 @@ config SND_PCM_XRUN_DEBUG | |||
| 206 | config SND_VMASTER | 206 | config SND_VMASTER |
| 207 | bool | 207 | bool |
| 208 | 208 | ||
| 209 | config SND_DMA_SGBUF | ||
| 210 | def_bool y | ||
| 211 | depends on X86 | ||
| 212 | |||
| 209 | source "sound/core/seq/Kconfig" | 213 | source "sound/core/seq/Kconfig" |
diff --git a/sound/core/Makefile b/sound/core/Makefile index 4229052e7b91..350a08d277f4 100644 --- a/sound/core/Makefile +++ b/sound/core/Makefile | |||
| @@ -13,7 +13,7 @@ snd-pcm-objs := pcm.o pcm_native.o pcm_lib.o pcm_timer.o pcm_misc.o \ | |||
| 13 | pcm_memory.o | 13 | pcm_memory.o |
| 14 | 14 | ||
| 15 | snd-page-alloc-y := memalloc.o | 15 | snd-page-alloc-y := memalloc.o |
| 16 | snd-page-alloc-$(CONFIG_HAS_DMA) += sgbuf.o | 16 | snd-page-alloc-$(CONFIG_SND_DMA_SGBUF) += sgbuf.o |
| 17 | 17 | ||
| 18 | snd-rawmidi-objs := rawmidi.o | 18 | snd-rawmidi-objs := rawmidi.o |
| 19 | snd-timer-objs := timer.o | 19 | snd-timer-objs := timer.o |
diff --git a/sound/core/memalloc.c b/sound/core/memalloc.c index 1b3534d67686..9e92441f9b78 100644 --- a/sound/core/memalloc.c +++ b/sound/core/memalloc.c | |||
| @@ -199,6 +199,8 @@ int snd_dma_alloc_pages(int type, struct device *device, size_t size, | |||
| 199 | case SNDRV_DMA_TYPE_DEV: | 199 | case SNDRV_DMA_TYPE_DEV: |
| 200 | dmab->area = snd_malloc_dev_pages(device, size, &dmab->addr); | 200 | dmab->area = snd_malloc_dev_pages(device, size, &dmab->addr); |
| 201 | break; | 201 | break; |
| 202 | #endif | ||
| 203 | #ifdef CONFIG_SND_DMA_SGBUF | ||
| 202 | case SNDRV_DMA_TYPE_DEV_SG: | 204 | case SNDRV_DMA_TYPE_DEV_SG: |
| 203 | snd_malloc_sgbuf_pages(device, size, dmab, NULL); | 205 | snd_malloc_sgbuf_pages(device, size, dmab, NULL); |
| 204 | break; | 206 | break; |
| @@ -269,6 +271,8 @@ void snd_dma_free_pages(struct snd_dma_buffer *dmab) | |||
| 269 | case SNDRV_DMA_TYPE_DEV: | 271 | case SNDRV_DMA_TYPE_DEV: |
| 270 | snd_free_dev_pages(dmab->dev.dev, dmab->bytes, dmab->area, dmab->addr); | 272 | snd_free_dev_pages(dmab->dev.dev, dmab->bytes, dmab->area, dmab->addr); |
| 271 | break; | 273 | break; |
| 274 | #endif | ||
| 275 | #ifdef CONFIG_SND_DMA_SGBUF | ||
| 272 | case SNDRV_DMA_TYPE_DEV_SG: | 276 | case SNDRV_DMA_TYPE_DEV_SG: |
| 273 | snd_free_sgbuf_pages(dmab); | 277 | snd_free_sgbuf_pages(dmab); |
| 274 | break; | 278 | break; |
diff --git a/sound/core/pcm_memory.c b/sound/core/pcm_memory.c index a6d42808828c..caa7796bc2f5 100644 --- a/sound/core/pcm_memory.c +++ b/sound/core/pcm_memory.c | |||
| @@ -304,6 +304,7 @@ int snd_pcm_lib_preallocate_pages_for_all(struct snd_pcm *pcm, | |||
| 304 | 304 | ||
| 305 | EXPORT_SYMBOL(snd_pcm_lib_preallocate_pages_for_all); | 305 | EXPORT_SYMBOL(snd_pcm_lib_preallocate_pages_for_all); |
| 306 | 306 | ||
| 307 | #ifdef CONFIG_SND_DMA_SGBUF | ||
| 307 | /** | 308 | /** |
| 308 | * snd_pcm_sgbuf_ops_page - get the page struct at the given offset | 309 | * snd_pcm_sgbuf_ops_page - get the page struct at the given offset |
| 309 | * @substream: the pcm substream instance | 310 | * @substream: the pcm substream instance |
| @@ -349,6 +350,7 @@ unsigned int snd_pcm_sgbuf_get_chunk_size(struct snd_pcm_substream *substream, | |||
| 349 | return size; | 350 | return size; |
| 350 | } | 351 | } |
| 351 | EXPORT_SYMBOL(snd_pcm_sgbuf_get_chunk_size); | 352 | EXPORT_SYMBOL(snd_pcm_sgbuf_get_chunk_size); |
| 353 | #endif /* CONFIG_SND_DMA_SGBUF */ | ||
| 352 | 354 | ||
| 353 | /** | 355 | /** |
| 354 | * snd_pcm_lib_malloc_pages - allocate the DMA buffer | 356 | * snd_pcm_lib_malloc_pages - allocate the DMA buffer |
