aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/tegra/tegra20_spdif.h
diff options
context:
space:
mode:
Diffstat (limited to 'sound/soc/tegra/tegra20_spdif.h')
-rw-r--r--sound/soc/tegra/tegra20_spdif.h398
1 files changed, 199 insertions, 199 deletions
diff --git a/sound/soc/tegra/tegra20_spdif.h b/sound/soc/tegra/tegra20_spdif.h
index 001f9dcd2033..823af4c6bb7c 100644
--- a/sound/soc/tegra/tegra20_spdif.h
+++ b/sound/soc/tegra/tegra20_spdif.h
@@ -23,83 +23,83 @@
23 * 23 *
24 */ 24 */
25 25
26#ifndef __TEGRA_SPDIF_H__ 26#ifndef __TEGRA20_SPDIF_H__
27#define __TEGRA_SPDIF_H__ 27#define __TEGRA20_SPDIF_H__
28 28
29#include "tegra_pcm.h" 29#include "tegra_pcm.h"
30 30
31/* Offsets from TEGRA_SPDIF_BASE */ 31/* Offsets from TEGRA20_SPDIF_BASE */
32 32
33#define TEGRA_SPDIF_CTRL 0x0 33#define TEGRA20_SPDIF_CTRL 0x0
34#define TEGRA_SPDIF_STATUS 0x4 34#define TEGRA20_SPDIF_STATUS 0x4
35#define TEGRA_SPDIF_STROBE_CTRL 0x8 35#define TEGRA20_SPDIF_STROBE_CTRL 0x8
36#define TEGRA_SPDIF_DATA_FIFO_CSR 0x0C 36#define TEGRA20_SPDIF_DATA_FIFO_CSR 0x0C
37#define TEGRA_SPDIF_DATA_OUT 0x40 37#define TEGRA20_SPDIF_DATA_OUT 0x40
38#define TEGRA_SPDIF_DATA_IN 0x80 38#define TEGRA20_SPDIF_DATA_IN 0x80
39#define TEGRA_SPDIF_CH_STA_RX_A 0x100 39#define TEGRA20_SPDIF_CH_STA_RX_A 0x100
40#define TEGRA_SPDIF_CH_STA_RX_B 0x104 40#define TEGRA20_SPDIF_CH_STA_RX_B 0x104
41#define TEGRA_SPDIF_CH_STA_RX_C 0x108 41#define TEGRA20_SPDIF_CH_STA_RX_C 0x108
42#define TEGRA_SPDIF_CH_STA_RX_D 0x10C 42#define TEGRA20_SPDIF_CH_STA_RX_D 0x10C
43#define TEGRA_SPDIF_CH_STA_RX_E 0x110 43#define TEGRA20_SPDIF_CH_STA_RX_E 0x110
44#define TEGRA_SPDIF_CH_STA_RX_F 0x114 44#define TEGRA20_SPDIF_CH_STA_RX_F 0x114
45#define TEGRA_SPDIF_CH_STA_TX_A 0x140 45#define TEGRA20_SPDIF_CH_STA_TX_A 0x140
46#define TEGRA_SPDIF_CH_STA_TX_B 0x144 46#define TEGRA20_SPDIF_CH_STA_TX_B 0x144
47#define TEGRA_SPDIF_CH_STA_TX_C 0x148 47#define TEGRA20_SPDIF_CH_STA_TX_C 0x148
48#define TEGRA_SPDIF_CH_STA_TX_D 0x14C 48#define TEGRA20_SPDIF_CH_STA_TX_D 0x14C
49#define TEGRA_SPDIF_CH_STA_TX_E 0x150 49#define TEGRA20_SPDIF_CH_STA_TX_E 0x150
50#define TEGRA_SPDIF_CH_STA_TX_F 0x154 50#define TEGRA20_SPDIF_CH_STA_TX_F 0x154
51#define TEGRA_SPDIF_USR_STA_RX_A 0x180 51#define TEGRA20_SPDIF_USR_STA_RX_A 0x180
52#define TEGRA_SPDIF_USR_DAT_TX_A 0x1C0 52#define TEGRA20_SPDIF_USR_DAT_TX_A 0x1C0
53 53
54/* Fields in TEGRA_SPDIF_CTRL */ 54/* Fields in TEGRA20_SPDIF_CTRL */
55 55
56/* Start capturing from 0=right, 1=left channel */ 56/* Start capturing from 0=right, 1=left channel */
57#define TEGRA_SPDIF_CTRL_CAP_LC (1 << 30) 57#define TEGRA20_SPDIF_CTRL_CAP_LC (1 << 30)
58 58
59/* SPDIF receiver(RX) enable */ 59/* SPDIF receiver(RX) enable */
60#define TEGRA_SPDIF_CTRL_RX_EN (1 << 29) 60#define TEGRA20_SPDIF_CTRL_RX_EN (1 << 29)
61 61
62/* SPDIF Transmitter(TX) enable */ 62/* SPDIF Transmitter(TX) enable */
63#define TEGRA_SPDIF_CTRL_TX_EN (1 << 28) 63#define TEGRA20_SPDIF_CTRL_TX_EN (1 << 28)
64 64
65/* Transmit Channel status */ 65/* Transmit Channel status */
66#define TEGRA_SPDIF_CTRL_TC_EN (1 << 27) 66#define TEGRA20_SPDIF_CTRL_TC_EN (1 << 27)
67 67
68/* Transmit user Data */ 68/* Transmit user Data */
69#define TEGRA_SPDIF_CTRL_TU_EN (1 << 26) 69#define TEGRA20_SPDIF_CTRL_TU_EN (1 << 26)
70 70
71/* Interrupt on transmit error */ 71/* Interrupt on transmit error */
72#define TEGRA_SPDIF_CTRL_IE_TXE (1 << 25) 72#define TEGRA20_SPDIF_CTRL_IE_TXE (1 << 25)
73 73
74/* Interrupt on receive error */ 74/* Interrupt on receive error */
75#define TEGRA_SPDIF_CTRL_IE_RXE (1 << 24) 75#define TEGRA20_SPDIF_CTRL_IE_RXE (1 << 24)
76 76
77/* Interrupt on invalid preamble */ 77/* Interrupt on invalid preamble */
78#define TEGRA_SPDIF_CTRL_IE_P (1 << 23) 78#define TEGRA20_SPDIF_CTRL_IE_P (1 << 23)
79 79
80/* Interrupt on "B" preamble */ 80/* Interrupt on "B" preamble */
81#define TEGRA_SPDIF_CTRL_IE_B (1 << 22) 81#define TEGRA20_SPDIF_CTRL_IE_B (1 << 22)
82 82
83/* Interrupt when block of channel status received */ 83/* Interrupt when block of channel status received */
84#define TEGRA_SPDIF_CTRL_IE_C (1 << 21) 84#define TEGRA20_SPDIF_CTRL_IE_C (1 << 21)
85 85
86/* Interrupt when a valid information unit (IU) is received */ 86/* Interrupt when a valid information unit (IU) is received */
87#define TEGRA_SPDIF_CTRL_IE_U (1 << 20) 87#define TEGRA20_SPDIF_CTRL_IE_U (1 << 20)
88 88
89/* Interrupt when RX user FIFO attention level is reached */ 89/* Interrupt when RX user FIFO attention level is reached */
90#define TEGRA_SPDIF_CTRL_QE_RU (1 << 19) 90#define TEGRA20_SPDIF_CTRL_QE_RU (1 << 19)
91 91
92/* Interrupt when TX user FIFO attention level is reached */ 92/* Interrupt when TX user FIFO attention level is reached */
93#define TEGRA_SPDIF_CTRL_QE_TU (1 << 18) 93#define TEGRA20_SPDIF_CTRL_QE_TU (1 << 18)
94 94
95/* Interrupt when RX data FIFO attention level is reached */ 95/* Interrupt when RX data FIFO attention level is reached */
96#define TEGRA_SPDIF_CTRL_QE_RX (1 << 17) 96#define TEGRA20_SPDIF_CTRL_QE_RX (1 << 17)
97 97
98/* Interrupt when TX data FIFO attention level is reached */ 98/* Interrupt when TX data FIFO attention level is reached */
99#define TEGRA_SPDIF_CTRL_QE_TX (1 << 16) 99#define TEGRA20_SPDIF_CTRL_QE_TX (1 << 16)
100 100
101/* Loopback test mode enable */ 101/* Loopback test mode enable */
102#define TEGRA_SPDIF_CTRL_LBK_EN (1 << 15) 102#define TEGRA20_SPDIF_CTRL_LBK_EN (1 << 15)
103 103
104/* 104/*
105 * Pack data mode: 105 * Pack data mode:
@@ -107,7 +107,7 @@
107 * interface data bit size). 107 * interface data bit size).
108 * 1 = Packeted left/right channel data into a single word. 108 * 1 = Packeted left/right channel data into a single word.
109 */ 109 */
110#define TEGRA_SPDIF_CTRL_PACK (1 << 14) 110#define TEGRA20_SPDIF_CTRL_PACK (1 << 14)
111 111
112/* 112/*
113 * 00 = 16bit data 113 * 00 = 16bit data
@@ -115,19 +115,19 @@
115 * 10 = 24bit data 115 * 10 = 24bit data
116 * 11 = raw data 116 * 11 = raw data
117 */ 117 */
118#define TEGRA_SPDIF_BIT_MODE_16BIT 0 118#define TEGRA20_SPDIF_BIT_MODE_16BIT 0
119#define TEGRA_SPDIF_BIT_MODE_20BIT 1 119#define TEGRA20_SPDIF_BIT_MODE_20BIT 1
120#define TEGRA_SPDIF_BIT_MODE_24BIT 2 120#define TEGRA20_SPDIF_BIT_MODE_24BIT 2
121#define TEGRA_SPDIF_BIT_MODE_RAW 3 121#define TEGRA20_SPDIF_BIT_MODE_RAW 3
122 122
123#define TEGRA_SPDIF_CTRL_BIT_MODE_SHIFT 12 123#define TEGRA20_SPDIF_CTRL_BIT_MODE_SHIFT 12
124#define TEGRA_SPDIF_CTRL_BIT_MODE_MASK (3 << TEGRA_SPDIF_CTRL_BIT_MODE_SHIFT) 124#define TEGRA20_SPDIF_CTRL_BIT_MODE_MASK (3 << TEGRA20_SPDIF_CTRL_BIT_MODE_SHIFT)
125#define TEGRA_SPDIF_CTRL_BIT_MODE_16BIT (TEGRA_SPDIF_BIT_MODE_16BIT << TEGRA_SPDIF_CTRL_BIT_MODE_SHIFT) 125#define TEGRA20_SPDIF_CTRL_BIT_MODE_16BIT (TEGRA20_SPDIF_BIT_MODE_16BIT << TEGRA20_SPDIF_CTRL_BIT_MODE_SHIFT)
126#define TEGRA_SPDIF_CTRL_BIT_MODE_20BIT (TEGRA_SPDIF_BIT_MODE_20BIT << TEGRA_SPDIF_CTRL_BIT_MODE_SHIFT) 126#define TEGRA20_SPDIF_CTRL_BIT_MODE_20BIT (TEGRA20_SPDIF_BIT_MODE_20BIT << TEGRA20_SPDIF_CTRL_BIT_MODE_SHIFT)
127#define TEGRA_SPDIF_CTRL_BIT_MODE_24BIT (TEGRA_SPDIF_BIT_MODE_24BIT << TEGRA_SPDIF_CTRL_BIT_MODE_SHIFT) 127#define TEGRA20_SPDIF_CTRL_BIT_MODE_24BIT (TEGRA20_SPDIF_BIT_MODE_24BIT << TEGRA20_SPDIF_CTRL_BIT_MODE_SHIFT)
128#define TEGRA_SPDIF_CTRL_BIT_MODE_RAW (TEGRA_SPDIF_BIT_MODE_RAW << TEGRA_SPDIF_CTRL_BIT_MODE_SHIFT) 128#define TEGRA20_SPDIF_CTRL_BIT_MODE_RAW (TEGRA20_SPDIF_BIT_MODE_RAW << TEGRA20_SPDIF_CTRL_BIT_MODE_SHIFT)
129 129
130/* Fields in TEGRA_SPDIF_STATUS */ 130/* Fields in TEGRA20_SPDIF_STATUS */
131 131
132/* 132/*
133 * Note: IS_P, IS_B, IS_C, and IS_U are sticky bits. Software must 133 * Note: IS_P, IS_B, IS_C, and IS_U are sticky bits. Software must
@@ -142,7 +142,7 @@
142 * (a) the end of a frame is reached after RX_EN is deeasserted, or 142 * (a) the end of a frame is reached after RX_EN is deeasserted, or
143 * (b) the SPDIF data stream becomes inactive. 143 * (b) the SPDIF data stream becomes inactive.
144 */ 144 */
145#define TEGRA_SPDIF_STATUS_RX_BSY (1 << 29) 145#define TEGRA20_SPDIF_STATUS_RX_BSY (1 << 29)
146 146
147/* 147/*
148 * Transmitter(TX) shifter is busy transmitting data. 148 * Transmitter(TX) shifter is busy transmitting data.
@@ -150,7 +150,7 @@
150 * This bit is deasserted when the end of a frame is reached after 150 * This bit is deasserted when the end of a frame is reached after
151 * TX_EN is deasserted. 151 * TX_EN is deasserted.
152 */ 152 */
153#define TEGRA_SPDIF_STATUS_TX_BSY (1 << 28) 153#define TEGRA20_SPDIF_STATUS_TX_BSY (1 << 28)
154 154
155/* 155/*
156 * TX is busy shifting out channel status. 156 * TX is busy shifting out channel status.
@@ -160,7 +160,7 @@
160 * (a) the end of a frame is reached after TX_EN is deasserted, or 160 * (a) the end of a frame is reached after TX_EN is deasserted, or
161 * (b) CH_STA_TX_F register is loaded into the internal shifter. 161 * (b) CH_STA_TX_F register is loaded into the internal shifter.
162 */ 162 */
163#define TEGRA_SPDIF_STATUS_TC_BSY (1 << 27) 163#define TEGRA20_SPDIF_STATUS_TC_BSY (1 << 27)
164 164
165/* 165/*
166 * TX User data FIFO busy. 166 * TX User data FIFO busy.
@@ -169,173 +169,173 @@
169 * (a) the end of a frame is reached after TX_EN is deasserted, or 169 * (a) the end of a frame is reached after TX_EN is deasserted, or
170 * (b) there's no data left in the TX user FIFO. 170 * (b) there's no data left in the TX user FIFO.
171 */ 171 */
172#define TEGRA_SPDIF_STATUS_TU_BSY (1 << 26) 172#define TEGRA20_SPDIF_STATUS_TU_BSY (1 << 26)
173 173
174/* TX FIFO Underrun error status */ 174/* TX FIFO Underrun error status */
175#define TEGRA_SPDIF_STATUS_TX_ERR (1 << 25) 175#define TEGRA20_SPDIF_STATUS_TX_ERR (1 << 25)
176 176
177/* RX FIFO Overrun error status */ 177/* RX FIFO Overrun error status */
178#define TEGRA_SPDIF_STATUS_RX_ERR (1 << 24) 178#define TEGRA20_SPDIF_STATUS_RX_ERR (1 << 24)
179 179
180/* Preamble status: 0=Preamble OK, 1=bad/missing preamble */ 180/* Preamble status: 0=Preamble OK, 1=bad/missing preamble */
181#define TEGRA_SPDIF_STATUS_IS_P (1 << 23) 181#define TEGRA20_SPDIF_STATUS_IS_P (1 << 23)
182 182
183/* B-preamble detection status: 0=not detected, 1=B-preamble detected */ 183/* B-preamble detection status: 0=not detected, 1=B-preamble detected */
184#define TEGRA_SPDIF_STATUS_IS_B (1 << 22) 184#define TEGRA20_SPDIF_STATUS_IS_B (1 << 22)
185 185
186/* 186/*
187 * RX channel block data receive status: 187 * RX channel block data receive status:
188 * 0=entire block not recieved yet. 188 * 0=entire block not recieved yet.
189 * 1=received entire block of channel status, 189 * 1=received entire block of channel status,
190 */ 190 */
191#define TEGRA_SPDIF_STATUS_IS_C (1 << 21) 191#define TEGRA20_SPDIF_STATUS_IS_C (1 << 21)
192 192
193/* RX User Data Valid flag: 1=valid IU detected, 0 = no IU detected. */ 193/* RX User Data Valid flag: 1=valid IU detected, 0 = no IU detected. */
194#define TEGRA_SPDIF_STATUS_IS_U (1 << 20) 194#define TEGRA20_SPDIF_STATUS_IS_U (1 << 20)
195 195
196/* 196/*
197 * RX User FIFO Status: 197 * RX User FIFO Status:
198 * 1=attention level reached, 0=attention level not reached. 198 * 1=attention level reached, 0=attention level not reached.
199 */ 199 */
200#define TEGRA_SPDIF_STATUS_QS_RU (1 << 19) 200#define TEGRA20_SPDIF_STATUS_QS_RU (1 << 19)
201 201
202/* 202/*
203 * TX User FIFO Status: 203 * TX User FIFO Status:
204 * 1=attention level reached, 0=attention level not reached. 204 * 1=attention level reached, 0=attention level not reached.
205 */ 205 */
206#define TEGRA_SPDIF_STATUS_QS_TU (1 << 18) 206#define TEGRA20_SPDIF_STATUS_QS_TU (1 << 18)
207 207
208/* 208/*
209 * RX Data FIFO Status: 209 * RX Data FIFO Status:
210 * 1=attention level reached, 0=attention level not reached. 210 * 1=attention level reached, 0=attention level not reached.
211 */ 211 */
212#define TEGRA_SPDIF_STATUS_QS_RX (1 << 17) 212#define TEGRA20_SPDIF_STATUS_QS_RX (1 << 17)
213 213
214/* 214/*
215 * TX Data FIFO Status: 215 * TX Data FIFO Status:
216 * 1=attention level reached, 0=attention level not reached. 216 * 1=attention level reached, 0=attention level not reached.
217 */ 217 */
218#define TEGRA_SPDIF_STATUS_QS_TX (1 << 16) 218#define TEGRA20_SPDIF_STATUS_QS_TX (1 << 16)
219 219
220/* Fields in TEGRA_SPDIF_STROBE_CTRL */ 220/* Fields in TEGRA20_SPDIF_STROBE_CTRL */
221 221
222/* 222/*
223 * Indicates the approximate number of detected SPDIFIN clocks within a 223 * Indicates the approximate number of detected SPDIFIN clocks within a
224 * bi-phase period. 224 * bi-phase period.
225 */ 225 */
226#define TEGRA_SPDIF_STROBE_CTRL_PERIOD_SHIFT 16 226#define TEGRA20_SPDIF_STROBE_CTRL_PERIOD_SHIFT 16
227#define TEGRA_SPDIF_STROBE_CTRL_PERIOD_MASK (0xff << TEGRA_SPDIF_STROBE_CTRL_PERIOD_SHIFT) 227#define TEGRA20_SPDIF_STROBE_CTRL_PERIOD_MASK (0xff << TEGRA20_SPDIF_STROBE_CTRL_PERIOD_SHIFT)
228 228
229/* Data strobe mode: 0=Auto-locked 1=Manual locked */ 229/* Data strobe mode: 0=Auto-locked 1=Manual locked */
230#define TEGRA_SPDIF_STROBE_CTRL_STROBE (1 << 15) 230#define TEGRA20_SPDIF_STROBE_CTRL_STROBE (1 << 15)
231 231
232/* 232/*
233 * Manual data strobe time within the bi-phase clock period (in terms of 233 * Manual data strobe time within the bi-phase clock period (in terms of
234 * the number of over-sampling clocks). 234 * the number of over-sampling clocks).
235 */ 235 */
236#define TEGRA_SPDIF_STROBE_CTRL_DATA_STROBES_SHIFT 8 236#define TEGRA20_SPDIF_STROBE_CTRL_DATA_STROBES_SHIFT 8
237#define TEGRA_SPDIF_STROBE_CTRL_DATA_STROBES_MASK (0x1f << TEGRA_SPDIF_STROBE_CTRL_DATA_STROBES_SHIFT) 237#define TEGRA20_SPDIF_STROBE_CTRL_DATA_STROBES_MASK (0x1f << TEGRA20_SPDIF_STROBE_CTRL_DATA_STROBES_SHIFT)
238 238
239/* 239/*
240 * Manual SPDIFIN bi-phase clock period (in terms of the number of 240 * Manual SPDIFIN bi-phase clock period (in terms of the number of
241 * over-sampling clocks). 241 * over-sampling clocks).
242 */ 242 */
243#define TEGRA_SPDIF_STROBE_CTRL_CLOCK_PERIOD_SHIFT 0 243#define TEGRA20_SPDIF_STROBE_CTRL_CLOCK_PERIOD_SHIFT 0
244#define TEGRA_SPDIF_STROBE_CTRL_CLOCK_PERIOD_MASK (0x3f << TEGRA_SPDIF_STROBE_CTRL_CLOCK_PERIOD_SHIFT) 244#define TEGRA20_SPDIF_STROBE_CTRL_CLOCK_PERIOD_MASK (0x3f << TEGRA20_SPDIF_STROBE_CTRL_CLOCK_PERIOD_SHIFT)
245 245
246/* Fields in SPDIF_DATA_FIFO_CSR */ 246/* Fields in SPDIF_DATA_FIFO_CSR */
247 247
248/* Clear Receiver User FIFO (RX USR.FIFO) */ 248/* Clear Receiver User FIFO (RX USR.FIFO) */
249#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_CLR (1 << 31) 249#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_CLR (1 << 31)
250 250
251#define TEGRA_SPDIF_FIFO_ATN_LVL_U_ONE_SLOT 0 251#define TEGRA20_SPDIF_FIFO_ATN_LVL_U_ONE_SLOT 0
252#define TEGRA_SPDIF_FIFO_ATN_LVL_U_TWO_SLOTS 1 252#define TEGRA20_SPDIF_FIFO_ATN_LVL_U_TWO_SLOTS 1
253#define TEGRA_SPDIF_FIFO_ATN_LVL_U_THREE_SLOTS 2 253#define TEGRA20_SPDIF_FIFO_ATN_LVL_U_THREE_SLOTS 2
254#define TEGRA_SPDIF_FIFO_ATN_LVL_U_FOUR_SLOTS 3 254#define TEGRA20_SPDIF_FIFO_ATN_LVL_U_FOUR_SLOTS 3
255 255
256/* RU FIFO attention level */ 256/* RU FIFO attention level */
257#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT 29 257#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT 29
258#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_MASK \ 258#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_MASK \
259 (0x3 << TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT) 259 (0x3 << TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT)
260#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU1_WORD_FULL \ 260#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU1_WORD_FULL \
261 (TEGRA_SPDIF_FIFO_ATN_LVL_U_ONE_SLOT << TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT) 261 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_ONE_SLOT << TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT)
262#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU2_WORD_FULL \ 262#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU2_WORD_FULL \
263 (TEGRA_SPDIF_FIFO_ATN_LVL_U_TWO_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT) 263 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_TWO_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT)
264#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU3_WORD_FULL \ 264#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU3_WORD_FULL \
265 (TEGRA_SPDIF_FIFO_ATN_LVL_U_THREE_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT) 265 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_THREE_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT)
266#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU4_WORD_FULL \ 266#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_RU4_WORD_FULL \
267 (TEGRA_SPDIF_FIFO_ATN_LVL_U_FOUR_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT) 267 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_FOUR_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_RU_ATN_LVL_SHIFT)
268 268
269/* Number of RX USR.FIFO levels with valid data. */ 269/* Number of RX USR.FIFO levels with valid data. */
270#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_FULL_COUNT_SHIFT 24 270#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_FULL_COUNT_SHIFT 24
271#define TEGRA_SPDIF_DATA_FIFO_CSR_RU_FULL_COUNT_MASK (0x1f << TEGRA_SPDIF_DATA_FIFO_CSR_RU_FULL_COUNT_SHIFT) 271#define TEGRA20_SPDIF_DATA_FIFO_CSR_RU_FULL_COUNT_MASK (0x1f << TEGRA20_SPDIF_DATA_FIFO_CSR_RU_FULL_COUNT_SHIFT)
272 272
273/* Clear Transmitter User FIFO (TX USR.FIFO) */ 273/* Clear Transmitter User FIFO (TX USR.FIFO) */
274#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_CLR (1 << 23) 274#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_CLR (1 << 23)
275 275
276/* TU FIFO attention level */ 276/* TU FIFO attention level */
277#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT 21 277#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT 21
278#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_MASK \ 278#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_MASK \
279 (0x3 << TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT) 279 (0x3 << TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT)
280#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU1_WORD_FULL \ 280#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU1_WORD_FULL \
281 (TEGRA_SPDIF_FIFO_ATN_LVL_U_ONE_SLOT << TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT) 281 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_ONE_SLOT << TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT)
282#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU2_WORD_FULL \ 282#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU2_WORD_FULL \
283 (TEGRA_SPDIF_FIFO_ATN_LVL_U_TWO_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT) 283 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_TWO_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT)
284#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU3_WORD_FULL \ 284#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU3_WORD_FULL \
285 (TEGRA_SPDIF_FIFO_ATN_LVL_U_THREE_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT) 285 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_THREE_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT)
286#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU4_WORD_FULL \ 286#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_TU4_WORD_FULL \
287 (TEGRA_SPDIF_FIFO_ATN_LVL_U_FOUR_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT) 287 (TEGRA20_SPDIF_FIFO_ATN_LVL_U_FOUR_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_TU_ATN_LVL_SHIFT)
288 288
289/* Number of TX USR.FIFO levels that could be filled. */ 289/* Number of TX USR.FIFO levels that could be filled. */
290#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_EMPTY_COUNT_SHIFT 16 290#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_EMPTY_COUNT_SHIFT 16
291#define TEGRA_SPDIF_DATA_FIFO_CSR_TU_EMPTY_COUNT_MASK (0x1f << SPDIF_DATA_FIFO_CSR_TU_EMPTY_COUNT_SHIFT) 291#define TEGRA20_SPDIF_DATA_FIFO_CSR_TU_EMPTY_COUNT_MASK (0x1f << SPDIF_DATA_FIFO_CSR_TU_EMPTY_COUNT_SHIFT)
292 292
293/* Clear Receiver Data FIFO (RX DATA.FIFO) */ 293/* Clear Receiver Data FIFO (RX DATA.FIFO) */
294#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_CLR (1 << 15) 294#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_CLR (1 << 15)
295 295
296#define TEGRA_SPDIF_FIFO_ATN_LVL_D_ONE_SLOT 0 296#define TEGRA20_SPDIF_FIFO_ATN_LVL_D_ONE_SLOT 0
297#define TEGRA_SPDIF_FIFO_ATN_LVL_D_FOUR_SLOTS 1 297#define TEGRA20_SPDIF_FIFO_ATN_LVL_D_FOUR_SLOTS 1
298#define TEGRA_SPDIF_FIFO_ATN_LVL_D_EIGHT_SLOTS 2 298#define TEGRA20_SPDIF_FIFO_ATN_LVL_D_EIGHT_SLOTS 2
299#define TEGRA_SPDIF_FIFO_ATN_LVL_D_TWELVE_SLOTS 3 299#define TEGRA20_SPDIF_FIFO_ATN_LVL_D_TWELVE_SLOTS 3
300 300
301/* RU FIFO attention level */ 301/* RU FIFO attention level */
302#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT 13 302#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT 13
303#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_MASK \ 303#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_MASK \
304 (0x3 << TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT) 304 (0x3 << TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT)
305#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU1_WORD_FULL \ 305#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU1_WORD_FULL \
306 (TEGRA_SPDIF_FIFO_ATN_LVL_D_ONE_SLOT << TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT) 306 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_ONE_SLOT << TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT)
307#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU4_WORD_FULL \ 307#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU4_WORD_FULL \
308 (TEGRA_SPDIF_FIFO_ATN_LVL_D_FOUR_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT) 308 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_FOUR_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT)
309#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU8_WORD_FULL \ 309#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU8_WORD_FULL \
310 (TEGRA_SPDIF_FIFO_ATN_LVL_D_EIGHT_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT) 310 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_EIGHT_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT)
311#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU12_WORD_FULL \ 311#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_RU12_WORD_FULL \
312 (TEGRA_SPDIF_FIFO_ATN_LVL_D_TWELVE_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT) 312 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_TWELVE_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_RX_ATN_LVL_SHIFT)
313 313
314/* Number of RX DATA.FIFO levels with valid data. */ 314/* Number of RX DATA.FIFO levels with valid data. */
315#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_FULL_COUNT_SHIFT 8 315#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_FULL_COUNT_SHIFT 8
316#define TEGRA_SPDIF_DATA_FIFO_CSR_RX_FULL_COUNT_MASK (0x1f << TEGRA_SPDIF_DATA_FIFO_CSR_RX_FULL_COUNT_SHIFT) 316#define TEGRA20_SPDIF_DATA_FIFO_CSR_RX_FULL_COUNT_MASK (0x1f << TEGRA20_SPDIF_DATA_FIFO_CSR_RX_FULL_COUNT_SHIFT)
317 317
318/* Clear Transmitter Data FIFO (TX DATA.FIFO) */ 318/* Clear Transmitter Data FIFO (TX DATA.FIFO) */
319#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_CLR (1 << 7) 319#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_CLR (1 << 7)
320 320
321/* TU FIFO attention level */ 321/* TU FIFO attention level */
322#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT 5 322#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT 5
323#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_MASK \ 323#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_MASK \
324 (0x3 << TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT) 324 (0x3 << TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT)
325#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU1_WORD_FULL \ 325#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU1_WORD_FULL \
326 (TEGRA_SPDIF_FIFO_ATN_LVL_D_ONE_SLOT << TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT) 326 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_ONE_SLOT << TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT)
327#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU4_WORD_FULL \ 327#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU4_WORD_FULL \
328 (TEGRA_SPDIF_FIFO_ATN_LVL_D_FOUR_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT) 328 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_FOUR_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT)
329#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU8_WORD_FULL \ 329#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU8_WORD_FULL \
330 (TEGRA_SPDIF_FIFO_ATN_LVL_D_EIGHT_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT) 330 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_EIGHT_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT)
331#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU12_WORD_FULL \ 331#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_TU12_WORD_FULL \
332 (TEGRA_SPDIF_FIFO_ATN_LVL_D_TWELVE_SLOTS << TEGRA_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT) 332 (TEGRA20_SPDIF_FIFO_ATN_LVL_D_TWELVE_SLOTS << TEGRA20_SPDIF_DATA_FIFO_CSR_TX_ATN_LVL_SHIFT)
333 333
334/* Number of TX DATA.FIFO levels that could be filled. */ 334/* Number of TX DATA.FIFO levels that could be filled. */
335#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_EMPTY_COUNT_SHIFT 0 335#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_EMPTY_COUNT_SHIFT 0
336#define TEGRA_SPDIF_DATA_FIFO_CSR_TX_EMPTY_COUNT_MASK (0x1f << SPDIF_DATA_FIFO_CSR_TX_EMPTY_COUNT_SHIFT) 336#define TEGRA20_SPDIF_DATA_FIFO_CSR_TX_EMPTY_COUNT_MASK (0x1f << SPDIF_DATA_FIFO_CSR_TX_EMPTY_COUNT_SHIFT)
337 337
338/* Fields in TEGRA_SPDIF_DATA_OUT */ 338/* Fields in TEGRA20_SPDIF_DATA_OUT */
339 339
340/* 340/*
341 * This register has 5 different formats: 341 * This register has 5 different formats:
@@ -346,36 +346,36 @@
346 * 16-bit packed (BIT_MODE=00, PACK=1) 346 * 16-bit packed (BIT_MODE=00, PACK=1)
347 */ 347 */
348 348
349#define TEGRA_SPDIF_DATA_OUT_DATA_16_SHIFT 0 349#define TEGRA20_SPDIF_DATA_OUT_DATA_16_SHIFT 0
350#define TEGRA_SPDIF_DATA_OUT_DATA_16_MASK (0xffff << TEGRA_SPDIF_DATA_OUT_DATA_16_SHIFT) 350#define TEGRA20_SPDIF_DATA_OUT_DATA_16_MASK (0xffff << TEGRA20_SPDIF_DATA_OUT_DATA_16_SHIFT)
351 351
352#define TEGRA_SPDIF_DATA_OUT_DATA_20_SHIFT 0 352#define TEGRA20_SPDIF_DATA_OUT_DATA_20_SHIFT 0
353#define TEGRA_SPDIF_DATA_OUT_DATA_20_MASK (0xfffff << TEGRA_SPDIF_DATA_OUT_DATA_20_SHIFT) 353#define TEGRA20_SPDIF_DATA_OUT_DATA_20_MASK (0xfffff << TEGRA20_SPDIF_DATA_OUT_DATA_20_SHIFT)
354 354
355#define TEGRA_SPDIF_DATA_OUT_DATA_24_SHIFT 0 355#define TEGRA20_SPDIF_DATA_OUT_DATA_24_SHIFT 0
356#define TEGRA_SPDIF_DATA_OUT_DATA_24_MASK (0xffffff << TEGRA_SPDIF_DATA_OUT_DATA_24_SHIFT) 356#define TEGRA20_SPDIF_DATA_OUT_DATA_24_MASK (0xffffff << TEGRA20_SPDIF_DATA_OUT_DATA_24_SHIFT)
357 357
358#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_P (1 << 31) 358#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_P (1 << 31)
359#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_C (1 << 30) 359#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_C (1 << 30)
360#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_U (1 << 29) 360#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_U (1 << 29)
361#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_V (1 << 28) 361#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_V (1 << 28)
362 362
363#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_DATA_SHIFT 8 363#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_DATA_SHIFT 8
364#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_DATA_MASK (0xfffff << TEGRA_SPDIF_DATA_OUT_DATA_RAW_DATA_SHIFT) 364#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_DATA_MASK (0xfffff << TEGRA20_SPDIF_DATA_OUT_DATA_RAW_DATA_SHIFT)
365 365
366#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_AUX_SHIFT 4 366#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_AUX_SHIFT 4
367#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_AUX_MASK (0xf << TEGRA_SPDIF_DATA_OUT_DATA_RAW_AUX_SHIFT) 367#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_AUX_MASK (0xf << TEGRA20_SPDIF_DATA_OUT_DATA_RAW_AUX_SHIFT)
368 368
369#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_PREAMBLE_SHIFT 0 369#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_PREAMBLE_SHIFT 0
370#define TEGRA_SPDIF_DATA_OUT_DATA_RAW_PREAMBLE_MASK (0xf << TEGRA_SPDIF_DATA_OUT_DATA_RAW_PREAMBLE_SHIFT) 370#define TEGRA20_SPDIF_DATA_OUT_DATA_RAW_PREAMBLE_MASK (0xf << TEGRA20_SPDIF_DATA_OUT_DATA_RAW_PREAMBLE_SHIFT)
371 371
372#define TEGRA_SPDIF_DATA_OUT_DATA_16_PACKED_RIGHT_SHIFT 16 372#define TEGRA20_SPDIF_DATA_OUT_DATA_16_PACKED_RIGHT_SHIFT 16
373#define TEGRA_SPDIF_DATA_OUT_DATA_16_PACKED_RIGHT_MASK (0xffff << TEGRA_SPDIF_DATA_OUT_DATA_16_PACKED_RIGHT_SHIFT) 373#define TEGRA20_SPDIF_DATA_OUT_DATA_16_PACKED_RIGHT_MASK (0xffff << TEGRA20_SPDIF_DATA_OUT_DATA_16_PACKED_RIGHT_SHIFT)
374 374
375#define TEGRA_SPDIF_DATA_OUT_DATA_16_PACKED_LEFT_SHIFT 0 375#define TEGRA20_SPDIF_DATA_OUT_DATA_16_PACKED_LEFT_SHIFT 0
376#define TEGRA_SPDIF_DATA_OUT_DATA_16_PACKED_LEFT_MASK (0xffff << TEGRA_SPDIF_DATA_OUT_DATA_16_PACKED_LEFT_SHIFT) 376#define TEGRA20_SPDIF_DATA_OUT_DATA_16_PACKED_LEFT_MASK (0xffff << TEGRA20_SPDIF_DATA_OUT_DATA_16_PACKED_LEFT_SHIFT)
377 377
378/* Fields in TEGRA_SPDIF_DATA_IN */ 378/* Fields in TEGRA20_SPDIF_DATA_IN */
379 379
380/* 380/*
381 * This register has 5 different formats: 381 * This register has 5 different formats:
@@ -388,44 +388,44 @@
388 * Bits 31:24 are common to all modes except 16-bit packed 388 * Bits 31:24 are common to all modes except 16-bit packed
389 */ 389 */
390 390
391#define TEGRA_SPDIF_DATA_IN_DATA_P (1 << 31) 391#define TEGRA20_SPDIF_DATA_IN_DATA_P (1 << 31)
392#define TEGRA_SPDIF_DATA_IN_DATA_C (1 << 30) 392#define TEGRA20_SPDIF_DATA_IN_DATA_C (1 << 30)
393#define TEGRA_SPDIF_DATA_IN_DATA_U (1 << 29) 393#define TEGRA20_SPDIF_DATA_IN_DATA_U (1 << 29)
394#define TEGRA_SPDIF_DATA_IN_DATA_V (1 << 28) 394#define TEGRA20_SPDIF_DATA_IN_DATA_V (1 << 28)
395 395
396#define TEGRA_SPDIF_DATA_IN_DATA_PREAMBLE_SHIFT 24 396#define TEGRA20_SPDIF_DATA_IN_DATA_PREAMBLE_SHIFT 24
397#define TEGRA_SPDIF_DATA_IN_DATA_PREAMBLE_MASK (0xf << TEGRA_SPDIF_DATA_IN_DATA_PREAMBLE_SHIFT) 397#define TEGRA20_SPDIF_DATA_IN_DATA_PREAMBLE_MASK (0xf << TEGRA20_SPDIF_DATA_IN_DATA_PREAMBLE_SHIFT)
398 398
399#define TEGRA_SPDIF_DATA_IN_DATA_16_SHIFT 0 399#define TEGRA20_SPDIF_DATA_IN_DATA_16_SHIFT 0
400#define TEGRA_SPDIF_DATA_IN_DATA_16_MASK (0xffff << TEGRA_SPDIF_DATA_IN_DATA_16_SHIFT) 400#define TEGRA20_SPDIF_DATA_IN_DATA_16_MASK (0xffff << TEGRA20_SPDIF_DATA_IN_DATA_16_SHIFT)
401 401
402#define TEGRA_SPDIF_DATA_IN_DATA_20_SHIFT 0 402#define TEGRA20_SPDIF_DATA_IN_DATA_20_SHIFT 0
403#define TEGRA_SPDIF_DATA_IN_DATA_20_MASK (0xfffff << TEGRA_SPDIF_DATA_IN_DATA_20_SHIFT) 403#define TEGRA20_SPDIF_DATA_IN_DATA_20_MASK (0xfffff << TEGRA20_SPDIF_DATA_IN_DATA_20_SHIFT)
404 404
405#define TEGRA_SPDIF_DATA_IN_DATA_24_SHIFT 0 405#define TEGRA20_SPDIF_DATA_IN_DATA_24_SHIFT 0
406#define TEGRA_SPDIF_DATA_IN_DATA_24_MASK (0xffffff << TEGRA_SPDIF_DATA_IN_DATA_24_SHIFT) 406#define TEGRA20_SPDIF_DATA_IN_DATA_24_MASK (0xffffff << TEGRA20_SPDIF_DATA_IN_DATA_24_SHIFT)
407 407
408#define TEGRA_SPDIF_DATA_IN_DATA_RAW_DATA_SHIFT 8 408#define TEGRA20_SPDIF_DATA_IN_DATA_RAW_DATA_SHIFT 8
409#define TEGRA_SPDIF_DATA_IN_DATA_RAW_DATA_MASK (0xfffff << TEGRA_SPDIF_DATA_IN_DATA_RAW_DATA_SHIFT) 409#define TEGRA20_SPDIF_DATA_IN_DATA_RAW_DATA_MASK (0xfffff << TEGRA20_SPDIF_DATA_IN_DATA_RAW_DATA_SHIFT)
410 410
411#define TEGRA_SPDIF_DATA_IN_DATA_RAW_AUX_SHIFT 4 411#define TEGRA20_SPDIF_DATA_IN_DATA_RAW_AUX_SHIFT 4
412#define TEGRA_SPDIF_DATA_IN_DATA_RAW_AUX_MASK (0xf << TEGRA_SPDIF_DATA_IN_DATA_RAW_AUX_SHIFT) 412#define TEGRA20_SPDIF_DATA_IN_DATA_RAW_AUX_MASK (0xf << TEGRA20_SPDIF_DATA_IN_DATA_RAW_AUX_SHIFT)
413 413
414#define TEGRA_SPDIF_DATA_IN_DATA_RAW_PREAMBLE_SHIFT 0 414#define TEGRA20_SPDIF_DATA_IN_DATA_RAW_PREAMBLE_SHIFT 0
415#define TEGRA_SPDIF_DATA_IN_DATA_RAW_PREAMBLE_MASK (0xf << TEGRA_SPDIF_DATA_IN_DATA_RAW_PREAMBLE_SHIFT) 415#define TEGRA20_SPDIF_DATA_IN_DATA_RAW_PREAMBLE_MASK (0xf << TEGRA20_SPDIF_DATA_IN_DATA_RAW_PREAMBLE_SHIFT)
416 416
417#define TEGRA_SPDIF_DATA_IN_DATA_16_PACKED_RIGHT_SHIFT 16 417#define TEGRA20_SPDIF_DATA_IN_DATA_16_PACKED_RIGHT_SHIFT 16
418#define TEGRA_SPDIF_DATA_IN_DATA_16_PACKED_RIGHT_MASK (0xffff << TEGRA_SPDIF_DATA_IN_DATA_16_PACKED_RIGHT_SHIFT) 418#define TEGRA20_SPDIF_DATA_IN_DATA_16_PACKED_RIGHT_MASK (0xffff << TEGRA20_SPDIF_DATA_IN_DATA_16_PACKED_RIGHT_SHIFT)
419 419
420#define TEGRA_SPDIF_DATA_IN_DATA_16_PACKED_LEFT_SHIFT 0 420#define TEGRA20_SPDIF_DATA_IN_DATA_16_PACKED_LEFT_SHIFT 0
421#define TEGRA_SPDIF_DATA_IN_DATA_16_PACKED_LEFT_MASK (0xffff << TEGRA_SPDIF_DATA_IN_DATA_16_PACKED_LEFT_SHIFT) 421#define TEGRA20_SPDIF_DATA_IN_DATA_16_PACKED_LEFT_MASK (0xffff << TEGRA20_SPDIF_DATA_IN_DATA_16_PACKED_LEFT_SHIFT)
422 422
423/* Fields in TEGRA_SPDIF_CH_STA_RX_A */ 423/* Fields in TEGRA20_SPDIF_CH_STA_RX_A */
424/* Fields in TEGRA_SPDIF_CH_STA_RX_B */ 424/* Fields in TEGRA20_SPDIF_CH_STA_RX_B */
425/* Fields in TEGRA_SPDIF_CH_STA_RX_C */ 425/* Fields in TEGRA20_SPDIF_CH_STA_RX_C */
426/* Fields in TEGRA_SPDIF_CH_STA_RX_D */ 426/* Fields in TEGRA20_SPDIF_CH_STA_RX_D */
427/* Fields in TEGRA_SPDIF_CH_STA_RX_E */ 427/* Fields in TEGRA20_SPDIF_CH_STA_RX_E */
428/* Fields in TEGRA_SPDIF_CH_STA_RX_F */ 428/* Fields in TEGRA20_SPDIF_CH_STA_RX_F */
429 429
430/* 430/*
431 * The 6-word receive channel data page buffer holds a block (192 frames) of 431 * The 6-word receive channel data page buffer holds a block (192 frames) of
@@ -433,12 +433,12 @@
433 * bit, and from CH_STA_RX_A to CH_STA_RX_F then back to CH_STA_RX_A. 433 * bit, and from CH_STA_RX_A to CH_STA_RX_F then back to CH_STA_RX_A.
434 */ 434 */
435 435
436/* Fields in TEGRA_SPDIF_CH_STA_TX_A */ 436/* Fields in TEGRA20_SPDIF_CH_STA_TX_A */
437/* Fields in TEGRA_SPDIF_CH_STA_TX_B */ 437/* Fields in TEGRA20_SPDIF_CH_STA_TX_B */
438/* Fields in TEGRA_SPDIF_CH_STA_TX_C */ 438/* Fields in TEGRA20_SPDIF_CH_STA_TX_C */
439/* Fields in TEGRA_SPDIF_CH_STA_TX_D */ 439/* Fields in TEGRA20_SPDIF_CH_STA_TX_D */
440/* Fields in TEGRA_SPDIF_CH_STA_TX_E */ 440/* Fields in TEGRA20_SPDIF_CH_STA_TX_E */
441/* Fields in TEGRA_SPDIF_CH_STA_TX_F */ 441/* Fields in TEGRA20_SPDIF_CH_STA_TX_F */
442 442
443/* 443/*
444 * The 6-word transmit channel data page buffer holds a block (192 frames) of 444 * The 6-word transmit channel data page buffer holds a block (192 frames) of
@@ -446,21 +446,21 @@
446 * bit, and from CH_STA_TX_A to CH_STA_TX_F then back to CH_STA_TX_A. 446 * bit, and from CH_STA_TX_A to CH_STA_TX_F then back to CH_STA_TX_A.
447 */ 447 */
448 448
449/* Fields in TEGRA_SPDIF_USR_STA_RX_A */ 449/* Fields in TEGRA20_SPDIF_USR_STA_RX_A */
450 450
451/* 451/*
452 * This 4-word deep FIFO receives user FIFO field information. The order of 452 * This 4-word deep FIFO receives user FIFO field information. The order of
453 * receive is from LSB to MSB bit. 453 * receive is from LSB to MSB bit.
454 */ 454 */
455 455
456/* Fields in TEGRA_SPDIF_USR_DAT_TX_A */ 456/* Fields in TEGRA20_SPDIF_USR_DAT_TX_A */
457 457
458/* 458/*
459 * This 4-word deep FIFO transmits user FIFO field information. The order of 459 * This 4-word deep FIFO transmits user FIFO field information. The order of
460 * transmission is from LSB to MSB bit. 460 * transmission is from LSB to MSB bit.
461 */ 461 */
462 462
463struct tegra_spdif { 463struct tegra20_spdif {
464 struct clk *clk_spdif_out; 464 struct clk *clk_spdif_out;
465 struct tegra_pcm_dma_params capture_dma_data; 465 struct tegra_pcm_dma_params capture_dma_data;
466 struct tegra_pcm_dma_params playback_dma_data; 466 struct tegra_pcm_dma_params playback_dma_data;