ASoC: Tegra: Add ALSA ctl to set DMA address
[linux-2.6.git] / sound / soc / tegra / tegra_pcm.h
1 /*
2  * tegra_pcm.h - Definitions for Tegra PCM driver
3  *
4  * Author: Stephen Warren <swarren@nvidia.com>
5  * Copyright (C) 2010-2012 - NVIDIA, Inc.
6  *
7  * Based on code copyright/by:
8  *
9  * Copyright (c) 2009-2010, NVIDIA Corporation.
10  * Scott Peterson <speterson@nvidia.com>
11  *
12  * Copyright (C) 2010 Google, Inc.
13  * Iliyan Malchev <malchev@google.com>
14  *
15  * This program is free software; you can redistribute it and/or
16  * modify it under the terms of the GNU General Public License
17  * version 2 as published by the Free Software Foundation.
18  *
19  * This program is distributed in the hope that it will be useful, but
20  * WITHOUT ANY WARRANTY; without even the implied warranty of
21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
22  * General Public License for more details.
23  *
24  * You should have received a copy of the GNU General Public License
25  * along with this program; if not, write to the Free Software
26  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
27  * 02110-1301 USA
28  *
29  */
30
31 #ifndef __TEGRA_PCM_H__
32 #define __TEGRA_PCM_H__
33
34 #include <mach/dma.h>
35 #include <linux/nvmap.h>
36
37 #define MAX_DMA_REQ_COUNT 2
38
39 #ifdef CONFIG_ARCH_TEGRA_11x_SOC
40 #define TEGRA30_USE_SMMU 0
41 #endif
42
43 struct tegra_pcm_dma_params {
44         unsigned long addr;
45         unsigned long wrap;
46         unsigned long width;
47         unsigned long req_sel;
48 };
49
50 struct tegra_runtime_data {
51         struct snd_pcm_substream *substream;
52         spinlock_t lock;
53         int running;
54         int dma_pos;
55         int dma_pos_end;
56         int period_index;
57         int dma_req_idx;
58         struct tegra_dma_req dma_req[MAX_DMA_REQ_COUNT];
59         struct tegra_dma_channel *dma_chan;
60         int dma_req_count;
61         int disable_intr;
62         unsigned int avp_dma_addr;
63 };
64
65 #ifdef TEGRA30_USE_SMMU
66 struct tegra_smmu_data {
67         struct nvmap_client *pcm_nvmap_client;
68         struct nvmap_handle_ref *pcm_nvmap_handle;
69 };
70 #endif
71
72 int tegra_pcm_trigger(struct snd_pcm_substream *substream, int cmd);
73 int tegra_pcm_allocate(struct snd_pcm_substream *substream,
74                                         int dma_mode,
75                                         const struct snd_pcm_hardware *pcm_hardware);
76 int tegra_pcm_close(struct snd_pcm_substream *substream);
77 int tegra_pcm_hw_params(struct snd_pcm_substream *substream,
78                                 struct snd_pcm_hw_params *params);
79 int tegra_pcm_trigger(struct snd_pcm_substream *substream, int cmd);
80 int tegra_pcm_mmap(struct snd_pcm_substream *substream,
81                                 struct vm_area_struct *vma);
82 int tegra_pcm_dma_allocate(struct snd_soc_pcm_runtime *rtd, size_t size);
83 void tegra_pcm_free(struct snd_pcm *pcm);
84 snd_pcm_uframes_t tegra_pcm_pointer(struct snd_pcm_substream *substream);
85 int tegra_pcm_hw_free(struct snd_pcm_substream *substream);
86
87 #endif