blob: a33232c0c59ef58968def37a53e91583182437a9 [file] [log] [blame]
Jon Smirl89dd0842009-05-23 19:12:59 -04001/*
2 * Freescale MPC5200 Audio DMA driver
3 */
4
5#ifndef __SOUND_SOC_FSL_MPC5200_DMA_H__
6#define __SOUND_SOC_FSL_MPC5200_DMA_H__
7
8/**
Jon Smirlcebe7762009-05-23 19:13:01 -04009 * psc_dma_stream - Data specific to a single stream (playback or capture)
Jon Smirl89dd0842009-05-23 19:12:59 -040010 * @active: flag indicating if the stream is active
Jon Smirlcebe7762009-05-23 19:13:01 -040011 * @psc_dma: pointer back to parent psc_dma data structure
Jon Smirl89dd0842009-05-23 19:12:59 -040012 * @bcom_task: bestcomm task structure
13 * @irq: irq number for bestcomm task
14 * @period_start: physical address of start of DMA region
15 * @period_end: physical address of end of DMA region
16 * @period_next_pt: physical address of next DMA buffer to enqueue
17 * @period_bytes: size of DMA period in bytes
18 */
Jon Smirlcebe7762009-05-23 19:13:01 -040019struct psc_dma_stream {
Jon Smirl89dd0842009-05-23 19:12:59 -040020 int active;
Jon Smirlcebe7762009-05-23 19:13:01 -040021 struct psc_dma *psc_dma;
Jon Smirl89dd0842009-05-23 19:12:59 -040022 struct bcom_task *bcom_task;
23 int irq;
24 struct snd_pcm_substream *stream;
25 dma_addr_t period_start;
26 dma_addr_t period_end;
27 dma_addr_t period_next_pt;
28 dma_addr_t period_current_pt;
29 int period_bytes;
30};
31
32/**
Jon Smirlcebe7762009-05-23 19:13:01 -040033 * psc_dma - Private driver data
Jon Smirl89dd0842009-05-23 19:12:59 -040034 * @name: short name for this device ("PSC0", "PSC1", etc)
35 * @psc_regs: pointer to the PSC's registers
36 * @fifo_regs: pointer to the PSC's FIFO registers
37 * @irq: IRQ of this PSC
38 * @dev: struct device pointer
39 * @dai: the CPU DAI for this device
40 * @sicr: Base value used in serial interface control register; mode is ORed
41 * with this value.
42 * @playback: Playback stream context data
43 * @capture: Capture stream context data
44 */
Jon Smirlcebe7762009-05-23 19:13:01 -040045struct psc_dma {
Jon Smirl89dd0842009-05-23 19:12:59 -040046 char name[32];
47 struct mpc52xx_psc __iomem *psc_regs;
48 struct mpc52xx_psc_fifo __iomem *fifo_regs;
49 unsigned int irq;
50 struct device *dev;
51 struct snd_soc_dai dai;
52 spinlock_t lock;
53 u32 sicr;
54
55 /* per-stream data */
Jon Smirlcebe7762009-05-23 19:13:01 -040056 struct psc_dma_stream playback;
57 struct psc_dma_stream capture;
Jon Smirl89dd0842009-05-23 19:12:59 -040058
59 /* Statistics */
60 struct {
61 int overrun_count;
62 int underrun_count;
63 } stats;
64};
65
66
Jon Smirlcebe7762009-05-23 19:13:01 -040067int psc_dma_startup(struct snd_pcm_substream *substream,
Jon Smirl89dd0842009-05-23 19:12:59 -040068 struct snd_soc_dai *dai);
69
Jon Smirlcebe7762009-05-23 19:13:01 -040070int psc_dma_hw_free(struct snd_pcm_substream *substream,
Jon Smirl89dd0842009-05-23 19:12:59 -040071 struct snd_soc_dai *dai);
72
Jon Smirlcebe7762009-05-23 19:13:01 -040073void psc_dma_shutdown(struct snd_pcm_substream *substream,
Jon Smirl89dd0842009-05-23 19:12:59 -040074 struct snd_soc_dai *dai);
75
Jon Smirlcebe7762009-05-23 19:13:01 -040076int psc_dma_trigger(struct snd_pcm_substream *substream, int cmd,
Jon Smirl89dd0842009-05-23 19:12:59 -040077 struct snd_soc_dai *dai);
78
Jon Smirlcebe7762009-05-23 19:13:01 -040079extern struct snd_soc_platform psc_dma_pcm_soc_platform;
Jon Smirl89dd0842009-05-23 19:12:59 -040080
81#endif /* __SOUND_SOC_FSL_MPC5200_DMA_H__ */