summaryrefslogtreecommitdiff
path: root/sound/soc/codecs/mxs_spdif.h
blob: 284b98cd6f74df80a4a12e8012ce3236171102ec (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
/*
 * ALSA SoC MXS SPDIF codec driver
 *
 * Copyright (C) 2008-2010 Freescale Semiconductor, Inc.
 *
 * Based on stmp3xxx_spdif.h by:
 * Vladimir Barinov <vbarinov@embeddedalley.com>
 *
 * Copyright 2008 SigmaTel, Inc
 * Copyright 2008 Embedded Alley Solutions, Inc
 * Copyright 2008-2009 Freescale Semiconductor, Inc.
 *
 * This file is licensed under the terms of the GNU General Public License
 * version 2.  This program  is licensed "as is" without any warranty of any
 * kind, whether express or implied.
 */
#ifndef __MXS_SPDIF_CODEC_H
#define __MXS_SPDIF_CODEC_H

#define SPDIF_CTRL_L		0
#define SPDIF_CTRL_H		1
#define SPDIF_STAT_L		2
#define SPDIF_STAT_H		3
#define SPDIF_FRAMECTRL_L	4
#define SPDIF_FRAMECTRL_H	5
#define SPDIF_SRR_L		6
#define SPDIF_SRR_H		7
#define SPDIF_DEBUG_L		8
#define SPDIF_DEBUG_H		9
#define SPDIF_DATA_L		10
#define SPDIF_DATA_H		11
#define SPDIF_VERSION_L		12
#define SPDIF_VERSION_H		13

#define SPDIF_REGNUM		14

#define HW_SPDIF_CTRL	(0x00000000)
#define HW_SPDIF_CTRL_SET	(0x00000004)
#define HW_SPDIF_CTRL_CLR	(0x00000008)
#define HW_SPDIF_CTRL_TOG	(0x0000000c)

#define BM_SPDIF_CTRL_SFTRST	0x80000000
#define BM_SPDIF_CTRL_CLKGATE	0x40000000
#define BP_SPDIF_CTRL_RSRVD1	21
#define BM_SPDIF_CTRL_RSRVD1	0x3FE00000
#define BF_SPDIF_CTRL_RSRVD1(v)  \
		(((v) << 21) & BM_SPDIF_CTRL_RSRVD1)
#define BP_SPDIF_CTRL_DMAWAIT_COUNT	16
#define BM_SPDIF_CTRL_DMAWAIT_COUNT	0x001F0000
#define BF_SPDIF_CTRL_DMAWAIT_COUNT(v)  \
		(((v) << 16) & BM_SPDIF_CTRL_DMAWAIT_COUNT)
#define BP_SPDIF_CTRL_RSRVD0	6
#define BM_SPDIF_CTRL_RSRVD0	0x0000FFC0
#define BF_SPDIF_CTRL_RSRVD0(v)  \
		(((v) << 6) & BM_SPDIF_CTRL_RSRVD0)
#define BM_SPDIF_CTRL_WAIT_END_XFER	0x00000020
#define BM_SPDIF_CTRL_WORD_LENGTH	0x00000010
#define BM_SPDIF_CTRL_FIFO_UNDERFLOW_IRQ	0x00000008
#define BM_SPDIF_CTRL_FIFO_OVERFLOW_IRQ	0x00000004
#define BM_SPDIF_CTRL_FIFO_ERROR_IRQ_EN	0x00000002
#define BM_SPDIF_CTRL_RUN	0x00000001

#define HW_SPDIF_STAT	(0x00000010)
#define HW_SPDIF_STAT_SET	(0x00000014)
#define HW_SPDIF_STAT_CLR	(0x00000018)
#define HW_SPDIF_STAT_TOG	(0x0000001c)

#define BM_SPDIF_STAT_PRESENT	0x80000000
#define BP_SPDIF_STAT_RSRVD1	1
#define BM_SPDIF_STAT_RSRVD1	0x7FFFFFFE
#define BF_SPDIF_STAT_RSRVD1(v)  \
		(((v) << 1) & BM_SPDIF_STAT_RSRVD1)
#define BM_SPDIF_STAT_END_XFER	0x00000001

#define HW_SPDIF_FRAMECTRL	(0x00000020)
#define HW_SPDIF_FRAMECTRL_SET	(0x00000024)
#define HW_SPDIF_FRAMECTRL_CLR	(0x00000028)
#define HW_SPDIF_FRAMECTRL_TOG	(0x0000002c)

#define BP_SPDIF_FRAMECTRL_RSRVD2	18
#define BM_SPDIF_FRAMECTRL_RSRVD2	0xFFFC0000
#define BF_SPDIF_FRAMECTRL_RSRVD2(v) \
		(((v) << 18) & BM_SPDIF_FRAMECTRL_RSRVD2)
#define BM_SPDIF_FRAMECTRL_V_CONFIG	0x00020000
#define BM_SPDIF_FRAMECTRL_AUTO_MUTE	0x00010000
#define BM_SPDIF_FRAMECTRL_RSRVD1	0x00008000
#define BM_SPDIF_FRAMECTRL_USER_DATA	0x00004000
#define BM_SPDIF_FRAMECTRL_V	0x00002000
#define BM_SPDIF_FRAMECTRL_L	0x00001000
#define BM_SPDIF_FRAMECTRL_RSRVD0	0x00000800
#define BP_SPDIF_FRAMECTRL_CC	4
#define BM_SPDIF_FRAMECTRL_CC	0x000007F0
#define BF_SPDIF_FRAMECTRL_CC(v)  \
		(((v) << 4) & BM_SPDIF_FRAMECTRL_CC)
#define BM_SPDIF_FRAMECTRL_PRE	0x00000008
#define BM_SPDIF_FRAMECTRL_COPY	0x00000004
#define BM_SPDIF_FRAMECTRL_AUDIO	0x00000002
#define BM_SPDIF_FRAMECTRL_PRO	0x00000001

#define HW_SPDIF_SRR	(0x00000030)
#define HW_SPDIF_SRR_SET	(0x00000034)
#define HW_SPDIF_SRR_CLR	(0x00000038)
#define HW_SPDIF_SRR_TOG	(0x0000003c)

#define BM_SPDIF_SRR_RSRVD1	0x80000000
#define BP_SPDIF_SRR_BASEMULT	28
#define BM_SPDIF_SRR_BASEMULT	0x70000000
#define BF_SPDIF_SRR_BASEMULT(v)  \
		(((v) << 28) & BM_SPDIF_SRR_BASEMULT)
#define BP_SPDIF_SRR_RSRVD0	20
#define BM_SPDIF_SRR_RSRVD0	0x0FF00000
#define BF_SPDIF_SRR_RSRVD0(v)  \
		(((v) << 20) & BM_SPDIF_SRR_RSRVD0)
#define BP_SPDIF_SRR_RATE	0
#define BM_SPDIF_SRR_RATE	0x000FFFFF
#define BF_SPDIF_SRR_RATE(v)  \
		(((v) << 0) & BM_SPDIF_SRR_RATE)

#define HW_SPDIF_DEBUG	(0x00000040)
#define HW_SPDIF_DEBUG_SET	(0x00000044)
#define HW_SPDIF_DEBUG_CLR	(0x00000048)
#define HW_SPDIF_DEBUG_TOG	(0x0000004c)

#define BP_SPDIF_DEBUG_RSRVD1	2
#define BM_SPDIF_DEBUG_RSRVD1	0xFFFFFFFC
#define BF_SPDIF_DEBUG_RSRVD1(v) \
		(((v) << 2) & BM_SPDIF_DEBUG_RSRVD1)
#define BM_SPDIF_DEBUG_DMA_PREQ	0x00000002
#define BM_SPDIF_DEBUG_FIFO_STATUS	0x00000001

#define HW_SPDIF_DATA	(0x00000050)
#define HW_SPDIF_DATA_SET	(0x00000054)
#define HW_SPDIF_DATA_CLR	(0x00000058)
#define HW_SPDIF_DATA_TOG	(0x0000005c)

#define BP_SPDIF_DATA_HIGH	16
#define BM_SPDIF_DATA_HIGH	0xFFFF0000
#define BF_SPDIF_DATA_HIGH(v) \
		(((v) << 16) & BM_SPDIF_DATA_HIGH)
#define BP_SPDIF_DATA_LOW	0
#define BM_SPDIF_DATA_LOW	0x0000FFFF
#define BF_SPDIF_DATA_LOW(v)  \
		(((v) << 0) & BM_SPDIF_DATA_LOW)

#define HW_SPDIF_VERSION	(0x00000060)

#define BP_SPDIF_VERSION_MAJOR	24
#define BM_SPDIF_VERSION_MAJOR	0xFF000000
#define BF_SPDIF_VERSION_MAJOR(v) \
		(((v) << 24) & BM_SPDIF_VERSION_MAJOR)
#define BP_SPDIF_VERSION_MINOR	16
#define BM_SPDIF_VERSION_MINOR	0x00FF0000
#define BF_SPDIF_VERSION_MINOR(v)  \
		(((v) << 16) & BM_SPDIF_VERSION_MINOR)
#define BP_SPDIF_VERSION_STEP	0
#define BM_SPDIF_VERSION_STEP	0x0000FFFF
#define BF_SPDIF_VERSION_STEP(v)  \
		(((v) << 0) & BM_SPDIF_VERSION_STEP)

#define MXS_SPDIF_RATES         (SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_44100 | \
				SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_64000 | \
				SNDRV_PCM_RATE_88200 | SNDRV_PCM_RATE_96000)

#define MXS_SPDIF_FORMATS       (SNDRV_PCM_FMTBIT_S16_LE | \
				SNDRV_PCM_FMTBIT_S20_3LE | \
				SNDRV_PCM_FMTBIT_S24_LE)

extern struct snd_soc_dai mxs_spdif_codec_dai;
extern struct snd_soc_codec_device soc_spdif_codec_dev_mxs;

#endif /* __MXS_SPDIF_CODEC_H */