ALSA: hda - Add pcm_mmap_prepare op.
authorDylan Reid <dgreid@chromium.org>
Fri, 28 Feb 2014 23:41:21 +0000 (15:41 -0800)
committerTakashi Iwai <tiwai@suse.de>
Sat, 1 Mar 2014 10:22:02 +0000 (11:22 +0100)
Adding this op allows the X86 specific mmap operation to help in
hda_intel without needing a CONFIG_X86 in future non-PCI hda drivers.

Signed-off-by: Dylan Reid <dgreid@chromium.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/hda_intel.c
sound/pci/hda/hda_priv.h

index fa3a04c7771e6ca6f0ec1ef2d1add2fd795be89a..aa8b765c92995c455fd1f67b43ea0e8c98c66b0a 100644 (file)
@@ -2190,19 +2190,15 @@ static void azx_clear_irq_pending(struct azx *chip)
        spin_unlock_irq(&chip->reg_lock);
 }
 
-#ifdef CONFIG_X86
 static int azx_pcm_mmap(struct snd_pcm_substream *substream,
                        struct vm_area_struct *area)
 {
        struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
        struct azx *chip = apcm->chip;
-       if (!azx_snoop(chip))
-               area->vm_page_prot = pgprot_writecombine(area->vm_page_prot);
+       if (chip->ops->pcm_mmap_prepare)
+               chip->ops->pcm_mmap_prepare(substream, area);
        return snd_pcm_lib_default_mmap(substream, area);
 }
-#else
-#define azx_pcm_mmap   NULL
-#endif
 
 static struct snd_pcm_ops azx_pcm_ops = {
        .open = azx_pcm_open,
@@ -3508,6 +3504,17 @@ static int substream_free_pages(struct azx *chip,
        return snd_pcm_lib_free_pages(substream);
 }
 
+static void pcm_mmap_prepare(struct snd_pcm_substream *substream,
+                            struct vm_area_struct *area)
+{
+#ifdef CONFIG_X86
+       struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
+       struct azx *chip = apcm->chip;
+       if (!azx_snoop(chip))
+               area->vm_page_prot = pgprot_writecombine(area->vm_page_prot);
+#endif
+}
+
 static const struct hda_controller_ops pci_hda_ops = {
        .writel = pci_azx_writel,
        .readl = pci_azx_readl,
@@ -3520,6 +3527,7 @@ static const struct hda_controller_ops pci_hda_ops = {
        .dma_free_pages = dma_free_pages,
        .substream_alloc_pages = substream_alloc_pages,
        .substream_free_pages = substream_free_pages,
+       .pcm_mmap_prepare = pcm_mmap_prepare,
 };
 
 static int azx_probe(struct pci_dev *pci,
index 10bcec127319c9f934fb3e97f0bd4a63926d9b34..edbe2ebac025830fcca050fcac7c343f83c9056f 100644 (file)
@@ -309,6 +309,8 @@ struct hda_controller_ops {
                                     size_t size);
        int (*substream_free_pages)(struct azx *chip,
                                    struct snd_pcm_substream *substream);
+       void (*pcm_mmap_prepare)(struct snd_pcm_substream *substream,
+                                struct vm_area_struct *area);
 };
 
 struct azx_pcm {