aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/samsung/pcm.c
diff options
context:
space:
mode:
Diffstat (limited to 'sound/soc/samsung/pcm.c')
-rw-r--r--sound/soc/samsung/pcm.c107
1 files changed, 107 insertions, 0 deletions
diff --git a/sound/soc/samsung/pcm.c b/sound/soc/samsung/pcm.c
index 48d0b750406b..091db5dce07e 100644
--- a/sound/soc/samsung/pcm.c
+++ b/sound/soc/samsung/pcm.c
@@ -32,6 +32,113 @@
32#include "dma.h" 32#include "dma.h"
33#include "pcm.h" 33#include "pcm.h"
34 34
35/*Register Offsets */
36#define S3C_PCM_CTL 0x00
37#define S3C_PCM_CLKCTL 0x04
38#define S3C_PCM_TXFIFO 0x08
39#define S3C_PCM_RXFIFO 0x0C
40#define S3C_PCM_IRQCTL 0x10
41#define S3C_PCM_IRQSTAT 0x14
42#define S3C_PCM_FIFOSTAT 0x18
43#define S3C_PCM_CLRINT 0x20
44
45/* PCM_CTL Bit-Fields */
46#define S3C_PCM_CTL_TXDIPSTICK_MASK 0x3f
47#define S3C_PCM_CTL_TXDIPSTICK_SHIFT 13
48#define S3C_PCM_CTL_RXDIPSTICK_MASK 0x3f
49#define S3C_PCM_CTL_RXDIPSTICK_SHIFT 7
50#define S3C_PCM_CTL_TXDMA_EN (0x1 << 6)
51#define S3C_PCM_CTL_RXDMA_EN (0x1 << 5)
52#define S3C_PCM_CTL_TXMSB_AFTER_FSYNC (0x1 << 4)
53#define S3C_PCM_CTL_RXMSB_AFTER_FSYNC (0x1 << 3)
54#define S3C_PCM_CTL_TXFIFO_EN (0x1 << 2)
55#define S3C_PCM_CTL_RXFIFO_EN (0x1 << 1)
56#define S3C_PCM_CTL_ENABLE (0x1 << 0)
57
58/* PCM_CLKCTL Bit-Fields */
59#define S3C_PCM_CLKCTL_SERCLK_EN (0x1 << 19)
60#define S3C_PCM_CLKCTL_SERCLKSEL_PCLK (0x1 << 18)
61#define S3C_PCM_CLKCTL_SCLKDIV_MASK 0x1ff
62#define S3C_PCM_CLKCTL_SYNCDIV_MASK 0x1ff
63#define S3C_PCM_CLKCTL_SCLKDIV_SHIFT 9
64#define S3C_PCM_CLKCTL_SYNCDIV_SHIFT 0
65
66/* PCM_TXFIFO Bit-Fields */
67#define S3C_PCM_TXFIFO_DVALID (0x1 << 16)
68#define S3C_PCM_TXFIFO_DATA_MSK (0xffff << 0)
69
70/* PCM_RXFIFO Bit-Fields */
71#define S3C_PCM_RXFIFO_DVALID (0x1 << 16)
72#define S3C_PCM_RXFIFO_DATA_MSK (0xffff << 0)
73
74/* PCM_IRQCTL Bit-Fields */
75#define S3C_PCM_IRQCTL_IRQEN (0x1 << 14)
76#define S3C_PCM_IRQCTL_WRDEN (0x1 << 12)
77#define S3C_PCM_IRQCTL_TXEMPTYEN (0x1 << 11)
78#define S3C_PCM_IRQCTL_TXALMSTEMPTYEN (0x1 << 10)
79#define S3C_PCM_IRQCTL_TXFULLEN (0x1 << 9)
80#define S3C_PCM_IRQCTL_TXALMSTFULLEN (0x1 << 8)
81#define S3C_PCM_IRQCTL_TXSTARVEN (0x1 << 7)
82#define S3C_PCM_IRQCTL_TXERROVRFLEN (0x1 << 6)
83#define S3C_PCM_IRQCTL_RXEMPTEN (0x1 << 5)
84#define S3C_PCM_IRQCTL_RXALMSTEMPTEN (0x1 << 4)
85#define S3C_PCM_IRQCTL_RXFULLEN (0x1 << 3)
86#define S3C_PCM_IRQCTL_RXALMSTFULLEN (0x1 << 2)
87#define S3C_PCM_IRQCTL_RXSTARVEN (0x1 << 1)
88#define S3C_PCM_IRQCTL_RXERROVRFLEN (0x1 << 0)
89
90/* PCM_IRQSTAT Bit-Fields */
91#define S3C_PCM_IRQSTAT_IRQPND (0x1 << 13)
92#define S3C_PCM_IRQSTAT_WRD_XFER (0x1 << 12)
93#define S3C_PCM_IRQSTAT_TXEMPTY (0x1 << 11)
94#define S3C_PCM_IRQSTAT_TXALMSTEMPTY (0x1 << 10)
95#define S3C_PCM_IRQSTAT_TXFULL (0x1 << 9)
96#define S3C_PCM_IRQSTAT_TXALMSTFULL (0x1 << 8)
97#define S3C_PCM_IRQSTAT_TXSTARV (0x1 << 7)
98#define S3C_PCM_IRQSTAT_TXERROVRFL (0x1 << 6)
99#define S3C_PCM_IRQSTAT_RXEMPT (0x1 << 5)
100#define S3C_PCM_IRQSTAT_RXALMSTEMPT (0x1 << 4)
101#define S3C_PCM_IRQSTAT_RXFULL (0x1 << 3)
102#define S3C_PCM_IRQSTAT_RXALMSTFULL (0x1 << 2)
103#define S3C_PCM_IRQSTAT_RXSTARV (0x1 << 1)
104#define S3C_PCM_IRQSTAT_RXERROVRFL (0x1 << 0)
105
106/* PCM_FIFOSTAT Bit-Fields */
107#define S3C_PCM_FIFOSTAT_TXCNT_MSK (0x3f << 14)
108#define S3C_PCM_FIFOSTAT_TXFIFOEMPTY (0x1 << 13)
109#define S3C_PCM_FIFOSTAT_TXFIFOALMSTEMPTY (0x1 << 12)
110#define S3C_PCM_FIFOSTAT_TXFIFOFULL (0x1 << 11)
111#define S3C_PCM_FIFOSTAT_TXFIFOALMSTFULL (0x1 << 10)
112#define S3C_PCM_FIFOSTAT_RXCNT_MSK (0x3f << 4)
113#define S3C_PCM_FIFOSTAT_RXFIFOEMPTY (0x1 << 3)
114#define S3C_PCM_FIFOSTAT_RXFIFOALMSTEMPTY (0x1 << 2)
115#define S3C_PCM_FIFOSTAT_RXFIFOFULL (0x1 << 1)
116#define S3C_PCM_FIFOSTAT_RXFIFOALMSTFULL (0x1 << 0)
117
118/**
119 * struct s3c_pcm_info - S3C PCM Controller information
120 * @dev: The parent device passed to use from the probe.
121 * @regs: The pointer to the device register block.
122 * @dma_playback: DMA information for playback channel.
123 * @dma_capture: DMA information for capture channel.
124 */
125struct s3c_pcm_info {
126 spinlock_t lock;
127 struct device *dev;
128 void __iomem *regs;
129
130 unsigned int sclk_per_fs;
131
132 /* Whether to keep PCMSCLK enabled even when idle(no active xfer) */
133 unsigned int idleclk;
134
135 struct clk *pclk;
136 struct clk *cclk;
137
138 struct s3c_dma_params *dma_playback;
139 struct s3c_dma_params *dma_capture;
140};
141
35static struct s3c2410_dma_client s3c_pcm_dma_client_out = { 142static struct s3c2410_dma_client s3c_pcm_dma_client_out = {
36 .name = "PCM Stereo out" 143 .name = "PCM Stereo out"
37}; 144};