diff options
| -rw-r--r-- | sound/core/pcm_native.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c index e48c5f618578..29ab46a12e11 100644 --- a/sound/core/pcm_native.c +++ b/sound/core/pcm_native.c | |||
| @@ -3070,6 +3070,16 @@ snd_pcm_default_page_ops(struct snd_pcm_substream *substream, unsigned long ofs) | |||
| 3070 | if (substream->dma_buffer.dev.type == SNDRV_DMA_TYPE_DEV) | 3070 | if (substream->dma_buffer.dev.type == SNDRV_DMA_TYPE_DEV) |
| 3071 | return virt_to_page(CAC_ADDR(vaddr)); | 3071 | return virt_to_page(CAC_ADDR(vaddr)); |
| 3072 | #endif | 3072 | #endif |
| 3073 | #if defined(CONFIG_PPC32) && defined(CONFIG_NOT_COHERENT_CACHE) | ||
| 3074 | if (substream->dma_buffer.dev.type == SNDRV_DMA_TYPE_DEV) { | ||
| 3075 | dma_addr_t addr = substream->runtime->dma_addr + ofs; | ||
| 3076 | addr -= get_dma_offset(substream->dma_buffer.dev.dev); | ||
| 3077 | /* assume dma_handle set via pfn_to_phys() in | ||
| 3078 | * mm/dma-noncoherent.c | ||
| 3079 | */ | ||
| 3080 | return pfn_to_page(addr >> PAGE_SHIFT); | ||
| 3081 | } | ||
| 3082 | #endif | ||
| 3073 | return virt_to_page(vaddr); | 3083 | return virt_to_page(vaddr); |
| 3074 | } | 3084 | } |
| 3075 | 3085 | ||
